2017-01-30 21:22:36 +01:00
|
|
|
package net.ME1312.SubServers.Host.Network.Packet;
|
|
|
|
|
2017-01-31 04:04:37 +01:00
|
|
|
import net.ME1312.SubServers.Host.Library.Log.Logger;
|
2017-01-30 21:22:36 +01:00
|
|
|
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;
|
2017-01-31 04:04:37 +01:00
|
|
|
import net.ME1312.SubServers.Host.Network.SubDataClient;
|
2017-01-30 21:22:36 +01:00
|
|
|
import net.ME1312.SubServers.Host.SubServers;
|
|
|
|
import org.json.JSONObject;
|
|
|
|
|
|
|
|
import java.io.IOException;
|
2017-01-31 04:04:37 +01:00
|
|
|
import java.lang.reflect.Field;
|
2017-01-30 21:22:36 +01:00
|
|
|
|
|
|
|
public final class PacketAuthorization implements PacketIn, PacketOut {
|
|
|
|
private SubServers plugin;
|
2017-01-31 04:04:37 +01:00
|
|
|
private Logger log = null;
|
2017-01-30 21:22:36 +01:00
|
|
|
|
|
|
|
public PacketAuthorization(SubServers plugin) {
|
|
|
|
if (Util.isNull(plugin)) throw new NullPointerException();
|
|
|
|
this.plugin = plugin;
|
2017-01-31 04:04:37 +01:00
|
|
|
try {
|
|
|
|
Field f = SubDataClient.class.getDeclaredField("log");
|
|
|
|
f.setAccessible(true);
|
|
|
|
this.log = (Logger) f.get(null);
|
|
|
|
f.setAccessible(false);
|
|
|
|
} catch (IllegalAccessException | NoSuchFieldException e) {}
|
2017-01-30 21:22:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public JSONObject generate() {
|
|
|
|
JSONObject json = new JSONObject();
|
|
|
|
json.put("password", plugin.config.get().getSection("Settings").getSection("SubData").getString("Password"));
|
|
|
|
return json;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void execute(JSONObject data) {
|
|
|
|
try {
|
|
|
|
if (data.getInt("r") == 0) {
|
|
|
|
//plugin.subdata.sendPacket(new PacketLinkServer(plugin));
|
|
|
|
plugin.subdata.sendPacket(new PacketDownloadLang());
|
|
|
|
} else {
|
2017-01-31 04:04:37 +01:00
|
|
|
log.info("SubServers > Could not authorize SubData connection: " + data.getString("m"));
|
2017-01-30 21:22:36 +01:00
|
|
|
plugin.subdata.destroy(false);
|
|
|
|
}
|
|
|
|
} catch (IOException e) {
|
2017-01-31 04:04:37 +01:00
|
|
|
log.error(e);
|
2017-01-30 21:22:36 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Version getVersion() {
|
|
|
|
return new Version("2.11.0a");
|
|
|
|
}
|
|
|
|
}
|