From e76a4ba3be73a740f5a903a7b905811252843cb4 Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Mon, 19 Sep 2016 02:53:39 +0300 Subject: servergreps: add to all servers for detect getting packet sizes. And into hercules forks also parsing actual packet sizes in packets.h --- servergreps/hercules/src/threeceam.py | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) (limited to 'servergreps/hercules/src/threeceam.py') diff --git a/servergreps/hercules/src/threeceam.py b/servergreps/hercules/src/threeceam.py index 77e1f19..e7b41c4 100755 --- a/servergreps/hercules/src/threeceam.py +++ b/servergreps/hercules/src/threeceam.py @@ -20,6 +20,7 @@ class Threeceam: inPackets = dict() functionToId = dict() loginPacketNameToId = dict() + getLenPackets = set() namedPacketre = re.compile( "((\t|[ ])*)(?P[\w0-9_]+)([ ]*)=" + @@ -47,6 +48,8 @@ class Threeceam: lclifPacketre = re.compile( "([ ]*)[{][ ]PACKET_ID_CA_(?P[A-Z0-9_]+),([^,]+)," + "([ ]*)[&](?P[0-9a-zA-Z_>-]+)([ ]*)[}],") + packetLenre = re.compile( + "packet_db[\\[]0[\\]][\\[]0x(?P[0-9a-fA-F]+)[\\]].len") def collectNamedPackets(self, fileName): with open(fileName, "r") as f: @@ -144,7 +147,6 @@ class Threeceam: while len(data) < 4: data = "0" + data self.addServerPacket(data) - m = self.ourPacketre2.findall(line) if len(m) > 0: for str in m: @@ -163,6 +165,15 @@ class Threeceam: data = str[2] data = self.loginPacketNameToId[data] self.addServerPacket(data) + m = self.packetLenre.findall(line) + if len(m) > 0: + for str in m: + data = str.lower() + if len(data) > 2 and data[0:2] == "0x": + data = data[2:] + while len(data) < 4: + data = "0" + data + self.getLenPackets.add(data) def sortOutPackets(self): -- cgit v1.2.3-70-g09d2