SubServers-2/SubServers.Bungee/src/net/ME1312/SubServers/Bungee/Network/Packet/PacketLinkServer.java

183 lines
7.9 KiB
Java
Raw Normal View History

2016-12-24 05:55:17 +01:00
package net.ME1312.SubServers.Bungee.Network.Packet;
2020-11-16 21:34:59 +01:00
import net.ME1312.Galaxi.Library.Map.ObjectMap;
import net.ME1312.Galaxi.Library.Try;
2020-11-16 21:34:59 +01:00
import net.ME1312.Galaxi.Library.Util;
import net.ME1312.SubData.Server.Library.DisconnectReason;
2019-05-11 23:23:31 +02:00
import net.ME1312.SubData.Server.Protocol.Initial.InitialPacket;
2020-11-16 21:34:59 +01:00
import net.ME1312.SubData.Server.Protocol.PacketObjectIn;
import net.ME1312.SubData.Server.Protocol.PacketObjectOut;
2019-04-18 16:02:09 +02:00
import net.ME1312.SubData.Server.SubDataClient;
2019-06-25 23:13:27 +02:00
import net.ME1312.SubServers.Bungee.Event.SubStartedEvent;
2016-12-24 05:55:17 +01:00
import net.ME1312.SubServers.Bungee.Host.Server;
import net.ME1312.SubServers.Bungee.Host.ServerImpl;
2016-12-24 05:55:17 +01:00
import net.ME1312.SubServers.Bungee.Host.SubServer;
import net.ME1312.SubServers.Bungee.Host.SubServerImpl;
2019-05-17 00:36:41 +02:00
import net.ME1312.SubServers.Bungee.Library.Compatibility.Logger;
import net.ME1312.SubServers.Bungee.SubAPI;
import net.ME1312.SubServers.Bungee.SubProxy;
2020-11-16 21:34:59 +01:00
2019-06-25 23:13:27 +02:00
import net.md_5.bungee.api.ProxyServer;
2016-12-05 04:21:04 +01:00
import java.net.InetSocketAddress;
import java.util.*;
import java.util.concurrent.TimeUnit;
2016-12-05 04:21:04 +01:00
2017-01-07 20:06:54 +01:00
/**
* Link Server Packet
*/
2019-05-11 23:23:31 +02:00
public class PacketLinkServer implements InitialPacket, PacketObjectIn<Integer>, PacketObjectOut<Integer> {
public static boolean strict = true;
private SubProxy plugin;
2016-12-19 01:38:02 +01:00
private int response;
2016-12-05 04:21:04 +01:00
private String message;
private String name;
2016-12-05 04:21:04 +01:00
2019-01-27 03:04:53 +01:00
private static class ServerLinkException extends IllegalStateException {
public ServerLinkException(String message) {
super(message);
}
}
2017-01-07 20:06:54 +01:00
/**
* New PacketLinkServer (In)
*
* @param plugin SubPlugin
*/
public PacketLinkServer(SubProxy plugin) {
Util.nullpo(plugin);
2016-12-05 04:21:04 +01:00
this.plugin = plugin;
}
2017-01-07 20:06:54 +01:00
/**
* New PacketLinkServer (Out)
*
* @param name The name that was determined
2017-01-07 20:06:54 +01:00
* @param response Response ID
* @param message Message
*/
public PacketLinkServer(String name, int response, String message) {
Util.nullpo(response);
this.name = name;
2016-12-05 04:21:04 +01:00
this.response = response;
this.message = message;
}
@Override
2019-04-18 16:02:09 +02:00
public ObjectMap<Integer> send(SubDataClient client) {
ObjectMap<Integer> data = new ObjectMap<Integer>();
data.set(0x0000, name);
data.set(0x0001, response);
if (message != null) data.set(0x0002, message);
return data;
2016-12-05 04:21:04 +01:00
}
@Override
2019-04-18 16:02:09 +02:00
public void receive(SubDataClient client, ObjectMap<Integer> data) {
String name = (data.contains(0x0000))?data.getString(0x0000):null;
2019-05-10 04:43:34 +02:00
Integer channel = data.getInt(0x0002);
InetSocketAddress address;
2019-04-18 16:02:09 +02:00
2016-12-05 04:21:04 +01:00
try {
if (!data.contains(0x0001)) {
address = null;
} else if (data.isNumber(0x0001)) {
address = new InetSocketAddress(client.getAddress().getAddress(), data.getInt(0x0001));
} else {
String[] sa = data.getString(0x0001).split(":");
address = new InetSocketAddress(sa[0], Integer.parseInt(sa[1]));
}
Server server;
Map<String, Server> servers = plugin.api.getServers();
if (name != null && servers.containsKey(name.toLowerCase())) {
link(client, servers.get(name.toLowerCase()), channel);
} else if (address != null) {
if ((server = search(address)) != null || (server = create(name, address)) != null) {
link(client, server, channel);
} else {
throw new ServerLinkException("There is no server with address: " + address.getAddress().getHostAddress() + ':' + address.getPort());
}
2019-01-27 03:04:53 +01:00
} else {
throw new ServerLinkException("Not enough arguments");
2019-01-27 03:04:53 +01:00
}
} catch (ServerLinkException e) {
2019-04-18 16:02:09 +02:00
if (name != null) {
client.sendPacket(new PacketLinkServer(null, 3, "There is no server with name: " + name));
2016-12-05 04:21:04 +01:00
} else {
2019-01-27 03:04:53 +01:00
client.sendPacket(new PacketLinkServer(null, 2, e.getMessage()));
2016-12-05 04:21:04 +01:00
}
2019-05-11 23:23:31 +02:00
} catch (Throwable e) {
2019-04-18 16:02:09 +02:00
client.sendPacket(new PacketLinkServer(null, 1, null));
e.printStackTrace();
2016-12-05 04:21:04 +01:00
}
}
private Server create(String name, InetSocketAddress address) throws Throwable {
if (strict) {
return null;
} else {
String id = (name == null)? Util.getNew(SubAPI.getInstance().getServers().keySet(), () -> UUID.randomUUID().toString()) : name;
Server server = SubAPI.getInstance().addServer(id, address.getAddress(), address.getPort(), "Some Dynamic Server", name == null, false);
if (server != null) Util.reflect(ServerImpl.class.getDeclaredField("persistent"), server, false);
return server;
}
}
private Server search(InetSocketAddress address) {
Server server = null;
for (Server s : plugin.api.getServers().values()) {
if (s.getAddress().equals(address)) {
if (server != null) throw new ServerLinkException("Multiple servers match address: " + address.getAddress().getHostAddress() + ':' + address.getPort());
server = s;
}
}
return server;
}
static long req = 1;
static long last = Calendar.getInstance().getTime().getTime();
private void link(SubDataClient client, Server server, int channel) throws Throwable {
HashMap<Integer, SubDataClient> subdata = Try.all.get(() -> Util.reflect(ServerImpl.class.getDeclaredField("subdata"), server));
if (!subdata.containsKey(channel) || (channel == 0 && subdata.get(0) == null)) {
2019-05-10 04:43:34 +02:00
server.setSubData(client, channel);
Logger.get("SubData").info(client.getAddress().toString() + " has been defined as " + ((server instanceof SubServer) ? "SubServer" : "Server") + ": " + server.getName() + ((channel > 0)?" [+"+channel+"]":""));
Runnable register = () -> {
if (server instanceof SubServer && !((SubServer) server).isRunning()) {
if (((SubServer) server).isAvailable()) {
Logger.get("SubServers").info("Sending shutdown signal to rogue SubServer: " + server.getName());
client.sendPacket(new PacketOutExReset("Rogue SubServer Detected"));
} else {
// Drop connection if host is unavailable for rogue checking (try again later)
Try.all.run(() -> Util.reflect(SubDataClient.class.getDeclaredMethod("close", DisconnectReason.class), client, DisconnectReason.CLOSE_REQUESTED));
}
} else {
if (server instanceof SubServer && !Try.all.get(() -> Util.reflect(SubServerImpl.class.getDeclaredField("started"), server), true)) {
Try.all.run(() -> Util.reflect(SubServerImpl.class.getDeclaredField("started"), server, true));
SubStartedEvent event = new SubStartedEvent((SubServer) server);
ProxyServer.getInstance().getPluginManager().callEvent(event);
}
client.sendPacket(new PacketLinkServer(server.getName(), 0, null));
}
--req;
};
final long now = Calendar.getInstance().getTime().getTime();
2020-11-23 06:25:00 +01:00
Timer timer = new Timer("SubServers.Bungee::Server_Linker(" + server.getName() + ")");
timer.schedule(new TimerTask() {
@Override
public void run() {
register.run();
2020-11-23 06:25:00 +01:00
timer.cancel();
}
}, ((server instanceof SubServer && !((SubServer) server).isRunning()) ? TimeUnit.SECONDS.toMillis(5) : 0) + ((now - last < 500) ? (req * 500) : 0));
++req;
last = now;
2021-01-21 20:28:23 +01:00
setReady(client);
} else {
2022-04-10 03:03:29 +02:00
client.sendPacket(new PacketLinkServer(null, 4, "Server already linked: " + server.getName()));
}
}
2016-12-05 04:21:04 +01:00
}