Archiviert
13
0

Attempt to correct a NPE due to a NULL socket.

Dieser Commit ist enthalten in:
Kristian S. Stangeland 2013-02-26 01:23:54 +01:00
Ursprung 2cf265f8e8
Commit 575248063d

Datei anzeigen

@ -17,8 +17,8 @@
package com.comphenix.protocol.injector.player; package com.comphenix.protocol.injector.player;
import java.lang.reflect.Method; import java.lang.reflect.Field;
import java.net.Socket; import java.net.SocketAddress;
import java.util.concurrent.ConcurrentMap; import java.util.concurrent.ConcurrentMap;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@ -27,6 +27,7 @@ import com.comphenix.protocol.error.ErrorReporter;
import com.comphenix.protocol.injector.GamePhase; import com.comphenix.protocol.injector.GamePhase;
import com.comphenix.protocol.injector.server.AbstractInputStreamLookup; import com.comphenix.protocol.injector.server.AbstractInputStreamLookup;
import com.comphenix.protocol.injector.server.SocketInjector; import com.comphenix.protocol.injector.server.SocketInjector;
import com.comphenix.protocol.reflect.FieldUtils;
import com.comphenix.protocol.reflect.FuzzyReflection; import com.comphenix.protocol.reflect.FuzzyReflection;
import com.comphenix.protocol.utility.MinecraftReflection; import com.comphenix.protocol.utility.MinecraftReflection;
import com.google.common.collect.Maps; import com.google.common.collect.Maps;
@ -39,7 +40,8 @@ import com.google.common.collect.Maps;
class NetLoginInjector { class NetLoginInjector {
private ConcurrentMap<Object, PlayerInjector> injectedLogins = Maps.newConcurrentMap(); private ConcurrentMap<Object, PlayerInjector> injectedLogins = Maps.newConcurrentMap();
private static Method getSocketMethod; private static Field networkManagerField;
private static Field socketAddressField;
// Handles every hook // Handles every hook
private ProxyPlayerInjectionHandler injectionHandler; private ProxyPlayerInjectionHandler injectionHandler;
@ -67,14 +69,11 @@ class NetLoginInjector {
if (!injectionHandler.isInjectionNecessary(GamePhase.LOGIN)) if (!injectionHandler.isInjectionNecessary(GamePhase.LOGIN))
return inserting; return inserting;
if (getSocketMethod == null) { Object networkManager = getNetworkManager(inserting);
getSocketMethod = FuzzyReflection.fromObject(inserting). SocketAddress address = getAddress(networkManager);
getMethodByParameters("getSocket", Socket.class, new Class<?>[0]);
}
// Get the underlying socket // Get the underlying socket
Socket socket = (Socket) getSocketMethod.invoke(inserting); SocketInjector socketInjector = inputStreamLookup.getSocketInjector(address);
SocketInjector socketInjector = inputStreamLookup.getSocketInjector(socket);
// This is the case if we're dealing with a connection initiated by the injected server socket // This is the case if we're dealing with a connection initiated by the injected server socket
if (socketInjector != null) { if (socketInjector != null) {
@ -96,6 +95,36 @@ class NetLoginInjector {
} }
} }
/**
* Retrieve the network manager from a given pending connection.
* @param inserting - the pending connection.
* @return The referenced network manager.
* @throws IllegalAccessException If we are unable to read the network manager.
*/
private Object getNetworkManager(Object inserting) throws IllegalAccessException {
if (networkManagerField == null) {
networkManagerField = FuzzyReflection.fromObject(inserting, true).
getFieldByType("networkManager", MinecraftReflection.getNetworkManagerClass());
}
return FieldUtils.readField(networkManagerField, inserting, true);
}
/**
* Retrieve the socket address stored in a network manager.
* @param networkManager - the network manager.
* @return The associated socket address.
* @throws IllegalAccessException If we are unable to read the address.
*/
private SocketAddress getAddress(Object networkManager) throws IllegalAccessException {
if (socketAddressField == null) {
socketAddressField = FuzzyReflection.fromObject(networkManager, true).
getFieldByType("socketAddress", SocketAddress.class);
}
return (SocketAddress) FieldUtils.readField(socketAddressField, networkManager, true);
}
/** /**
* Invoked when a NetLoginHandler should be reverted. * Invoked when a NetLoginHandler should be reverted.
* @param inserting - the original NetLoginHandler. * @param inserting - the original NetLoginHandler.