Add Melon Proxy Plugin Files
This commit is contained in:
parent
2bfa8ddaf0
commit
93dc8c4b41
12 changed files with 334 additions and 0 deletions
3
.idea/.gitignore
generated
vendored
Normal file
3
.idea/.gitignore
generated
vendored
Normal file
|
@ -0,0 +1,3 @@
|
|||
# Default ignored files
|
||||
/shelf/
|
||||
/workspace.xml
|
1
.idea/.name
generated
Normal file
1
.idea/.name
generated
Normal file
|
@ -0,0 +1 @@
|
|||
MelonProxy.java
|
15
.idea/compiler.xml
generated
Normal file
15
.idea/compiler.xml
generated
Normal file
|
@ -0,0 +1,15 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="CompilerConfiguration">
|
||||
<annotationProcessing>
|
||||
<profile name="Maven default annotation processors profile" enabled="true">
|
||||
<sourceOutputDir name="target/generated-sources/annotations" />
|
||||
<sourceTestOutputDir name="target/generated-test-sources/test-annotations" />
|
||||
<outputRelativeToContentRoot value="true" />
|
||||
<module name="Melon_Proxy" />
|
||||
<module name="Melon_Proxy_Helper" />
|
||||
<module name="MelonEconomy-Proxy" />
|
||||
</profile>
|
||||
</annotationProcessing>
|
||||
</component>
|
||||
</project>
|
7
.idea/encodings.xml
generated
Normal file
7
.idea/encodings.xml
generated
Normal file
|
@ -0,0 +1,7 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding">
|
||||
<file url="file://$PROJECT_DIR$/src/main/java" charset="UTF-8" />
|
||||
<file url="file://$PROJECT_DIR$/src/main/resources" charset="UTF-8" />
|
||||
</component>
|
||||
</project>
|
30
.idea/jarRepositories.xml
generated
Normal file
30
.idea/jarRepositories.xml
generated
Normal file
|
@ -0,0 +1,30 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="RemoteRepositoriesConfiguration">
|
||||
<remote-repository>
|
||||
<option name="id" value="kyori" />
|
||||
<option name="name" value="kyori" />
|
||||
<option name="url" value="https://repo.kyori.net/repository/maven-public/" />
|
||||
</remote-repository>
|
||||
<remote-repository>
|
||||
<option name="id" value="central" />
|
||||
<option name="name" value="Central Repository" />
|
||||
<option name="url" value="https://repo.maven.apache.org/maven2" />
|
||||
</remote-repository>
|
||||
<remote-repository>
|
||||
<option name="id" value="papermc-repo" />
|
||||
<option name="name" value="papermc-repo" />
|
||||
<option name="url" value="https://repo.papermc.io/repository/maven-public/" />
|
||||
</remote-repository>
|
||||
<remote-repository>
|
||||
<option name="id" value="central" />
|
||||
<option name="name" value="Maven Central repository" />
|
||||
<option name="url" value="https://repo1.maven.org/maven2" />
|
||||
</remote-repository>
|
||||
<remote-repository>
|
||||
<option name="id" value="jboss.community" />
|
||||
<option name="name" value="JBoss Community repository" />
|
||||
<option name="url" value="https://repository.jboss.org/nexus/content/repositories/public/" />
|
||||
</remote-repository>
|
||||
</component>
|
||||
</project>
|
14
.idea/misc.xml
generated
Normal file
14
.idea/misc.xml
generated
Normal file
|
@ -0,0 +1,14 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ExternalStorageConfigurationManager" enabled="true" />
|
||||
<component name="MavenProjectsManager">
|
||||
<option name="originalFiles">
|
||||
<list>
|
||||
<option value="$PROJECT_DIR$/pom.xml" />
|
||||
</list>
|
||||
</option>
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_17" default="true" project-jdk-name="temurin-17" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
</project>
|
10
.idea/modules.xml
generated
Normal file
10
.idea/modules.xml
generated
Normal file
|
@ -0,0 +1,10 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/MelonEconomy-Proxy.iml" filepath="$PROJECT_DIR$/MelonEconomy-Proxy.iml" />
|
||||
<module fileurl="file://$PROJECT_DIR$/Melon_Proxy.iml" filepath="$PROJECT_DIR$/Melon_Proxy.iml" />
|
||||
<module fileurl="file://$PROJECT_DIR$/Melon_Proxy_Helper.iml" filepath="$PROJECT_DIR$/Melon_Proxy_Helper.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
14
MelonEconomy-Proxy.iml
Normal file
14
MelonEconomy-Proxy.iml
Normal file
|
@ -0,0 +1,14 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module version="4">
|
||||
<component name="FacetManager">
|
||||
<facet type="minecraft" name="Minecraft">
|
||||
<configuration>
|
||||
<autoDetectTypes>
|
||||
<platformType>VELOCITY</platformType>
|
||||
<platformType>ADVENTURE</platformType>
|
||||
</autoDetectTypes>
|
||||
<projectReimportVersion>1</projectReimportVersion>
|
||||
</configuration>
|
||||
</facet>
|
||||
</component>
|
||||
</module>
|
14
Melon_Proxy.iml
Normal file
14
Melon_Proxy.iml
Normal file
|
@ -0,0 +1,14 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module version="4">
|
||||
<component name="FacetManager">
|
||||
<facet type="minecraft" name="Minecraft">
|
||||
<configuration>
|
||||
<autoDetectTypes>
|
||||
<platformType>VELOCITY</platformType>
|
||||
<platformType>ADVENTURE</platformType>
|
||||
</autoDetectTypes>
|
||||
<projectReimportVersion>1</projectReimportVersion>
|
||||
</configuration>
|
||||
</facet>
|
||||
</component>
|
||||
</module>
|
13
Melon_Proxy_Helper.iml
Normal file
13
Melon_Proxy_Helper.iml
Normal file
|
@ -0,0 +1,13 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module version="4">
|
||||
<component name="FacetManager">
|
||||
<facet type="minecraft" name="Minecraft">
|
||||
<configuration>
|
||||
<autoDetectTypes>
|
||||
<platformType>VELOCITY</platformType>
|
||||
</autoDetectTypes>
|
||||
<projectReimportVersion>1</projectReimportVersion>
|
||||
</configuration>
|
||||
</facet>
|
||||
</component>
|
||||
</module>
|
62
pom.xml
Normal file
62
pom.xml
Normal file
|
@ -0,0 +1,62 @@
|
|||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
<groupId>org.derek</groupId>
|
||||
<artifactId>MelonEconomy-Proxy</artifactId>
|
||||
<version>1.3.1</version>
|
||||
<packaging>jar</packaging>
|
||||
|
||||
<name>Melon Proxy</name>
|
||||
|
||||
<properties>
|
||||
<java.version>17</java.version>
|
||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||
</properties>
|
||||
|
||||
<repositories>
|
||||
<repository>
|
||||
<id>papermc-repo</id>
|
||||
<url>https://repo.papermc.io/repository/maven-public/</url>
|
||||
</repository>
|
||||
|
||||
<repository>
|
||||
<id>kyori</id>
|
||||
<url>https://repo.kyori.net/repository/maven-public/</url>
|
||||
</repository>
|
||||
</repositories>
|
||||
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>com.velocitypowered</groupId>
|
||||
<artifactId>velocity-api</artifactId>
|
||||
<version>3.3.0-SNAPSHOT</version>
|
||||
<scope>provided</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>net.kyori</groupId>
|
||||
<artifactId>adventure-platform-api</artifactId>
|
||||
<version>4.3.0</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>net.kyori</groupId>
|
||||
<artifactId>adventure-text-minimessage</artifactId>
|
||||
<version>4.14.0</version>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
|
||||
<build>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-compiler-plugin</artifactId>
|
||||
<version>3.8.1</version>
|
||||
<configuration>
|
||||
<source>${java.version}</source>
|
||||
<target>${java.version}</target>
|
||||
</configuration>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
</project>
|
151
src/main/java/org/derek/melon_proxy/MelonProxy.java
Normal file
151
src/main/java/org/derek/melon_proxy/MelonProxy.java
Normal file
|
@ -0,0 +1,151 @@
|
|||
package org.derek.melon_proxy;
|
||||
|
||||
import com.velocitypowered.api.command.CommandSource;
|
||||
import com.velocitypowered.api.command.SimpleCommand;
|
||||
import com.velocitypowered.api.event.Subscribe;
|
||||
import com.velocitypowered.api.event.proxy.ProxyInitializeEvent;
|
||||
import com.velocitypowered.api.plugin.Plugin;
|
||||
import com.velocitypowered.api.proxy.ProxyServer;
|
||||
import com.velocitypowered.api.proxy.server.RegisteredServer;
|
||||
import net.kyori.adventure.text.Component;
|
||||
import net.kyori.adventure.text.minimessage.MiniMessage;
|
||||
|
||||
import javax.inject.Inject;
|
||||
import java.util.Arrays;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
@Plugin(id = "melon_proxy", name = "Melon Proxy", version = "1.3", authors = {"Derek1256"})
|
||||
public class MelonProxy {
|
||||
|
||||
private final ProxyServer server;
|
||||
|
||||
@Inject
|
||||
public MelonProxy(ProxyServer server) {
|
||||
this.server = server;
|
||||
}
|
||||
|
||||
@Subscribe
|
||||
public void onProxyInitialization(ProxyInitializeEvent event) {
|
||||
server.getCommandManager().register("melonproxy", new MelonProxyCommand(server));
|
||||
}
|
||||
|
||||
public static class MelonProxyCommand implements SimpleCommand {
|
||||
|
||||
private final ProxyServer server;
|
||||
private final MiniMessage miniMessage = MiniMessage.miniMessage();
|
||||
|
||||
public MelonProxyCommand(ProxyServer server) {
|
||||
this.server = server;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void execute(Invocation invocation) {
|
||||
CommandSource source = invocation.source();
|
||||
String[] args = invocation.arguments();
|
||||
|
||||
if (args.length == 0) {
|
||||
source.sendMessage(Component.text("Usage: /melonproxy <broadcast|storebroadcast> <args>"));
|
||||
return;
|
||||
}
|
||||
|
||||
String subCommand = args[0].toLowerCase();
|
||||
|
||||
switch (subCommand) {
|
||||
case "broadcast":
|
||||
handleBroadcast(source, String.join(" ", Arrays.copyOfRange(args, 1, args.length)));
|
||||
break;
|
||||
case "storebroadcast":
|
||||
handleStoreBroadcast(source, String.join(" ", Arrays.copyOfRange(args, 1, args.length)));
|
||||
break;
|
||||
default:
|
||||
source.sendMessage(Component.text("Usage: /melonproxy <broadcast|storebroadcast|tebexforward> <args>"));
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
private void handleBroadcast(CommandSource source, String message) {
|
||||
if (message.isEmpty()) {
|
||||
source.sendMessage(miniMessage.deserialize("<red>Usage: /melonproxy broadcast <message>"));
|
||||
return;
|
||||
}
|
||||
|
||||
String formattedMessage = convertLegacyColorsToMiniMessage(message);
|
||||
Component broadcastMessage = miniMessage.deserialize(
|
||||
"<b><gradient:#E2106E:#FC00FF>Melon Nexu</gradient>" +
|
||||
"<gradient:#FC00FF:#E700FF>s</gradient>" +
|
||||
"<gradient:#E700FF:#B008F8> | Pro</gradient>" +
|
||||
"<gradient:#B008F8:#8000EC>xy »</gradient></b> " +
|
||||
"<white>" + formattedMessage + "</white>"
|
||||
);
|
||||
|
||||
for (RegisteredServer registeredServer : server.getAllServers()) {
|
||||
for (var player : registeredServer.getPlayersConnected()) {
|
||||
player.sendMessage(broadcastMessage);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void handleStoreBroadcast(CommandSource source, String message) {
|
||||
if (message.isEmpty()) {
|
||||
source.sendMessage(miniMessage.deserialize("<red>Usage: /melonproxy storebroadcast <message>"));
|
||||
return;
|
||||
}
|
||||
|
||||
String formattedMessage = convertLegacyColorsToMiniMessage(message);
|
||||
Component storeBroadcastMessage = miniMessage.deserialize(
|
||||
"<b><gradient:#E2106E:#FC00FF>Melon Nexu</gradient>" +
|
||||
"<gradient:#FC00FF:#E700FF>s</gradient>" +
|
||||
"<gradient:#E700FF:#B008F8> | Sto</gradient>" +
|
||||
"<gradient:#B008F8:#8000EC>re »</gradient></b> " +
|
||||
"<white>" + formattedMessage + "</white>"
|
||||
);
|
||||
|
||||
for (RegisteredServer registeredServer : server.getAllServers()) {
|
||||
if (!registeredServer.getServerInfo().getName().equalsIgnoreCase("prisons")) {
|
||||
for (var player : registeredServer.getPlayersConnected()) {
|
||||
player.sendMessage(storeBroadcastMessage);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
private String convertLegacyColorsToMiniMessage(String message) {
|
||||
Map<String, String> legacyToMiniMessage = new HashMap<>();
|
||||
legacyToMiniMessage.put("&0", "<black>");
|
||||
legacyToMiniMessage.put("&1", "<dark_blue>");
|
||||
legacyToMiniMessage.put("&2", "<dark_green>");
|
||||
legacyToMiniMessage.put("&3", "<dark_aqua>");
|
||||
legacyToMiniMessage.put("&4", "<dark_red>");
|
||||
legacyToMiniMessage.put("&5", "<dark_purple>");
|
||||
legacyToMiniMessage.put("&6", "<gold>");
|
||||
legacyToMiniMessage.put("&7", "<gray>");
|
||||
legacyToMiniMessage.put("&8", "<dark_gray>");
|
||||
legacyToMiniMessage.put("&9", "<blue>");
|
||||
legacyToMiniMessage.put("&a", "<green>");
|
||||
legacyToMiniMessage.put("&b", "<aqua>");
|
||||
legacyToMiniMessage.put("&c", "<red>");
|
||||
legacyToMiniMessage.put("&d", "<light_purple>");
|
||||
legacyToMiniMessage.put("&e", "<yellow>");
|
||||
legacyToMiniMessage.put("&f", "<white>");
|
||||
legacyToMiniMessage.put("&k", "<obfuscated>");
|
||||
legacyToMiniMessage.put("&l", "<bold>");
|
||||
legacyToMiniMessage.put("&m", "<strikethrough>");
|
||||
legacyToMiniMessage.put("&n", "<underline>");
|
||||
legacyToMiniMessage.put("&o", "<italic>");
|
||||
legacyToMiniMessage.put("&r", "<reset>");
|
||||
|
||||
for (Map.Entry<String, String> entry : legacyToMiniMessage.entrySet()) {
|
||||
message = message.replace(entry.getKey(), entry.getValue());
|
||||
}
|
||||
|
||||
return message;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean hasPermission(Invocation invocation) {
|
||||
return invocation.source().hasPermission("melonproxy.use");
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue