#!/usr/bin/env python3 """ Minimal SMB server using Impacket's SimpleSMBServer. Logs all connection attempts, optionally forwarding them as JSON to LOG_TARGET. """ import os from impacket import smbserver from syslog_bridge import syslog_line, write_syslog_file, forward_syslog NODE_NAME = os.environ.get("NODE_NAME", "WORKSTATION") SERVICE_NAME = "smb" LOG_TARGET = os.environ.get("LOG_TARGET", "") def _log(event_type: str, severity: int = 6, **kwargs) -> None: line = syslog_line(SERVICE_NAME, NODE_NAME, event_type, severity, **kwargs) write_syslog_file(line) forward_syslog(line, LOG_TARGET) if __name__ == "__main__": _log("startup", msg=f"SMB server starting as {NODE_NAME}") os.makedirs("/tmp/smb_share", exist_ok=True) # nosec B108 server = smbserver.SimpleSMBServer(listenAddress="0.0.0.0", listenPort=445) # nosec B104 server.setSMB2Support(True) server.setSMBChallenge("") server.addShare("SHARE", "/tmp/smb_share", "Shared Documents") # nosec B108 try: server.start() except KeyboardInterrupt: _log("shutdown")