diff --git a/RNS/Interfaces/TCPInterface.py b/RNS/Interfaces/TCPInterface.py index d15d5a1..025530c 100644 --- a/RNS/Interfaces/TCPInterface.py +++ b/RNS/Interfaces/TCPInterface.py @@ -539,6 +539,7 @@ class TCPServerInterface(Interface): else: ThreadingTCPServer.allow_reuse_address = True self.server = ThreadingTCPServer(bind_address, handlerFactory(self.incoming_connection)) + self.server.daemon_threads = True self.bitrate = TCPServerInterface.BITRATE_GUESS @@ -606,13 +607,15 @@ class TCPServerInterface(Interface): pass def detach(self): + self.detached = True + self.online = False if self.server != None: if hasattr(self.server, "shutdown"): if callable(self.server.shutdown): try: RNS.log("Detaching "+str(self), RNS.LOG_DEBUG) self.server.shutdown() - self.detached = True + self.server.server_close() self.server = None except Exception as e: diff --git a/RNS/Reticulum.py b/RNS/Reticulum.py index b31075d..9d78089 100755 --- a/RNS/Reticulum.py +++ b/RNS/Reticulum.py @@ -263,6 +263,7 @@ class Reticulum: RNS.loglevel = self.requested_loglevel self.is_shared_instance = False + self.shared_instance_interface = None self.require_shared = require_shared_instance self.is_connected_to_shared_instance = False self.is_standalone_instance = False @@ -361,6 +362,7 @@ class Reticulum: else: RNS.Transport.interfaces.append(interface) + self.shared_instance_interface = interface self.is_shared_instance = True RNS.log("Started shared instance interface: "+str(interface), RNS.LOG_DEBUG) self.__start_jobs() diff --git a/RNS/Utilities/rnsd.py b/RNS/Utilities/rnsd.py index 6a46e1c..2db5455 100755 --- a/RNS/Utilities/rnsd.py +++ b/RNS/Utilities/rnsd.py @@ -42,6 +42,8 @@ def program_setup(configdir, verbosity = 0, quietness = 0, service = False): if reticulum.is_connected_to_shared_instance: RNS.log("Started rnsd version {version} connected to another shared local instance, this is probably NOT what you want!".format(version=__version__), RNS.LOG_WARNING) else: + if RNS.Reticulum.get_instance().shared_instance_interface: + RNS.Reticulum.get_instance().shared_instance_interface.server.daemon_threads = True RNS.log("Started rnsd version {version}".format(version=__version__), RNS.LOG_NOTICE) while True: