SubServers-2/SubServers.Host/src/net/ME1312/SubServers/Host/Network/Packet/PacketExAddServer.java

87 lines
3.2 KiB
Java
Raw Normal View History

package net.ME1312.SubServers.Host.Network.Packet;
2018-10-08 01:25:08 +02:00
import com.dosse.upnp.UPnP;
2019-05-13 05:28:27 +02:00
import net.ME1312.Galaxi.Library.Map.ObjectMap;
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;
import net.ME1312.SubServers.Host.Executable.SubServer;
2017-04-16 19:02:14 +02:00
import net.ME1312.SubServers.Host.ExHost;
import java.util.UUID;
2019-05-13 05:28:27 +02:00
import java.util.logging.Logger;
/**
* 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;
private int response;
2019-05-13 05:28:27 +02:00
private UUID tracker;
/**
* New PacketExAddServer (In)
*
2019-05-13 05:28:27 +02:00
* @param host ExHost
*/
2017-04-16 19:02:14 +02:00
public PacketExAddServer(ExHost host) {
if (Util.isNull(host)) throw new NullPointerException();
this.host = host;
}
/**
* New PacketExAddServer (Out)
*
* @param response Response ID
2019-05-13 05:28:27 +02:00
* @param tracker Receiver ID
*/
2019-05-13 05:28:27 +02:00
public PacketExAddServer(int response, UUID tracker) {
if (Util.isNull(response)) throw new NullPointerException();
this.response = response;
2019-05-13 05:28:27 +02:00
this.tracker = tracker;
}
@Override
2019-05-13 05:28:27 +02:00
public ObjectMap<Integer> send(SubDataClient client) {
ObjectMap<Integer> data = new ObjectMap<Integer>();
if (tracker != null) data.set(0x0000, tracker);
data.set(0x0001, response);
return data;
}
@Override
2019-05-13 05:28:27 +02:00
public void receive(SubDataClient client, ObjectMap<Integer> data) {
Logger logger = Util.getDespiteException(() -> Util.reflect(SubDataClient.class.getDeclaredField("log"), client), null);
UUID tracker = (data.contains(0x0000)?data.getUUID(0x0000):null);
try {
2019-05-13 05:28:27 +02:00
String name = data.getRawString(0x0001);
boolean enabled = data.getBoolean(0x0002);
int port = data.getInt(0x0003);
boolean log = data.getBoolean(0x0004);
String dir = data.getRawString(0x0005);
String exec = data.getRawString(0x0006);
String stopcmd = data.getRawString(0x0007);
UUID running = data.contains(0x0008)?data.getUUID(0x0008):null;
if (host.servers.keySet().contains(name.toLowerCase())) {
client.sendPacket(new PacketExAddServer(1, tracker));
} else {
2019-05-13 05:28:27 +02:00
SubServer server = new SubServer(host, name, enabled, port, log, dir, exec, stopcmd);
host.servers.put(name.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: " + name);
if (running != null) server.start(running);
client.sendPacket(new PacketExAddServer(0, tracker));
}
} catch (Throwable e) {
2019-05-13 05:28:27 +02:00
client.sendPacket(new PacketExAddServer(2, tracker));
host.log.error.println(e);
}
}
@Override
2019-05-13 05:28:27 +02:00
public int version() {
return 0x0001;
}
}