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

122 lines
5.1 KiB
Java
Raw Normal View History

2017-04-01 18:50:09 +02:00
package net.ME1312.SubServers.Host.Network.Packet;
2018-10-08 01:25:08 +02:00
import com.dosse.upnp.UPnP;
import net.ME1312.Galaxi.Engine.GalaxiEngine;
import net.ME1312.Galaxi.Library.Config.YAMLSection;
2019-05-13 05:28:27 +02:00
import net.ME1312.Galaxi.Library.Map.ObjectMap;
import net.ME1312.Galaxi.Library.UniversalFile;
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;
import net.ME1312.SubServers.Host.Executable.SubServerImpl;
2017-04-16 19:02:14 +02:00
import net.ME1312.SubServers.Host.ExHost;
import net.ME1312.SubServers.Host.SubAPI;
2017-04-01 18:50:09 +02:00
import java.io.File;
import java.io.FileWriter;
2019-05-13 05:28:27 +02:00
import java.util.Map;
import java.util.UUID;
import java.util.logging.Logger;
2017-04-01 18:50:09 +02:00
/**
* Create Server Packet
*/
2019-05-13 05:28:27 +02:00
public class PacketExDeleteServer implements PacketObjectIn<Integer>, PacketObjectOut<Integer> {
2017-04-16 19:02:14 +02:00
private ExHost host;
2017-04-01 18:50:09 +02:00
private int response;
2019-05-13 05:28:27 +02:00
private UUID tracker;
2017-04-01 18:50:09 +02:00
/**
* New PacketExDeleteServer (In)
*
2019-05-13 05:28:27 +02:00
* @param host ExHost
2017-04-01 18:50:09 +02:00
*/
2017-04-16 19:02:14 +02:00
public PacketExDeleteServer(ExHost host) {
2017-04-01 18:50:09 +02:00
if (Util.isNull(host)) throw new NullPointerException();
this.host = host;
}
/**
* New PacketExDeleteServer (Out)
*
* @param response Response ID
2019-05-13 05:28:27 +02:00
* @param tracker Receiver ID
2017-04-01 18:50:09 +02:00
*/
2019-05-13 05:28:27 +02:00
public PacketExDeleteServer(int response, UUID tracker) {
if (Util.isNull(response)) throw new NullPointerException();
2017-04-01 18:50:09 +02:00
this.response = response;
2019-05-13 05:28:27 +02:00
this.tracker = tracker;
2017-04-01 18:50:09 +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);
return data;
2017-04-01 18:50:09 +02:00
}
2019-05-13 05:28:27 +02:00
@SuppressWarnings("unchecked")
2017-04-01 18:50:09 +02:00
@Override
2019-10-19 00:24:58 +02:00
public void receive(SubDataSender client, ObjectMap<Integer> data) {
Logger log = Util.getDespiteException(() -> 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 18:50:09 +02:00
try {
2019-05-13 05:28:27 +02:00
String name = data.getRawString(0x0001);
YAMLSection info = new YAMLSection((Map<String, ?>) data.getObject(0x0002));
boolean recycle = data.getBoolean(0x0003, false);
if (!host.servers.keySet().contains(name.toLowerCase())) {
((SubDataClient) SubAPI.getInstance().getSubDataNetwork()[0]).sendPacket(new PacketExDeleteServer(1, tracker));
} else if (host.servers.get(name.toLowerCase()).isRunning()) {
((SubDataClient) SubAPI.getInstance().getSubDataNetwork()[0]).sendPacket(new PacketExDeleteServer(3, tracker));
2017-04-01 18:50:09 +02:00
} else {
SubServerImpl server = host.servers.get(name.toLowerCase());
2019-05-13 05:28:27 +02:00
host.servers.remove(name.toLowerCase());
2017-04-01 18:50:09 +02:00
new Thread(() -> {
UniversalFile to = new UniversalFile(GalaxiEngine.getInstance().getRuntimeDirectory(), "Recently Deleted:" + server.getName().toLowerCase());
2017-04-01 18:50:09 +02:00
try {
File from = new File(host.host.getRawString("Directory"), server.getPath());
2017-04-01 18:50:09 +02:00
if (from.exists()) {
2019-05-13 05:28:27 +02:00
log.info("Removing Files...");
if (recycle) {
if (to.exists()) {
if (to.isDirectory()) Util.deleteDirectory(to);
else to.delete();
}
to.mkdirs();
Util.copyDirectory(from, to);
2017-04-01 18:50:09 +02:00
}
Util.deleteDirectory(from);
2017-04-01 18:50:09 +02:00
}
} catch (Exception e) {
2019-05-13 05:28:27 +02:00
SubAPI.getInstance().getAppInfo().getLogger().error.println(e);
2017-04-01 18:50:09 +02:00
}
2019-05-13 05:28:27 +02:00
log.info("Saving...");
if (recycle) try {
2017-04-01 18:50:09 +02:00
if (!to.exists()) to.mkdirs();
FileWriter writer = new FileWriter(new File(to, "info.json"));
2019-05-13 05:28:27 +02:00
info.toJSON().write(writer);
2017-04-01 18:50:09 +02:00
writer.close();
} catch (Exception e) {
2019-05-13 05:28:27 +02:00
SubAPI.getInstance().getAppInfo().getLogger().error.println(e);
2017-04-01 18:50:09 +02:00
}
2018-10-08 01:25:08 +02:00
if (UPnP.isUPnPAvailable() && UPnP.isMappedTCP(server.getPort())) UPnP.closePortTCP(server.getPort());
2019-05-13 05:28:27 +02:00
log.info("Deleted SubServer: " + name);
((SubDataClient) SubAPI.getInstance().getSubDataNetwork()[0]).sendPacket(new PacketExDeleteServer(0, tracker));
}, SubAPI.getInstance().getAppInfo().getName() + "::Server_Deletion(" + server.getName() + ')').start();
2017-04-01 18:50:09 +02:00
}
} catch (Throwable e) {
2019-05-13 05:28:27 +02:00
((SubDataClient) SubAPI.getInstance().getSubDataNetwork()[0]).sendPacket(new PacketExDeleteServer(2, tracker));
host.log.error.println(e);
2017-04-01 18:50:09 +02:00
}
}
@Override
2019-05-13 05:28:27 +02:00
public int version() {
return 0x0001;
2017-04-01 18:50:09 +02:00
}
}