diff options
author | Devaev Maxim <[email protected]> | 2020-12-21 01:59:49 +0300 |
---|---|---|
committer | Devaev Maxim <[email protected]> | 2020-12-21 01:59:49 +0300 |
commit | 42475809fcafef12d39a12b7dd2be49aea9d9b6f (patch) | |
tree | a56572c31a6128434d2c8b89e7d479a558965b47 /kvmd/plugins/msd/relay/__init__.py | |
parent | 2cb210c975b37d4e9db06b8e121f42f7d09c6fe1 (diff) |
refactoring
Diffstat (limited to 'kvmd/plugins/msd/relay/__init__.py')
-rw-r--r-- | kvmd/plugins/msd/relay/__init__.py | 40 |
1 files changed, 17 insertions, 23 deletions
diff --git a/kvmd/plugins/msd/relay/__init__.py b/kvmd/plugins/msd/relay/__init__.py index ea87168c..bbb2b647 100644 --- a/kvmd/plugins/msd/relay/__init__.py +++ b/kvmd/plugins/msd/relay/__init__.py @@ -176,32 +176,26 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes raise MsdCdromNotSupported() @aiotools.atomic - async def connect(self) -> None: + async def set_connected(self, connected: bool) -> None: async with self.__working(): async with self.__region: - if self.__connected: - raise MsdConnectedError() - - self.__gpio.switch_to_server() - self.__connected = True - get_logger(0).info("MSD switched to Server") - - @aiotools.atomic - async def disconnect(self) -> None: - async with self.__working(): - async with self.__region: - if not self.__connected: - raise MsdDisconnectedError() - - self.__gpio.switch_to_local() - try: - await self.__load_device_info() - except Exception: + if connected: if self.__connected: - self.__gpio.switch_to_server() - raise - self.__connected = False - get_logger(0).info("MSD switched to KVM: %s", self.__device_info) + raise MsdConnectedError() + self.__gpio.switch_to_server() + get_logger(0).info("MSD switched to Server") + else: + if not self.__connected: + raise MsdDisconnectedError() + self.__gpio.switch_to_local() + try: + await self.__load_device_info() + except Exception: + if self.__connected: + self.__gpio.switch_to_server() + raise + get_logger(0).info("MSD switched to KVM: %s", self.__device_info) + self.__connected = connected @contextlib.asynccontextmanager async def write_image(self, name: str) -> AsyncGenerator[None, None]: |