diff options
author | Devaev Maxim <[email protected]> | 2021-05-25 01:41:23 +0300 |
---|---|---|
committer | Devaev Maxim <[email protected]> | 2021-05-25 01:41:23 +0300 |
commit | 8bc36eac5d0ccc916df7e45e5c29362c09079b02 (patch) | |
tree | 87d73f776644e59cbccf41943ffd7bebe4865545 /kvmd/plugins/msd/otg/__init__.py | |
parent | ec2fff0df78c66f781131da3aab62a21232768de (diff) |
pikvm/pikvm#208: permanent image
Diffstat (limited to 'kvmd/plugins/msd/otg/__init__.py')
-rw-r--r-- | kvmd/plugins/msd/otg/__init__.py | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/kvmd/plugins/msd/otg/__init__.py b/kvmd/plugins/msd/otg/__init__.py index c0c9f38e..3bbad09e 100644 --- a/kvmd/plugins/msd/otg/__init__.py +++ b/kvmd/plugins/msd/otg/__init__.py @@ -41,7 +41,9 @@ from ....inotify import Inotify from ....yamlconf import Option +from ....validators.basic import valid_bool from ....validators.os import valid_abs_dir +from ....validators.os import valid_printable_filename from ....validators.os import valid_command from .... import aiotools @@ -138,6 +140,8 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes remount_cmd: List[str], unlock_cmd: List[str], + initial: Dict, + gadget: str, # XXX: Not from options, see /kvmd/apps/kvmd/__init__.py for details ) -> None: @@ -148,6 +152,9 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes self.__remount_cmd = remount_cmd self.__unlock_cmd = unlock_cmd + self.__initial_image: str = initial["image"] + self.__initial_cdrom: bool = initial["cdrom"] + self.__drive = Drive(gadget, instance=0, lun=0) self.__new_file: Optional[aiofiles.base.AiofilesContextManager] = None @@ -168,6 +175,10 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes "storage": Option("/var/lib/kvmd/msd", type=valid_abs_dir, unpack_as="storage_path"), "remount_cmd": Option([*sudo, "/usr/bin/kvmd-helper-otgmsd-remount", "{mode}"], type=valid_command), "unlock_cmd": Option([*sudo, "/usr/bin/kvmd-helper-otgmsd-unlock", "unlock"], type=valid_command), + "initial": { + "image": Option("", type=(lambda arg: (valid_printable_filename(arg) if arg else ""))), + "cdrom": Option(False, type=valid_bool), + }, } async def get_state(self) -> Dict: @@ -423,6 +434,7 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes logger.info("Probing to remount storage ...") await self.__remount_storage(rw=True) await self.__remount_storage(rw=False) + await self.__setup_initial() storage_state = self.__get_storage_state() except Exception: @@ -448,6 +460,21 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes self.__state.vd.connected = False + async def __setup_initial(self) -> None: + if self.__initial_image: + logger = get_logger(0) + path = os.path.join(self.__images_path, self.__initial_image) + if os.path.exists(path): + logger.info("Setting up initial image %r ...", self.__initial_image) + try: + await self.__unlock_drive() + self.__drive.set_cdrom_flag(self.__initial_cdrom) + self.__drive.set_image_path(path) + except Exception: + logger.exception("Can't setup initial image: ignored") + else: + logger.error("Can't find initial image %r: ignored", self.__initial_image) + # ===== def __get_storage_state(self) -> _StorageState: |