2012-12-17 14:40:49 +01:00
|
|
|
import string
|
|
|
|
import copy
|
|
|
|
|
|
|
|
class PacketDumper:
|
|
|
|
options = None
|
|
|
|
writeFile = None
|
|
|
|
|
|
|
|
def onEnable(self, parser):
|
2012-12-25 21:38:02 +01:00
|
|
|
parser.add_option("-d", "--dump-packets",
|
|
|
|
action="store_true", dest="dumpPackets", default=False,
|
|
|
|
help="run with this argument to dump packets")
|
|
|
|
|
2012-12-17 14:40:49 +01:00
|
|
|
parser.add_option("-o", "--out-file", dest="filename", default="dump.txt",
|
2012-12-25 21:38:02 +01:00
|
|
|
help="file to dump packets to")
|
|
|
|
|
2012-12-17 14:40:49 +01:00
|
|
|
def onDisable(self):
|
|
|
|
if (self.writeFile != None):
|
|
|
|
self.writeFile.close()
|
2012-12-25 21:38:02 +01:00
|
|
|
|
2012-12-17 14:40:49 +01:00
|
|
|
def optionsParsed(self, parsedOptions):
|
|
|
|
self.options = parsedOptions
|
|
|
|
if (self.options.dumpPackets):
|
|
|
|
self.writeFile = open(self.options.filename, 'w')
|
|
|
|
|
|
|
|
def packetReceive(self, packetID, receivedPacket):
|
|
|
|
packet = copy.deepcopy(receivedPacket)
|
|
|
|
if (self.writeFile != None):
|
|
|
|
if (packetID == "\x33" or packetID == "\x38"):
|
2012-12-25 21:38:02 +01:00
|
|
|
packet = {'ChunkPlaceHolder': 0}
|
2012-12-17 14:40:49 +01:00
|
|
|
if (packetID == "\x03"):
|
|
|
|
packet['Message'] = filter(lambda x: x in string.printable, packet['Message'])
|
|
|
|
self.writeFile.write(hex(ord(packetID)) + " : " + str(packet) + '\n')
|
|
|
|
|
|
|
|
|