6 from resources.lib.common import log
7 from resources.lib.MSLHttpRequestHandler import MSLHttpRequestHandler
9 def select_unused_port():
10 s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
11 s.bind(('localhost', 0))
12 addr, port = s.getsockname()
16 addon = xbmcaddon.Addon()
17 PORT = select_unused_port()
18 addon.setSetting('msl_service_port', str(PORT))
19 log("Picked Port: " + str(PORT))
20 Handler = MSLHttpRequestHandler
21 SocketServer.TCPServer.allow_reuse_address = True
22 server = SocketServer.TCPServer(('127.0.0.1', PORT), Handler)
23 server.server_activate()
26 if __name__ == '__main__':
27 monitor = xbmc.Monitor()
28 thread = threading.Thread(target=server.serve_forever)
32 while not monitor.abortRequested():
33 if monitor.waitForAbort(5):
40 log("Stopped MSL Service")