From 2826e2cdeea4b02d3d62369d3e8e73e4b594a9de Mon Sep 17 00:00:00 2001 From: Fallen_Breath Date: Tue, 17 Aug 2021 09:18:06 +0800 Subject: [PATCH] proper thread name hack and disconnect handling --- mcdr_pycraft_bot/bot_manager.py | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/mcdr_pycraft_bot/bot_manager.py b/mcdr_pycraft_bot/bot_manager.py index 20f4cb2..1be2335 100644 --- a/mcdr_pycraft_bot/bot_manager.py +++ b/mcdr_pycraft_bot/bot_manager.py @@ -7,14 +7,16 @@ class Bot: - def __init__(self, name: str, address: str, port: int): + def __init__(self, storage: 'BotStorage', name: str, address: str, port: int): + self.__storage = storage self.name = name self.connection = Connection( address=address, port=port, auth_token=None, username=name, - handle_exception=self.handle_exception + handle_exception=self.handle_exception, + handle_exit=self.handle_exit ) self.connection.connect() @@ -23,6 +25,11 @@ def stop(self): def handle_exception(self, exc, exc_info): ServerInterface.get_instance().logger.warning('Exception at MCDR bot {}: {}'.format(self.name, exc)) + self.handle_exit() + + def handle_exit(self): + ServerInterface.get_instance().logger.warning('Disconnected') + self.__storage.remove_bot(self.name) class BotStorage(Dict[str, Bot]): @@ -33,10 +40,14 @@ def __init__(self): @staticmethod def __patch_pycraft(): - NetworkingThread.getName = lambda self: 'MCDR Bot {}'.format(self.connection.username) + def modify_thread_name(self, *args, **kwargs): + original_init(self, *args, **kwargs) + self.name = 'MCDR-Bot {}'.format(self.connection.username) + original_init = NetworkingThread.__init__ + NetworkingThread.__init__ = modify_thread_name def add_bot(self, name: str, address: str, port: int) -> bool: - bot = Bot(name, address, port) + bot = Bot(self, name, address, port) if bot.connection.connected: with self.__lock: self[name] = bot