summaryrefslogtreecommitdiffstats
path: root/src/main/java/net/minecraft/server/NetLoginHandler.java
diff options
context:
space:
mode:
authorfeildmaster <admin@feildmaster.com>2012-12-19 22:03:52 -0600
committerfeildmaster <admin@feildmaster.com>2012-12-20 10:43:00 -0600
commit23b67643741d5754af4de020a29d557078f9f81d (patch)
tree90e1a32f7eb94af49a381cb6bc34bf6247f0efe6 /src/main/java/net/minecraft/server/NetLoginHandler.java
parent9f1bf124eec7c20f16b2034fd9fba55f70c805fd (diff)
downloadcraftbukkit-23b67643741d5754af4de020a29d557078f9f81d.tar
craftbukkit-23b67643741d5754af4de020a29d557078f9f81d.tar.gz
craftbukkit-23b67643741d5754af4de020a29d557078f9f81d.tar.lz
craftbukkit-23b67643741d5754af4de020a29d557078f9f81d.tar.xz
craftbukkit-23b67643741d5754af4de020a29d557078f9f81d.zip
Update CraftBukkit to Minecraft 1.4.6
Diffstat (limited to 'src/main/java/net/minecraft/server/NetLoginHandler.java')
-rw-r--r--src/main/java/net/minecraft/server/NetLoginHandler.java220
1 files changed, 0 insertions, 220 deletions
diff --git a/src/main/java/net/minecraft/server/NetLoginHandler.java b/src/main/java/net/minecraft/server/NetLoginHandler.java
deleted file mode 100644
index 977c89c3..00000000
--- a/src/main/java/net/minecraft/server/NetLoginHandler.java
+++ /dev/null
@@ -1,220 +0,0 @@
-package net.minecraft.server;
-
-import java.io.Serializable;
-import java.net.InetAddress;
-import java.net.Socket;
-import java.security.PrivateKey;
-import java.security.PublicKey;
-import java.util.Arrays;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Random;
-import java.util.logging.Logger;
-import javax.crypto.SecretKey;
-
-public class NetLoginHandler extends NetHandler {
-
- private byte[] d;
- public static Logger logger = Logger.getLogger("Minecraft");
- private static Random random = new Random();
- public NetworkManager networkManager;
- public boolean c = false;
- private MinecraftServer server;
- private int g = 0;
- private String h = null;
- private volatile boolean i = false;
- private String loginKey = Long.toString(random.nextLong(), 16); // CraftBukkit - Security fix
- private SecretKey k = null;
- public String hostname = ""; // CraftBukkit - add field
- private boolean login = false; // CraftBukkit
-
- public NetLoginHandler(MinecraftServer minecraftserver, Socket socket, String s) throws java.io.IOException { // CraftBukkit - throws IOException
- this.server = minecraftserver;
- this.networkManager = new NetworkManager(socket, s, this, minecraftserver.F().getPrivate());
- this.networkManager.e = 0;
- }
-
- // CraftBukkit start
- public Socket getSocket() {
- return this.networkManager.getSocket();
- }
- // CraftBukkit end
-
- public void c() {
- if (this.i) {
- this.d();
- }
-
- if (this.g++ == 600) {
- this.disconnect("Took too long to log in");
- } else {
- this.networkManager.b();
- }
- }
-
- public void disconnect(String s) {
- try {
- logger.info("Disconnecting " + this.getName() + ": " + s);
- this.networkManager.queue(new Packet255KickDisconnect(s));
- this.networkManager.d();
- this.c = true;
- } catch (Exception exception) {
- exception.printStackTrace();
- }
- }
-
- public void a(Packet2Handshake packet2handshake) {
- // CraftBukkit start
- this.hostname = packet2handshake.c == null ? "" : packet2handshake.c + ':' + packet2handshake.d;
- // CraftBukkit end
- this.h = packet2handshake.f();
- if (!this.h.equals(StripColor.a(this.h))) {
- this.disconnect("Invalid username!");
- } else {
- PublicKey publickey = this.server.F().getPublic();
-
- if (packet2handshake.d() != 49) {
- if (packet2handshake.d() > 49) {
- this.disconnect("Outdated server!");
- } else {
- this.disconnect("Outdated client!");
- }
- } else {
- this.loginKey = this.server.getOnlineMode() ? Long.toString(random.nextLong(), 16) : "-";
- this.d = new byte[4];
- random.nextBytes(this.d);
- this.networkManager.queue(new Packet253KeyRequest(this.loginKey, publickey, this.d));
- }
- }
- }
-
- public void a(Packet252KeyResponse packet252keyresponse) {
- PrivateKey privatekey = this.server.F().getPrivate();
-
- this.k = packet252keyresponse.a(privatekey);
- if (!Arrays.equals(this.d, packet252keyresponse.b(privatekey))) {
- this.disconnect("Invalid client reply");
- }
-
- this.networkManager.queue(new Packet252KeyResponse());
- }
-
- public void a(Packet205ClientCommand packet205clientcommand) {
- if (packet205clientcommand.a == 0) {
- if (this.server.getOnlineMode()) {
- // CraftBukkit start
- if (this.login) {
- this.disconnect("Duplicate login");
- return;
- }
- this.login = true;
- // CraftBukkit end
- (new ThreadLoginVerifier(this, server.server)).start(); // CraftBukkit - add CraftServer
- } else {
- this.i = true;
- }
- }
- }
-
- public void a(Packet1Login packet1login) {}
-
- public void d() {
- // CraftBukkit start
- EntityPlayer s = this.server.getServerConfigurationManager().attemptLogin(this, this.h, this.hostname);
-
- if (s == null) {
- return;
- // CraftBukkit end
- } else {
- EntityPlayer entityplayer = this.server.getServerConfigurationManager().processLogin(s); // CraftBukkit - this.h -> s
-
- if (entityplayer != null) {
- this.server.getServerConfigurationManager().a((INetworkManager) this.networkManager, entityplayer);
- }
- }
-
- this.c = true;
- }
-
- public void a(String s, Object[] aobject) {
- logger.info(this.getName() + " lost connection");
- this.c = true;
- }
-
- public void a(Packet254GetInfo packet254getinfo) {
- if (this.networkManager.getSocket() == null) return; // CraftBukkit - fix NPE when a client queries a server that is unable to handle it.
- try {
- ServerConfigurationManagerAbstract serverconfigurationmanagerabstract = this.server.getServerConfigurationManager();
- String s = null;
- // CraftBukkit
- org.bukkit.event.server.ServerListPingEvent pingEvent = org.bukkit.craftbukkit.event.CraftEventFactory.callServerListPingEvent(this.server.server, getSocket().getInetAddress(), this.server.getMotd(), serverconfigurationmanagerabstract.getPlayerCount(), serverconfigurationmanagerabstract.getMaxPlayers());
-
- if (packet254getinfo.a == 1) {
- // CraftBukkit start - fix decompile issues, don't create a list from an array
- Object[] list = new Object[] { 1, 49, this.server.getVersion(), pingEvent.getMotd(), serverconfigurationmanagerabstract.getPlayerCount(), pingEvent.getMaxPlayers() };
-
- for (Object object : list) {
- if (s == null) {
- s = "\u00A7";
- } else {
- s = s + "\0";
- }
-
- s += org.apache.commons.lang.StringUtils.replace(object.toString(), "\0", "");
- }
- // CraftBukkit end
- } else {
- // CraftBukkit
- s = pingEvent.getMotd() + "\u00A7" + serverconfigurationmanagerabstract.getPlayerCount() + "\u00A7" + pingEvent.getMaxPlayers();
- }
-
- InetAddress inetaddress = null;
-
- if (this.networkManager.getSocket() != null) {
- inetaddress = this.networkManager.getSocket().getInetAddress();
- }
-
- this.networkManager.queue(new Packet255KickDisconnect(s));
- this.networkManager.d();
- if (inetaddress != null && this.server.ae() instanceof DedicatedServerConnection) {
- ((DedicatedServerConnection) this.server.ae()).a(inetaddress);
- }
-
- this.c = true;
- } catch (Exception exception) {
- exception.printStackTrace();
- }
- }
-
- public void onUnhandledPacket(Packet packet) {
- this.disconnect("Protocol error");
- }
-
- public String getName() {
- return this.h != null ? this.h + " [" + this.networkManager.getSocketAddress().toString() + "]" : this.networkManager.getSocketAddress().toString();
- }
-
- public boolean a() {
- return true;
- }
-
- static String a(NetLoginHandler netloginhandler) {
- return netloginhandler.loginKey;
- }
-
- static MinecraftServer b(NetLoginHandler netloginhandler) {
- return netloginhandler.server;
- }
-
- static SecretKey c(NetLoginHandler netloginhandler) {
- return netloginhandler.k;
- }
-
- static String d(NetLoginHandler netloginhandler) {
- return netloginhandler.h;
- }
-
- static boolean a(NetLoginHandler netloginhandler, boolean flag) {
- return netloginhandler.i = flag;
- }
-}