From a0147b0e7389a885e16fb5535f3711031fdaa324 Mon Sep 17 00:00:00 2001 From: Stefano Pigozzi Date: Sun, 20 Oct 2019 18:54:48 +0200 Subject: [PATCH] Add support for network broadcasts --- requirements.txt | 2 +- royalnet/bots/generic.py | 39 +++++++++++++++++++++------------------ 2 files changed, 22 insertions(+), 19 deletions(-) diff --git a/requirements.txt b/requirements.txt index 27833fed..64de8678 100644 --- a/requirements.txt +++ b/requirements.txt @@ -30,7 +30,7 @@ python-telegram-bot==12.2.0 pytz==2019.3 pywin32-ctypes==0.2.0 regex==2019.8.19 -royalherald==5.0b8 +royalherald==5.1b2 sentry-sdk==0.13.0 six==1.12.0 sortedcontainers==2.1.0 diff --git a/royalnet/bots/generic.py b/royalnet/bots/generic.py index d6bc102a..71c40989 100644 --- a/royalnet/bots/generic.py +++ b/royalnet/bots/generic.py @@ -29,7 +29,7 @@ class GenericBot: self._Data = self._data_factory() self.commands = {} self.network_handlers: typing.Dict[str, typing.Callable[["GenericBot", typing.Any], - typing.Awaitable[typing.Dict]]] = {} + typing.Awaitable[typing.Optional[typing.Dict]]]] = {} for SelectedCommand in self.uninitialized_commands: interface = self._Interface() try: @@ -97,26 +97,29 @@ class GenericBot: log.debug(f"Running NetworkLink {self.network}") self.loop.create_task(self.network.run()) - async def _network_handler(self, request: rh.Request) -> rh.Response: + async def _network_handler(self, message: typing.Union[rh.Request, rh.Broadcast]) -> rh.Response: try: - network_handler = self.network_handlers[request.handler] + network_handler = self.network_handlers[message.handler] except KeyError: - log.warning(f"Missing network_handler for {request.handler}") - return rh.ResponseFailure("no_handler", f"This bot is missing a network handler for {request.handler}.") + log.warning(f"Missing network_handler for {message.handler}") + return rh.ResponseFailure("no_handler", f"This bot is missing a network handler for {message.handler}.") else: - log.debug(f"Using {network_handler} as handler for {request.handler}") - try: - response_data = await network_handler(self, **request.data) - return rh.ResponseSuccess(data=response_data) - except Exception as e: - sentry_sdk.capture_exception(e) - log.error(f"Exception {e} in {network_handler}") - return rh.ResponseFailure("exception_in_handler", - f"An exception was raised in {network_handler} for {request.handler}.", - extra_info={ - "type": e.__class__.__name__, - "message": str(e) - }) + log.debug(f"Using {network_handler} as handler for {message.handler}") + if isinstance(message, rh.Request): + try: + response_data = await network_handler(self, **message.data) + return rh.ResponseSuccess(data=response_data) + except Exception as e: + sentry_sdk.capture_exception(e) + log.error(f"Exception {e} in {network_handler}") + return rh.ResponseFailure("exception_in_handler", + f"An exception was raised in {network_handler} for {message.handler}.", + extra_info={ + "type": e.__class__.__name__, + "message": str(e) + }) + elif isinstance(message, rh.Broadcast): + await network_handler(self, **message.data) def _init_database(self): """Create an :py:class:`royalnet.database.Alchemy` with the tables required by the packs. Then,