2016-12-24 05:55:17 +01:00
|
|
|
package net.ME1312.SubServers.Bungee.Network.Packet;
|
2016-12-19 01:38:02 +01:00
|
|
|
|
2016-12-24 05:55:17 +01:00
|
|
|
import net.ME1312.SubServers.Bungee.Host.Server;
|
|
|
|
import net.ME1312.SubServers.Bungee.Host.SubServer;
|
2018-04-15 03:53:51 +02:00
|
|
|
import net.ME1312.SubServers.Bungee.Library.Config.YAMLSection;
|
2017-01-30 21:22:36 +01:00
|
|
|
import net.ME1312.SubServers.Bungee.Library.Util;
|
2016-12-24 05:55:17 +01:00
|
|
|
import net.ME1312.SubServers.Bungee.Library.Version.Version;
|
|
|
|
import net.ME1312.SubServers.Bungee.Network.Client;
|
|
|
|
import net.ME1312.SubServers.Bungee.Network.PacketIn;
|
|
|
|
import net.ME1312.SubServers.Bungee.Network.PacketOut;
|
|
|
|
import net.ME1312.SubServers.Bungee.SubPlugin;
|
2016-12-19 01:38:02 +01:00
|
|
|
|
|
|
|
import java.util.Map;
|
|
|
|
import java.util.UUID;
|
|
|
|
|
2017-01-07 20:06:54 +01:00
|
|
|
/**
|
|
|
|
* Stop Server Packet
|
|
|
|
*/
|
2016-12-19 01:38:02 +01:00
|
|
|
public class PacketStopServer implements PacketIn, PacketOut {
|
|
|
|
private SubPlugin plugin;
|
|
|
|
private int response;
|
|
|
|
private String message;
|
|
|
|
private String id;
|
|
|
|
|
2017-01-07 20:06:54 +01:00
|
|
|
/**
|
|
|
|
* New PacketStopServer (In)
|
|
|
|
*
|
|
|
|
* @param plugin SubPlugin
|
|
|
|
*/
|
2016-12-19 01:38:02 +01:00
|
|
|
public PacketStopServer(SubPlugin plugin) {
|
2017-01-30 21:22:36 +01:00
|
|
|
if (Util.isNull(plugin)) throw new NullPointerException();
|
2016-12-19 01:38:02 +01:00
|
|
|
this.plugin = plugin;
|
|
|
|
}
|
|
|
|
|
2017-01-07 20:06:54 +01:00
|
|
|
/**
|
|
|
|
* New PacketStopServer (Out)
|
|
|
|
*
|
|
|
|
* @param response Response ID
|
|
|
|
* @param message Message
|
|
|
|
* @param id Receiver ID
|
|
|
|
*/
|
2016-12-19 01:38:02 +01:00
|
|
|
public PacketStopServer(int response, String message, String id) {
|
2017-01-30 21:22:36 +01:00
|
|
|
if (Util.isNull(response, message)) throw new NullPointerException();
|
2016-12-19 01:38:02 +01:00
|
|
|
this.response = response;
|
|
|
|
this.message = message;
|
|
|
|
this.id = id;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2018-04-15 03:53:51 +02:00
|
|
|
public YAMLSection generate() {
|
|
|
|
YAMLSection json = new YAMLSection();
|
2018-08-24 04:32:49 +02:00
|
|
|
if (id != null) json.set("id", id);
|
2018-04-15 03:53:51 +02:00
|
|
|
json.set("r", response);
|
|
|
|
json.set("m", message);
|
2016-12-19 01:38:02 +01:00
|
|
|
return json;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2018-04-15 03:53:51 +02:00
|
|
|
public void execute(Client client, YAMLSection data) {
|
2016-12-19 01:38:02 +01:00
|
|
|
try {
|
|
|
|
Map<String, Server> servers = plugin.api.getServers();
|
2019-01-07 22:09:20 +01:00
|
|
|
if (!data.getRawString("server").equals("*") && !servers.keySet().contains(data.getRawString("server").toLowerCase())) {
|
2018-04-15 03:53:51 +02:00
|
|
|
client.sendPacket(new PacketStopServer(3, "There is no server with that name", (data.contains("id"))?data.getRawString("id"):null));
|
2019-01-07 22:09:20 +01:00
|
|
|
} else if (!data.getRawString("server").equals("*") && !(servers.get(data.getRawString("server").toLowerCase()) instanceof SubServer)) {
|
2018-04-15 03:53:51 +02:00
|
|
|
client.sendPacket(new PacketStopServer(4, "That Server is not a SubServer", (data.contains("id"))?data.getRawString("id"):null));
|
2019-01-07 22:09:20 +01:00
|
|
|
} else if (!data.getRawString("server").equals("*") && !((SubServer) servers.get(data.getRawString("server").toLowerCase())).isRunning()) {
|
2018-04-15 03:53:51 +02:00
|
|
|
client.sendPacket(new PacketStopServer(5, "That SubServer is not running", (data.contains("id"))?data.getRawString("id"):null));
|
2019-01-07 22:09:20 +01:00
|
|
|
} else if (data.getRawString("server").equals("*")) {
|
|
|
|
boolean sent = false;
|
|
|
|
if (data.contains("force") && data.getBoolean("force")) {
|
|
|
|
for (Server server : servers.values()) {
|
|
|
|
if (server instanceof SubServer && ((SubServer) server).isRunning()) {
|
2019-01-17 16:39:15 +01:00
|
|
|
if (((SubServer) server).terminate((data.contains("player"))?data.getUUID("player"):null)) {
|
2019-01-07 22:09:20 +01:00
|
|
|
sent = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (sent) {
|
|
|
|
client.sendPacket(new PacketStopServer(0, "Terminating SubServers", (data.contains("id"))?data.getRawString("id"):null));
|
|
|
|
} else {
|
|
|
|
client.sendPacket(new PacketStopServer(1, "Couldn't terminate SubServers", (data.contains("id"))?data.getRawString("id"):null));
|
|
|
|
}
|
2016-12-19 01:38:02 +01:00
|
|
|
} else {
|
2019-01-07 22:09:20 +01:00
|
|
|
for (Server server : servers.values()) {
|
|
|
|
if (server instanceof SubServer && ((SubServer) server).isRunning()) {
|
2019-01-17 16:39:15 +01:00
|
|
|
if (((SubServer) server).stop((data.contains("player"))?data.getUUID("player"):null)) {
|
2019-01-07 22:09:20 +01:00
|
|
|
sent = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (sent) {
|
|
|
|
client.sendPacket(new PacketStopServer(0, "Stopping SubServers", (data.contains("id"))?data.getRawString("id"):null));
|
|
|
|
} else {
|
|
|
|
client.sendPacket(new PacketStopServer(1, "Couldn't stop SubServers", (data.contains("id"))?data.getRawString("id"):null));
|
|
|
|
}
|
2016-12-19 01:38:02 +01:00
|
|
|
}
|
|
|
|
} else {
|
2019-01-07 22:09:20 +01:00
|
|
|
if (data.contains("force") && data.getBoolean("force")) {
|
2019-01-17 16:39:15 +01:00
|
|
|
if (((SubServer) servers.get(data.getRawString("server").toLowerCase())).terminate((data.contains("player"))?data.getUUID("player"):null)) {
|
2019-01-07 22:09:20 +01:00
|
|
|
client.sendPacket(new PacketStopServer(0, "Terminating SubServer", (data.contains("id"))?data.getRawString("id"):null));
|
|
|
|
} else {
|
|
|
|
client.sendPacket(new PacketStopServer(1, "Couldn't terminate SubServer", (data.contains("id"))?data.getRawString("id"):null));
|
|
|
|
}
|
2016-12-19 01:38:02 +01:00
|
|
|
} else {
|
2019-01-17 16:39:15 +01:00
|
|
|
if (((SubServer) servers.get(data.getRawString("server").toLowerCase())).stop((data.contains("player"))?data.getUUID("player"):null)) {
|
2019-01-07 22:09:20 +01:00
|
|
|
client.sendPacket(new PacketStopServer(0, "Stopping SubServer", (data.contains("id"))?data.getRawString("id"):null));
|
|
|
|
} else {
|
|
|
|
client.sendPacket(new PacketStopServer(1, "Couldn't stop SubServer", (data.contains("id"))?data.getRawString("id"):null));
|
|
|
|
}
|
2016-12-19 01:38:02 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (Throwable e) {
|
2018-04-15 03:53:51 +02:00
|
|
|
client.sendPacket(new PacketStopServer(2, e.getClass().getCanonicalName() + ": " + e.getMessage(), (data.contains("id"))?data.getRawString("id"):null));
|
2017-07-23 06:32:57 +02:00
|
|
|
e.printStackTrace();
|
2016-12-19 01:38:02 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Version getVersion() {
|
|
|
|
return new Version("2.11.0a");
|
|
|
|
}
|
|
|
|
}
|