2016-09-12 06:52:50 +00:00
|
|
|
import threading
|
|
|
|
import logging
|
2017-05-03 00:52:16 +00:00
|
|
|
from sys import exit
|
2016-09-12 06:52:50 +00:00
|
|
|
from impacket import smbserver
|
|
|
|
|
|
|
|
class CMESMBServer(threading.Thread):
|
|
|
|
|
2017-03-27 21:09:36 +00:00
|
|
|
def __init__(self, logger, share_name, share_path='/tmp/cme_hosted', listen_address='0.0.0.0', listen_port=445, verbose=False):
|
2016-09-12 06:52:50 +00:00
|
|
|
try:
|
|
|
|
threading.Thread.__init__(self)
|
|
|
|
|
2017-03-27 21:09:36 +00:00
|
|
|
self.server = smbserver.SimpleSMBServer(listen_address, listen_port)
|
|
|
|
self.server.addShare(share_name.upper(), share_path)
|
2016-09-12 06:52:50 +00:00
|
|
|
if verbose: self.server.setLogFile('')
|
|
|
|
self.server.setSMB2Support(False)
|
|
|
|
self.server.setSMBChallenge('')
|
|
|
|
except Exception as e:
|
|
|
|
errno, message = e.args
|
|
|
|
if errno == 98 and message == 'Address already in use':
|
2017-03-27 21:09:36 +00:00
|
|
|
logger.error('Error starting SMB server on port 445: the port is already in use')
|
2016-09-12 06:52:50 +00:00
|
|
|
else:
|
2017-03-27 21:09:36 +00:00
|
|
|
logger.error('Error starting SMB server on port 445: {}'.format(message))
|
2017-05-03 00:52:16 +00:00
|
|
|
exit(1)
|
2016-09-12 06:52:50 +00:00
|
|
|
|
2017-03-27 21:09:36 +00:00
|
|
|
def addShare(self, share_name, share_path):
|
|
|
|
self.server.addShare(share_name, share_path)
|
2016-09-12 06:52:50 +00:00
|
|
|
|
|
|
|
def run(self):
|
2016-12-15 07:28:00 +00:00
|
|
|
try:
|
2016-09-12 06:52:50 +00:00
|
|
|
self.server.start()
|
2016-12-15 07:28:00 +00:00
|
|
|
except:
|
2016-09-12 06:52:50 +00:00
|
|
|
pass
|
|
|
|
|
|
|
|
def shutdown(self):
|
|
|
|
self._Thread__stop()
|
|
|
|
# make sure all the threads are killed
|
|
|
|
for thread in threading.enumerate():
|
|
|
|
if thread.isAlive():
|
|
|
|
try:
|
|
|
|
thread._Thread__stop()
|
|
|
|
except:
|
|
|
|
pass
|