2017-04-01 07:37:48 +02:00
|
|
|
package net.ME1312.SubServers.Host.Network.Packet;
|
|
|
|
|
|
|
|
import net.ME1312.SubServers.Host.Executable.Executable;
|
|
|
|
import net.ME1312.SubServers.Host.Executable.SubServer;
|
2018-04-15 03:53:51 +02:00
|
|
|
import net.ME1312.SubServers.Host.Library.Config.YAMLSection;
|
2017-04-01 07:37:48 +02:00
|
|
|
import net.ME1312.SubServers.Host.Library.Log.Logger;
|
|
|
|
import net.ME1312.SubServers.Host.Library.Util;
|
|
|
|
import net.ME1312.SubServers.Host.Library.Version.Version;
|
|
|
|
import net.ME1312.SubServers.Host.Network.PacketIn;
|
|
|
|
import net.ME1312.SubServers.Host.Network.PacketOut;
|
|
|
|
import net.ME1312.SubServers.Host.Network.SubDataClient;
|
2017-04-16 19:02:14 +02:00
|
|
|
import net.ME1312.SubServers.Host.ExHost;
|
2017-04-01 07:37:48 +02:00
|
|
|
|
|
|
|
import java.lang.reflect.Field;
|
|
|
|
import java.util.UUID;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create Server Packet
|
|
|
|
*/
|
|
|
|
public class PacketExAddServer implements PacketIn, PacketOut {
|
2017-04-16 19:02:14 +02:00
|
|
|
private ExHost host;
|
2017-04-01 07:37:48 +02:00
|
|
|
private int response;
|
|
|
|
private String message;
|
|
|
|
private String id;
|
|
|
|
private Logger log = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* New PacketExAddServer (In)
|
|
|
|
*
|
|
|
|
* @param host SubPlugin
|
|
|
|
*/
|
2017-04-16 19:02:14 +02:00
|
|
|
public PacketExAddServer(ExHost host) {
|
2017-04-01 07:37:48 +02:00
|
|
|
if (Util.isNull(host)) throw new NullPointerException();
|
|
|
|
this.host = host;
|
|
|
|
try {
|
|
|
|
Field f = SubDataClient.class.getDeclaredField("log");
|
|
|
|
f.setAccessible(true);
|
|
|
|
this.log = (Logger) f.get(null);
|
|
|
|
f.setAccessible(false);
|
|
|
|
} catch (IllegalAccessException | NoSuchFieldException e) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* New PacketExAddServer (Out)
|
|
|
|
*
|
|
|
|
* @param response Response ID
|
|
|
|
* @param message Message
|
|
|
|
* @param id Receiver ID
|
|
|
|
*/
|
|
|
|
public PacketExAddServer(int response, String message, String id) {
|
|
|
|
if (Util.isNull(response, message)) throw new NullPointerException();
|
|
|
|
this.response = response;
|
|
|
|
this.message = message;
|
|
|
|
this.id = id;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2018-04-15 03:53:51 +02:00
|
|
|
public YAMLSection generate() {
|
|
|
|
YAMLSection data = new YAMLSection();
|
2018-08-24 04:32:49 +02:00
|
|
|
if (id != null) data.set("id", id);
|
2018-04-15 03:53:51 +02:00
|
|
|
data.set("r", response);
|
|
|
|
data.set("m", message);
|
|
|
|
return data;
|
2017-04-01 07:37:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2018-04-15 03:53:51 +02:00
|
|
|
public void execute(YAMLSection data) {
|
2017-04-01 07:37:48 +02:00
|
|
|
try {
|
2018-04-15 03:53:51 +02:00
|
|
|
if (host.servers.keySet().contains(data.getSection("server").getRawString("name").toLowerCase())) {
|
|
|
|
host.subdata.sendPacket(new PacketExAddServer(0, "Server Already Added", (data.contains("id"))?data.getRawString("id"):null));
|
2017-04-01 07:37:48 +02:00
|
|
|
} else {
|
2018-04-15 03:53:51 +02:00
|
|
|
SubServer server = new SubServer(host, data.getSection("server").getRawString("name"), data.getSection("server").getBoolean("enabled"), data.getSection("server").getBoolean("log"),
|
|
|
|
data.getSection("server").getRawString("dir"), new Executable(data.getSection("server").getRawString("exec")), data.getSection("server").getRawString("stopcmd"));
|
|
|
|
host.servers.put(data.getSection("server").getRawString("name").toLowerCase(), server);
|
|
|
|
log.info.println("Added SubServer: " + data.getSection("server").getRawString("name"));
|
|
|
|
if (data.getSection("server").contains("running")) server.start(UUID.fromString(data.getSection("server").getRawString("running")));
|
|
|
|
host.subdata.sendPacket(new PacketExAddServer(0, "Server Added Successfully", (data.contains("id"))?data.getRawString("id"):null));
|
2017-04-01 07:37:48 +02:00
|
|
|
}
|
|
|
|
} catch (Throwable e) {
|
2018-04-15 03:53:51 +02:00
|
|
|
host.subdata.sendPacket(new PacketExAddServer(1, e.getClass().getCanonicalName() + ": " + e.getMessage(), (data.contains("id"))?data.getRawString("id"):null));
|
2017-07-23 06:32:57 +02:00
|
|
|
host.log.error.println(e);
|
2017-04-01 07:37:48 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Version getVersion() {
|
|
|
|
return new Version("2.11.0a");
|
|
|
|
}
|
|
|
|
}
|