import os import struct import settings from SocketServer import BaseRequestHandler from packets import LDAPSearchDefaultPacket, LDAPSearchSupportedCapabilitiesPacket, LDAPSearchSupportedMechanismsPacket, LDAPNTLMChallenge from utils import * def ParseSearch(data): Search1 = re.search('(objectClass)', data) Search2 = re.search('(?i)(objectClass0*.*supportedCapabilities)', data) Search3 = re.search('(?i)(objectClass0*.*supportedSASLMechanisms)', data) if Search1: return str(LDAPSearchDefaultPacket(MessageIDASNStr=data[8:9])) if Search2: return str(LDAPSearchSupportedCapabilitiesPacket(MessageIDASNStr=data[8:9],MessageIDASN2Str=data[8:9])) if Search3: return str(LDAPSearchSupportedMechanismsPacket(MessageIDASNStr=data[8:9],MessageIDASN2Str=data[8:9])) def ParseLDAPHash(data, client): SSPIStart = data[42:] LMhashLen = struct.unpack(' 10: LMhashOffset = struct.unpack('i',data[2:6])[0] MessageSequence = struct.unpack('i',data[11:15])[0] LDAPVersion = struct.unpack('