diff --git a/src/main/protocol/HPacket.java b/src/main/protocol/HPacket.java index 63ef9bdc..24a5fda4 100644 --- a/src/main/protocol/HPacket.java +++ b/src/main/protocol/HPacket.java @@ -185,6 +185,46 @@ private static byte[] fromStringToBytes(String curstring) { return new byte[0]; } + public boolean structureEquals(String structure) { + if (isCorrupted()) return false; + + int indexbuffer = readIndex; + readIndex = 6; + + String[] split = structure.split(","); + + for (int i = 0; i < split.length; i++) { + String s = split[i]; + + if (s.equals("s")) { + if (readUshort(readIndex) + 2 + readIndex > getBytesLength()) return false; + readString(); + } + else if (s.equals("i")) { + if (readIndex + 4 > getBytesLength()) return false; + readInteger(); + } + else if (s.equals("u")) { + if (readIndex + 2 > getBytesLength()) return false; + readUshort(); + } + else if (s.equals("b")) { + if (readIndex + 1 > getBytesLength()) return false; + readBoolean(); + } + } + + boolean result = (isEOF() == 1); + readIndex = indexbuffer; + return result; + } + + public int isEOF() { + if (readIndex < getBytesLength()) return 0; + if (readIndex == getBytesLength()) return 1; + return 2; + } + public byte[] toBytes() { return packetInBytes; } @@ -800,34 +840,5 @@ public boolean equals(Object object) { } public static void main(String[] args) { -// HPacket packet = new HPacket("{l}{u:500}{i:4}{s:heey}{b:false}"); -// System.out.println(packet); -// -// String stringified = packet.stringify(); -// System.out.println("stringified: " + stringified); -// System.out.println(stringified.length()); -// -// -// HPacket packet1 = new HPacket(new byte[0]); -// packet1.constructFromString(stringified); -// -// System.out.println(packet1); -// System.out.println(packet.equals(packet1)); - - HPacket packet = new HPacket(555); - for (int i = -128; i < 128; i++) { - packet.appendByte((byte)i); - } - System.out.println(packet); - - String stringified = packet.stringify(); - System.out.println(stringified.length()); - - - HPacket packet1 = new HPacket(new byte[0]); - packet1.constructFromString(stringified); - - System.out.println(packet1); - System.out.println(packet.equals(packet1)); } } \ No newline at end of file diff --git a/src/main/protocol/packethandler/Handler.java b/src/main/protocol/packethandler/Handler.java index b86cd9c4..46600312 100644 --- a/src/main/protocol/packethandler/Handler.java +++ b/src/main/protocol/packethandler/Handler.java @@ -104,15 +104,12 @@ public void unblock() { * @param message */ void notifyListeners(HMessage message) { - for (TrafficListener listener : (List)listeners[0]) { - listener.onCapture(message); - } - for (TrafficListener listener : (List)listeners[1]) { - listener.onCapture(message); - } - for (TrafficListener listener : (List)listeners[2]) { - listener.onCapture(message); + for (int x = 0; x < 3; x++) { + for (int i = ((List)listeners[x]).size() - 1; i >= 0; i--) { + ((List)listeners[x]).get(i).onCapture(message); + } } + } public void sendToStream(byte[] buffer) { diff --git a/src/main/protocol/packethandler/IncomingHandler.java b/src/main/protocol/packethandler/IncomingHandler.java index 7ddb8bcf..a6198e54 100644 --- a/src/main/protocol/packethandler/IncomingHandler.java +++ b/src/main/protocol/packethandler/IncomingHandler.java @@ -10,16 +10,22 @@ public class IncomingHandler extends Handler { - private volatile boolean onlyOnce = true; public IncomingHandler(OutputStream outputStream, Object[] listeners) { super(outputStream, listeners); - ((List)listeners[0]).add(message -> { - if (isDataStream && onlyOnce && (message.getPacket().length() == 261 || message.getPacket().length() == 517)) { - onlyOnce = false; - isEncryptedStream = message.getPacket().readBoolean(message.getPacket().length() + 3); + TrafficListener listener = new TrafficListener() { + @Override + public void onCapture(HMessage message) { + if (isDataStream && message.getPacket().structureEquals("s,b")) { + ((List)listeners[0]).remove(this); + HPacket packet = message.getPacket(); + packet.readString(); + isEncryptedStream = packet.readBoolean(); + } } - }); + }; + + ((List)listeners[0]).add(listener); } @Override