import struct import logging import threading import re from SocketServer import TCPServer, ThreadingMixIn, BaseRequestHandler from LDAPPackets import * from core.responder.common import * from core.logger import logger formatter = logging.Formatter("%(asctime)s [LDAPserver] %(message)s", datefmt="%Y-%m-%d %H:%M:%S") log = logger().setup_logger("LDAPserver", formatter) class LDAPserver(): def start(self, chal): global Challenge; Challenge = chal try: log.debug("online") server = ThreadingTCPServer(("0.0.0.0", 389), LDAP) t = threading.Thread(name="LDAPserver", target=server.serve_forever) t.setDaemon(True) t.start() except Exception as e: log.error("Error starting on port {}: {}".format(389, e)) class ThreadingTCPServer(ThreadingMixIn, TCPServer): allow_reuse_address = 1 def server_bind(self): TCPServer.server_bind(self) 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): SSPIStarts = 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('