From 26e429019e5fe5b01ee1a476c879d8f8333b0ab0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adolfo=20G=C3=B3mez=20Garc=C3=ADa?= Date: Mon, 20 Jan 2020 17:42:33 +0100 Subject: [PATCH] fixing actor on exit --- actor/src/udsactor/service.py | 12 +----------- actor/src/udsactor/windows/service.py | 1 + 2 files changed, 2 insertions(+), 11 deletions(-) diff --git a/actor/src/udsactor/service.py b/actor/src/udsactor/service.py index 2a3890d25..3ae9bc070 100644 --- a/actor/src/udsactor/service.py +++ b/actor/src/udsactor/service.py @@ -59,7 +59,6 @@ class CommonService: # pylint: disable=too-many-instance-attributes _isAlive: bool = True _rebootRequested: bool = False _loggedIn = False - _ready = False _cfg: types.ActorConfigurationType _api: rest.UDSServerApi @@ -128,8 +127,6 @@ class CommonService: # pylint: disable=too-many-instance-attributes if not self._isAlive: return - self._ready = False - # First, if postconfig is available, execute it and disable it if self._cfg.post_command: self.execute(self._cfg.post_command, 'postConfig') @@ -146,9 +143,7 @@ class CommonService: # pylint: disable=too-many-instance-attributes counter -= 1 try: self._certificate = self._api.ready(self._cfg.own_token, self._secret, srvInterface.ip, rest.LISTEN_PORT) - self._ready = True except rest.RESTConnectionError as e: - logger.error('Error en ready: %s -- %s', e, self._isAlive) if not logged: # Only log connection problems ONCE logged = True logger.error('Error connecting with UDS Broker') @@ -277,8 +272,7 @@ class CommonService: # pylint: disable=too-many-instance-attributes if self._loggedIn and self._cfg.own_token: self._loggedIn = False try: - if self._ready: - self._api.logout(self._cfg.own_token, '') + self._api.logout(self._cfg.own_token, '') except Exception as e: logger.error('Error notifying final logout to UDS: %s', e) @@ -364,8 +358,6 @@ class CommonService: # pylint: disable=too-many-instance-attributes # Client notifications def login(self, username: str) -> types.LoginResultInfoType: - if not self._ready: - return types.LoginResultInfoType('', '', 0, 0) result = types.LoginResultInfoType(ip='', hostname='', dead_line=None, max_idle=None) self._loggedIn = True if self._cfg.own_token: @@ -373,8 +365,6 @@ class CommonService: # pylint: disable=too-many-instance-attributes return result def logout(self, username: str) -> None: - if not self._ready: - return self._loggedIn = False if self._cfg.own_token: self._api.logout(self._cfg.own_token, username) diff --git a/actor/src/udsactor/windows/service.py b/actor/src/udsactor/windows/service.py index 81db4e56f..9a90c5a16 100644 --- a/actor/src/udsactor/windows/service.py +++ b/actor/src/udsactor/windows/service.py @@ -91,6 +91,7 @@ class UDSActorSvc(win32serviceutil.ServiceFramework, CommonService): def doWait(self, miliseconds: int) -> None: win32event.WaitForSingleObject(self._hWaitStop, miliseconds) + # On windows, and while on tasks, ensure that our app processes waiting messages on "wait times" pythoncom.PumpWaitingMessages() # pylint: disable=no-member def oneStepJoin(self, name: str, domain: str, ou: str, account: str, password: str) -> None: # pylint: disable=too-many-arguments