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

52 lines
1.6 KiB
Java
Raw Normal View History

package net.ME1312.SubServers.Host.Network.Packet;
2019-05-13 05:28:27 +02:00
import net.ME1312.Galaxi.Library.Map.ObjectMap;
import net.ME1312.Galaxi.Library.NamedContainer;
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.Protocol.PacketOut;
import net.ME1312.SubData.Client.SubDataClient;
2017-04-16 19:02:14 +02:00
import net.ME1312.SubServers.Host.ExHost;
import java.util.Calendar;
2019-05-13 05:28:27 +02:00
import java.util.logging.Logger;
2019-05-13 05:28:27 +02:00
/**
* Download Lang Packet
*/
public class PacketDownloadLang implements PacketObjectIn<Integer>, PacketOut {
2017-04-16 19:02:14 +02:00
private ExHost host;
2019-05-13 05:28:27 +02:00
/**
* New PacketDownloadLang (In)
*
* @param host ExHost
*/
2017-04-16 19:02:14 +02:00
public PacketDownloadLang(ExHost host) {
if (Util.isNull(host)) throw new NullPointerException();
this.host = host;
}
2019-05-13 05:28:27 +02:00
/**
* New PacketDownloadLang (Out)
*/
public PacketDownloadLang() {}
@Override
2019-05-13 05:28:27 +02:00
public void receive(SubDataClient client, ObjectMap<Integer> data) {
Logger log = Util.getDespiteException(() -> Util.reflect(SubDataClient.class.getDeclaredField("log"), client), null);
try {
2019-05-13 05:28:27 +02:00
Util.reflect(ExHost.class.getDeclaredField("lang"), host, new NamedContainer<>(Calendar.getInstance().getTime().getTime(), data.getObject(0x0001)));
log.info("Lang Settings Downloaded");
} catch (IllegalAccessException | NoSuchFieldException e) {
2019-05-13 05:28:27 +02:00
e.printStackTrace();
}
}
@Override
2019-05-13 05:28:27 +02:00
public int version() {
return 0x0001;
}
}