summaryrefslogtreecommitdiff
path: root/kvmd/plugins
diff options
context:
space:
mode:
Diffstat (limited to 'kvmd/plugins')
-rw-r--r--kvmd/plugins/msd/otg/__init__.py2
-rw-r--r--kvmd/plugins/msd/otg/storage.py47
2 files changed, 25 insertions, 24 deletions
diff --git a/kvmd/plugins/msd/otg/__init__.py b/kvmd/plugins/msd/otg/__init__.py
index ce43d3d8..4155a89e 100644
--- a/kvmd/plugins/msd/otg/__init__.py
+++ b/kvmd/plugins/msd/otg/__init__.py
@@ -179,7 +179,6 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes
for name in list(storage["images"]):
del storage["images"][name]["path"]
del storage["images"][name]["in_storage"]
- del storage["images"][name]["storage"]
storage["downloading"] = (self.__reader.get_state() if self.__reader else None)
@@ -197,7 +196,6 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes
vd = dataclasses.asdict(self.__state.vd)
if vd["image"]:
del vd["image"]["path"]
- del vd["image"]["storage"]
return {
"enabled": True,
diff --git a/kvmd/plugins/msd/otg/storage.py b/kvmd/plugins/msd/otg/storage.py
index 80e6fa87..051ef007 100644
--- a/kvmd/plugins/msd/otg/storage.py
+++ b/kvmd/plugins/msd/otg/storage.py
@@ -38,24 +38,30 @@ from .. import MsdError
class _Image:
name: str
path: str
- storage: Optional["Storage"] = dataclasses.field(compare=False)
-
in_storage: bool = dataclasses.field(init=False)
-
complete: bool = dataclasses.field(init=False, compare=False)
size: int = dataclasses.field(init=False, compare=False)
mod_ts: float = dataclasses.field(init=False, compare=False)
class Image(_Image):
+ def __init__(self, name: str, path: str, storage: Optional["Storage"]) -> None:
+ super().__init__(name, path)
+ self.__storage = storage
+ self.__complete_path = os.path.join(
+ os.path.dirname(path),
+ ".__" + os.path.basename(path) + ".complete",
+ )
+ self.__adopted = (storage._is_adopted(self) if storage else True)
+
@property
def in_storage(self) -> bool:
- return (self.storage is not None)
+ return bool(self.__storage)
@property
def complete(self) -> bool:
- if self.storage is not None:
- return os.path.exists(self.__get_complete_path())
+ if self.__storage:
+ return os.path.exists(self.__complete_path)
return True
@property
@@ -76,12 +82,12 @@ class Image(_Image):
return os.path.exists(self.path)
async def remount_rw(self, rw: bool, fatal: bool=True) -> None:
- assert self.storage
- if self.storage._is_mounted(self): # pylint: disable=protected-access
- await self.storage.remount_rw(rw, fatal)
+ assert self.__storage
+ if not self.__adopted:
+ await self.__storage.remount_rw(rw, fatal)
def remove(self, fatal: bool) -> None:
- assert self.storage is not None
+ assert self.__storage
try:
os.remove(self.path)
except FileNotFoundError:
@@ -92,22 +98,15 @@ class Image(_Image):
self.set_complete(False)
def set_complete(self, flag: bool) -> None:
- assert self.storage is not None
- path = self.__get_complete_path()
+ assert self.__storage
if flag:
- open(path, "w").close() # pylint: disable=consider-using-with
+ open(self.__complete_path, "w").close() # pylint: disable=consider-using-with
else:
try:
- os.remove(path)
+ os.remove(self.__complete_path)
except FileNotFoundError:
pass
- def __get_complete_path(self) -> str:
- return os.path.join(
- os.path.dirname(self.path),
- ".__" + os.path.basename(self.path) + ".complete",
- )
-
@dataclasses.dataclass(frozen=True)
class StorageSpace:
@@ -173,11 +172,15 @@ class Storage:
free=(st.f_bavail * st.f_frsize),
)
- def _is_mounted(self, image: Image) -> bool:
+ def _is_adopted(self, image: Image) -> bool:
+ # True, если образ находится вне хранилища
+ # или в другой точке монтирования под ним
+ if not image.in_storage:
+ return True
path = image.path
while not os.path.ismount(path):
path = os.path.dirname(path)
- return (path == self.__path)
+ return (self.__path != path)
async def remount_rw(self, rw: bool, fatal: bool=True) -> None:
if not (await aiohelpers.remount("MSD", self.__remount_cmd, rw)):