2017-04-01 07:37:48 +02:00
|
|
|
package net.ME1312.SubServers.Host.Network.Packet;
|
|
|
|
|
2019-05-13 05:28:27 +02:00
|
|
|
import net.ME1312.Galaxi.Library.Map.ObjectMap;
|
2021-10-24 06:14:07 +02:00
|
|
|
import net.ME1312.Galaxi.Library.Try;
|
2018-09-09 00:06:21 +02:00
|
|
|
import net.ME1312.Galaxi.Library.Util;
|
2019-05-13 05:28:27 +02:00
|
|
|
import net.ME1312.SubData.Client.Protocol.PacketObjectIn;
|
|
|
|
import net.ME1312.SubData.Client.Protocol.PacketObjectOut;
|
|
|
|
import net.ME1312.SubData.Client.SubDataClient;
|
2019-10-19 00:24:58 +02:00
|
|
|
import net.ME1312.SubData.Client.SubDataSender;
|
2017-04-16 19:02:14 +02:00
|
|
|
import net.ME1312.SubServers.Host.ExHost;
|
2020-11-16 21:34:59 +01:00
|
|
|
import net.ME1312.SubServers.Host.Executable.SubServerImpl;
|
|
|
|
|
|
|
|
import com.dosse.upnp.UPnP;
|
2017-04-01 07:37:48 +02:00
|
|
|
|
|
|
|
import java.util.UUID;
|
2019-05-13 05:28:27 +02:00
|
|
|
import java.util.logging.Logger;
|
2017-04-01 07:37:48 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Create Server Packet
|
|
|
|
*/
|
2019-05-13 05:28:27 +02:00
|
|
|
public class PacketExAddServer implements PacketObjectIn<Integer>, PacketObjectOut<Integer> {
|
2017-04-16 19:02:14 +02:00
|
|
|
private ExHost host;
|
2017-04-01 07:37:48 +02:00
|
|
|
private int response;
|
2019-08-30 02:01:52 +02:00
|
|
|
private UUID running;
|
2019-05-13 05:28:27 +02:00
|
|
|
private UUID tracker;
|
2017-04-01 07:37:48 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* New PacketExAddServer (In)
|
|
|
|
*
|
2019-05-13 05:28:27 +02:00
|
|
|
* @param host ExHost
|
2017-04-01 07:37:48 +02:00
|
|
|
*/
|
2017-04-16 19:02:14 +02:00
|
|
|
public PacketExAddServer(ExHost host) {
|
2021-10-24 06:14:07 +02:00
|
|
|
Util.nullpo(host);
|
2017-04-01 07:37:48 +02:00
|
|
|
this.host = host;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* New PacketExAddServer (Out)
|
|
|
|
*
|
|
|
|
* @param response Response ID
|
2019-05-13 05:28:27 +02:00
|
|
|
* @param tracker Receiver ID
|
2017-04-01 07:37:48 +02:00
|
|
|
*/
|
2019-05-13 05:28:27 +02:00
|
|
|
public PacketExAddServer(int response, UUID tracker) {
|
2019-08-30 02:01:52 +02:00
|
|
|
this(response, null, tracker);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* New PacketExAddServer (Out)
|
|
|
|
*
|
|
|
|
* @param response Response ID
|
|
|
|
* @param tracker Receiver ID
|
|
|
|
*/
|
|
|
|
public PacketExAddServer(int response, UUID running, UUID tracker) {
|
2021-10-24 06:14:07 +02:00
|
|
|
Util.nullpo(response);
|
2017-04-01 07:37:48 +02:00
|
|
|
this.response = response;
|
2019-05-13 05:28:27 +02:00
|
|
|
this.tracker = tracker;
|
2019-08-30 02:01:52 +02:00
|
|
|
this.running = running;
|
2017-04-01 07:37:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2019-10-19 00:24:58 +02:00
|
|
|
public ObjectMap<Integer> send(SubDataSender client) {
|
2019-05-13 05:28:27 +02:00
|
|
|
ObjectMap<Integer> data = new ObjectMap<Integer>();
|
|
|
|
if (tracker != null) data.set(0x0000, tracker);
|
|
|
|
data.set(0x0001, response);
|
2019-08-30 02:01:52 +02:00
|
|
|
if (running != null) data.set(0x0002, running);
|
2018-04-15 03:53:51 +02:00
|
|
|
return data;
|
2017-04-01 07:37:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2019-10-19 00:24:58 +02:00
|
|
|
public void receive(SubDataSender client, ObjectMap<Integer> data) {
|
2021-10-24 06:14:07 +02:00
|
|
|
Logger logger = Try.all.get(() -> Util.reflect(SubDataClient.class.getDeclaredField("log"), client.getConnection()), null);
|
2019-05-13 05:28:27 +02:00
|
|
|
UUID tracker = (data.contains(0x0000)?data.getUUID(0x0000):null);
|
2017-04-01 07:37:48 +02:00
|
|
|
try {
|
2021-10-24 20:53:15 +02:00
|
|
|
String name = data.getString(0x0001);
|
2019-05-13 05:28:27 +02:00
|
|
|
boolean enabled = data.getBoolean(0x0002);
|
|
|
|
int port = data.getInt(0x0003);
|
|
|
|
boolean log = data.getBoolean(0x0004);
|
2021-10-24 20:53:15 +02:00
|
|
|
String dir = data.getString(0x0005);
|
|
|
|
String exec = data.getString(0x0006);
|
|
|
|
String stopcmd = data.getString(0x0007);
|
2019-05-13 05:28:27 +02:00
|
|
|
UUID running = data.contains(0x0008)?data.getUUID(0x0008):null;
|
|
|
|
|
|
|
|
if (host.servers.keySet().contains(name.toLowerCase())) {
|
2019-08-30 02:01:52 +02:00
|
|
|
SubServerImpl server = host.servers.get(name.toLowerCase());
|
2020-06-13 23:53:18 +02:00
|
|
|
if (server.getPort() == port && server.getExecutable().equals(exec) && server.getPath().equals(dir)) {
|
2019-08-30 02:01:52 +02:00
|
|
|
if (server.isEnabled() != enabled || server.getLogger().isLogging() != log || !server.getStopCommand().equals(stopcmd)) {
|
|
|
|
server.setEnabled(enabled);
|
|
|
|
server.setLogging(log);
|
|
|
|
server.setStopCommand(stopcmd);
|
|
|
|
logger.info("Re-Added SubServer: " + server.getName());
|
|
|
|
}
|
|
|
|
client.sendPacket(new PacketExAddServer(0, (server.isRunning())?server.getLogger().getAddress():null, tracker));
|
|
|
|
} else {
|
|
|
|
server.stop();
|
|
|
|
server.waitFor();
|
|
|
|
if (UPnP.isUPnPAvailable() && UPnP.isMappedTCP(server.getPort()))
|
|
|
|
UPnP.closePortTCP(server.getPort());
|
|
|
|
|
2019-10-19 00:24:58 +02:00
|
|
|
init(client.getConnection(), server = new SubServerImpl(host, name, enabled, port, log, dir, exec, stopcmd), running, tracker, logger);
|
2019-08-30 02:01:52 +02:00
|
|
|
}
|
2017-04-01 07:37:48 +02:00
|
|
|
} else {
|
2019-10-19 00:24:58 +02:00
|
|
|
init(client.getConnection(), new SubServerImpl(host, name, enabled, port, log, dir, exec, stopcmd), running, tracker, logger);
|
2017-04-01 07:37:48 +02:00
|
|
|
}
|
|
|
|
} catch (Throwable e) {
|
2019-05-13 05:28:27 +02:00
|
|
|
client.sendPacket(new PacketExAddServer(2, tracker));
|
2017-07-23 06:32:57 +02:00
|
|
|
host.log.error.println(e);
|
2017-04-01 07:37:48 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-08-30 02:01:52 +02:00
|
|
|
private void init(SubDataClient client, SubServerImpl server, UUID running, UUID tracker, Logger logger) {
|
|
|
|
host.servers.put(server.getName().toLowerCase(), server);
|
|
|
|
if (UPnP.isUPnPAvailable() && host.config.get().getMap("Settings").getMap("UPnP", new ObjectMap<String>()).getBoolean("Forward-Servers", false)) UPnP.openPortTCP(server.getPort());
|
|
|
|
logger.info("Added SubServer: " + server.getName());
|
|
|
|
if (running != null) server.start(running);
|
|
|
|
client.sendPacket(new PacketExAddServer(0, tracker));
|
|
|
|
}
|
2017-04-01 07:37:48 +02:00
|
|
|
}
|