Get rid of reflection in relay protocol classes
This commit is contained in:
parent
b177675186
commit
6757d63fa1
|
@ -9,6 +9,7 @@ import java.io.InputStream;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Copyright (c) 2022-2024 lax1dude. All Rights Reserved.
|
* Copyright (c) 2022-2024 lax1dude. All Rights Reserved.
|
||||||
|
@ -28,47 +29,43 @@ import java.util.Map;
|
||||||
public class RelayPacket {
|
public class RelayPacket {
|
||||||
|
|
||||||
private static final Map<Integer,Class<? extends RelayPacket>> definedPacketClasses = new HashMap<>();
|
private static final Map<Integer,Class<? extends RelayPacket>> definedPacketClasses = new HashMap<>();
|
||||||
|
private static final Map<Integer,Supplier<? extends RelayPacket>> definedPacketCtors = new HashMap<>();
|
||||||
private static final Map<Class<? extends RelayPacket>,Integer> definedPacketIds = new HashMap<>();
|
private static final Map<Class<? extends RelayPacket>,Integer> definedPacketIds = new HashMap<>();
|
||||||
|
|
||||||
private static void register(int id, Class<? extends RelayPacket> clazz) {
|
private static void register(int id, Class<? extends RelayPacket> clazz, Supplier<? extends RelayPacket> ctor) {
|
||||||
definedPacketClasses.put(id, clazz);
|
definedPacketClasses.put(id, clazz);
|
||||||
|
definedPacketCtors.put(id, ctor);
|
||||||
definedPacketIds.put(clazz, id);
|
definedPacketIds.put(clazz, id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static {
|
static {
|
||||||
register(0x00, RelayPacket00Handshake.class);
|
register(0x00, RelayPacket00Handshake.class, RelayPacket00Handshake::new);
|
||||||
register(0x01, RelayPacket01ICEServers.class);
|
register(0x01, RelayPacket01ICEServers.class, RelayPacket01ICEServers::new);
|
||||||
register(0x02, RelayPacket02NewClient.class);
|
register(0x02, RelayPacket02NewClient.class, RelayPacket02NewClient::new);
|
||||||
register(0x03, RelayPacket03ICECandidate.class);
|
register(0x03, RelayPacket03ICECandidate.class, RelayPacket03ICECandidate::new);
|
||||||
register(0x04, RelayPacket04Description.class);
|
register(0x04, RelayPacket04Description.class, RelayPacket04Description::new);
|
||||||
register(0x05, RelayPacket05ClientSuccess.class);
|
register(0x05, RelayPacket05ClientSuccess.class, RelayPacket05ClientSuccess::new);
|
||||||
register(0x06, RelayPacket06ClientFailure.class);
|
register(0x06, RelayPacket06ClientFailure.class, RelayPacket06ClientFailure::new);
|
||||||
register(0x07, RelayPacket07LocalWorlds.class);
|
register(0x07, RelayPacket07LocalWorlds.class, RelayPacket07LocalWorlds::new);
|
||||||
register(0x69, RelayPacket69Pong.class);
|
register(0x69, RelayPacket69Pong.class, RelayPacket69Pong::new);
|
||||||
register(0x70, RelayPacket70SpecialUpdate.class);
|
register(0x70, RelayPacket70SpecialUpdate.class, RelayPacket70SpecialUpdate::new);
|
||||||
register(0xFE, RelayPacketFEDisconnectClient.class);
|
register(0xFE, RelayPacketFEDisconnectClient.class, RelayPacketFEDisconnectClient::new);
|
||||||
register(0xFF, RelayPacketFFErrorCode.class);
|
register(0xFF, RelayPacketFFErrorCode.class, RelayPacketFFErrorCode::new);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static RelayPacket readPacket(DataInputStream input, IRelayLogger logger) throws IOException {
|
public static RelayPacket readPacket(DataInputStream input, IRelayLogger logger) throws IOException {
|
||||||
int i = input.read();
|
int i = input.read();
|
||||||
try {
|
Supplier<? extends RelayPacket> ctor = definedPacketCtors.get(i);
|
||||||
Class<? extends RelayPacket> clazz = definedPacketClasses.get(i);
|
if(ctor == null) {
|
||||||
if(clazz == null) {
|
|
||||||
throw new IOException("Unknown packet type: " + i);
|
throw new IOException("Unknown packet type: " + i);
|
||||||
}
|
}
|
||||||
RelayPacket pkt = clazz.newInstance();
|
RelayPacket pkt = ctor.get();
|
||||||
pkt.read(input);
|
pkt.read(input);
|
||||||
int j = input.available();
|
int j = input.available();
|
||||||
if(j > 0) {
|
if(j > 0) {
|
||||||
throw new IOException("Packet type " + i + " had " + j + " remaining bytes");
|
throw new IOException("Packet type " + i + " had " + j + " remaining bytes");
|
||||||
}
|
}
|
||||||
return pkt;
|
return pkt;
|
||||||
} catch (InstantiationException | IllegalAccessException e) {
|
|
||||||
logger.error("Could not instanciate packet {}", i);
|
|
||||||
logger.error(e);
|
|
||||||
throw new IOException("Unknown packet type: " + i);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static byte[] writePacket(RelayPacket packet, IRelayLogger logger) throws IOException {
|
public static byte[] writePacket(RelayPacket packet, IRelayLogger logger) throws IOException {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user