diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..744289d
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,2 @@
+# Project exclude paths
+/target/
\ No newline at end of file
diff --git a/TerraPlusMinusBungeeBridge.iml b/TerraPlusMinusBungeeBridge.iml
new file mode 100644
index 0000000..1932263
--- /dev/null
+++ b/TerraPlusMinusBungeeBridge.iml
@@ -0,0 +1,46 @@
+
+
+
+
+
+
+ BUNGEECORD
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/pom.xml b/pom.xml
new file mode 100644
index 0000000..acc03e7
--- /dev/null
+++ b/pom.xml
@@ -0,0 +1,71 @@
+
+
+ 4.0.0
+
+ de.btegermany
+ TerraPlusMinusBungeeBridge
+ 1.0-SNAPSHOT
+ jar
+
+ TerraPlusMinusBungeeBridge
+
+
+ 1.8
+ UTF-8
+
+
+
+ clean package
+
+
+ org.apache.maven.plugins
+ maven-compiler-plugin
+ 3.8.1
+
+
+ ${java.version}
+
+
+
+ org.apache.maven.plugins
+ maven-shade-plugin
+ 3.2.4
+
+
+ package
+
+ shade
+
+
+ false
+
+
+
+
+
+
+
+ src/main/resources
+ true
+
+
+
+
+
+
+ sonatype
+ https://oss.sonatype.org/content/groups/public/
+
+
+
+
+
+ net.md-5
+ bungeecord-api
+ 1.20-R0.1-SNAPSHOT
+ provided
+
+
+
diff --git a/src/main/java/de/btegermany/terraplusminusbungeebridge/TerraPlusMinusBungeeBridge.java b/src/main/java/de/btegermany/terraplusminusbungeebridge/TerraPlusMinusBungeeBridge.java
new file mode 100644
index 0000000..6f3dcc7
--- /dev/null
+++ b/src/main/java/de/btegermany/terraplusminusbungeebridge/TerraPlusMinusBungeeBridge.java
@@ -0,0 +1,23 @@
+package de.btegermany.terraplusminusbungeebridge;
+
+import de.btegermany.terraplusminusbungeebridge.listener.PluginMessageListener;
+import net.md_5.bungee.api.ProxyServer;
+import net.md_5.bungee.api.plugin.Plugin;
+
+public final class TerraPlusMinusBungeeBridge extends Plugin {
+
+ @Override
+ public void onEnable() {
+ ProxyServer.getInstance().registerChannel("BungeeCord");
+ ProxyServer.getInstance().registerChannel("bungeecord:terraplusminus");
+ ProxyServer.getInstance().getPluginManager().registerListener(this, new PluginMessageListener());
+ // Plugin startup logic
+ }
+
+ @Override
+ public void onDisable() {
+ // Unregister plugin messaging channel
+ ProxyServer.getInstance().getPluginManager().unregisterListeners(this);
+ // --------------------------
+ }
+}
diff --git a/src/main/java/de/btegermany/terraplusminusbungeebridge/listener/PluginMessageListener.java b/src/main/java/de/btegermany/terraplusminusbungeebridge/listener/PluginMessageListener.java
new file mode 100644
index 0000000..13648ea
--- /dev/null
+++ b/src/main/java/de/btegermany/terraplusminusbungeebridge/listener/PluginMessageListener.java
@@ -0,0 +1,51 @@
+package de.btegermany.terraplusminusbungeebridge.listener;
+
+import com.google.common.io.ByteArrayDataInput;
+import com.google.common.io.ByteStreams;
+import net.md_5.bungee.api.ProxyServer;
+import net.md_5.bungee.api.connection.ProxiedPlayer;
+import net.md_5.bungee.api.event.PluginMessageEvent;
+import net.md_5.bungee.api.plugin.Listener;
+import net.md_5.bungee.event.EventHandler;
+
+import java.io.ByteArrayOutputStream;
+import java.io.DataOutputStream;
+import java.io.IOException;
+import java.util.UUID;
+
+public class PluginMessageListener implements Listener {
+ @EventHandler
+ public void onPluginMessage(PluginMessageEvent event) {
+ if (!event.getTag().equalsIgnoreCase("bungeecord:terraplusminus")) return;
+ // get uuid and coordinates from message
+ ByteArrayDataInput dataInput = ByteStreams.newDataInput(event.getData());
+ String uuid = dataInput.readUTF();
+ UUID playerUUID = UUID.fromString(uuid);
+
+ String servername = dataInput.readUTF();
+ String coordinates = dataInput.readUTF();
+
+ // Assuming you have a method to get the player by UUID
+ ProxiedPlayer player = ProxyServer.getInstance().getPlayer(playerUUID);
+ if (player != null) {
+ // Move the player to the specified server
+ sendMessageToBukkitServer(player,servername, coordinates);
+ player.connect(ProxyServer.getInstance().getServerInfo(servername));
+ }
+ }
+
+ // method to send message via messaging channel to bukkit server
+ public void sendMessageToBukkitServer(ProxiedPlayer player, String servername, String coordinates) {
+ ByteArrayOutputStream stream = new ByteArrayOutputStream();
+ DataOutputStream out = new DataOutputStream(stream);
+ try {
+ out.writeUTF(player.getUniqueId().toString());
+ out.writeUTF(coordinates);
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+ ProxyServer.getInstance().getServers().get(servername).sendData("bungeecord:terraplusminus", stream.toByteArray());
+ }
+
+
+}
diff --git a/src/main/resources/bungee.yml b/src/main/resources/bungee.yml
new file mode 100644
index 0000000..99d40d5
--- /dev/null
+++ b/src/main/resources/bungee.yml
@@ -0,0 +1,4 @@
+name: TerraPlusMinusBungeeBridge
+version: '${project.version}'
+main: de.btegermany.terraplusminusbungeebridge.TerraPlusMinusBungeeBridge
+author: Leander