summaryrefslogtreecommitdiff
path: root/kvmd/plugins/msd/relay/__init__.py
diff options
context:
space:
mode:
authorDevaev Maxim <[email protected]>2020-12-21 01:59:49 +0300
committerDevaev Maxim <[email protected]>2020-12-21 01:59:49 +0300
commit42475809fcafef12d39a12b7dd2be49aea9d9b6f (patch)
treea56572c31a6128434d2c8b89e7d479a558965b47 /kvmd/plugins/msd/relay/__init__.py
parent2cb210c975b37d4e9db06b8e121f42f7d09c6fe1 (diff)
refactoring
Diffstat (limited to 'kvmd/plugins/msd/relay/__init__.py')
-rw-r--r--kvmd/plugins/msd/relay/__init__.py40
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]: