summaryrefslogtreecommitdiff
path: root/kvmd/plugins/msd
diff options
context:
space:
mode:
authorMaxim Devaev <[email protected]>2023-03-03 02:20:41 +0200
committerMaxim Devaev <[email protected]>2023-03-04 16:13:04 +0200
commitedd9435945a93e343f47344b689a17837fd5a738 (patch)
treea4319dbb9f599b051733fbf6151214129e4a7cb4 /kvmd/plugins/msd
parent5bc480c6e87319377604eed11ced18f0bbc4001e (diff)
refactoring
Diffstat (limited to 'kvmd/plugins/msd')
-rw-r--r--kvmd/plugins/msd/otg/__init__.py10
-rw-r--r--kvmd/plugins/msd/otg/storage.py92
2 files changed, 62 insertions, 40 deletions
diff --git a/kvmd/plugins/msd/otg/__init__.py b/kvmd/plugins/msd/otg/__init__.py
index e8805313..d7bbb571 100644
--- a/kvmd/plugins/msd/otg/__init__.py
+++ b/kvmd/plugins/msd/otg/__init__.py
@@ -183,6 +183,7 @@ 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)
@@ -200,6 +201,7 @@ 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,
@@ -336,7 +338,7 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes
raise MsdImageExistsError()
await self.__remount_rw(True)
- self.__storage.set_image_complete(image, False)
+ image.set_complete(False)
self.__writer = await MsdFileWriter(
notifier=self.__notifier,
@@ -348,11 +350,11 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes
self.__notifier.notify()
yield self.__writer
- self.__storage.set_image_complete(image, self.__writer.is_complete())
+ image.set_complete(self.__writer.is_complete())
finally:
if image and remove_incomplete and self.__writer and not self.__writer.is_complete():
- self.__storage.remove_image(image, fatal=False)
+ image.remove(fatal=False)
try:
await aiotools.shield_fg(self.__close_writer())
finally:
@@ -377,7 +379,7 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes
await self.__remount_rw(True)
try:
- self.__storage.remove_image(image, fatal=True)
+ image.remove(fatal=True)
finally:
await self.__remount_rw(False, fatal=False)
diff --git a/kvmd/plugins/msd/otg/storage.py b/kvmd/plugins/msd/otg/storage.py
index beb7f620..f9095224 100644
--- a/kvmd/plugins/msd/otg/storage.py
+++ b/kvmd/plugins/msd/otg/storage.py
@@ -23,32 +23,74 @@
import os
import dataclasses
+from typing import Optional
+
from ....logging import get_logger
# =====
@dataclasses.dataclass(frozen=True)
-class Image:
+class _Image:
name: str
path: str
+ storage: Optional["Storage"] = dataclasses.field(compare=False)
+
+ complete: bool = dataclasses.field(init=False, compare=False)
+ in_storage: 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):
+ @property
+ def complete(self) -> bool:
+ if self.storage is not None:
+ return os.path.exists(self.storage._get_complete_path(self)) # pylint: disable=protected-access
+ return True
- complete: bool = dataclasses.field(compare=False)
- in_storage: bool = dataclasses.field(compare=False)
+ @property
+ def in_storage(self) -> bool:
+ return (self.storage is not None)
- size: int = dataclasses.field(default=0, compare=False)
- mod_ts: float = dataclasses.field(default=0, compare=False)
+ @property
+ def size(self) -> int:
+ try:
+ return os.stat(self.path).st_size
+ except Exception:
+ return 0
+
+ @property
+ def mod_ts(self) -> float:
+ try:
+ return os.stat(self.path).st_mtime
+ except Exception:
+ return 0
def exists(self) -> bool:
return os.path.exists(self.path)
- def __post_init__(self) -> None:
+ def remove(self, fatal: bool) -> None:
+ assert self.storage is not None
try:
- st = os.stat(self.path)
- except Exception:
+ os.remove(self.path)
+ except FileNotFoundError:
pass
+ except Exception:
+ if fatal:
+ raise
+ self.set_complete(False)
+
+ def set_complete(self, flag: bool) -> None:
+ assert self.storage is not None
+ path = self.storage._get_complete_path(self) # pylint: disable=protected-access
+ if flag:
+ open(path, "w").close() # pylint: disable=consider-using-with
else:
- object.__setattr__(self, "size", st.st_size)
- object.__setattr__(self, "mod_ts", st.st_mtime)
+ try:
+ os.remove(path)
+ except FileNotFoundError:
+ pass
@dataclasses.dataclass(frozen=True)
@@ -63,6 +105,9 @@ class Storage:
self.__images_path = os.path.join(self.__path, "images")
self.__meta_path = os.path.join(self.__path, "meta")
+ def _get_complete_path(self, image: Image) -> str:
+ return os.path.join(self.__meta_path, image.name + ".complete")
+
def get_watchable_paths(self) -> list[str]:
return [self.__images_path, self.__meta_path]
@@ -85,33 +130,8 @@ class Storage:
def __get_image(self, name: str, path: str) -> Image:
assert name
assert path
- complete = True
in_storage = (os.path.dirname(path) == self.__images_path)
- if in_storage:
- complete = os.path.exists(os.path.join(self.__meta_path, name + ".complete"))
- return Image(name, path, complete, in_storage)
-
- def remove_image(self, image: Image, fatal: bool) -> None:
- assert image.in_storage
- try:
- os.remove(image.path)
- except FileNotFoundError:
- pass
- except Exception:
- if fatal:
- raise
- self.set_image_complete(image, False)
-
- def set_image_complete(self, image: Image, flag: bool) -> None:
- assert image.in_storage
- path = os.path.join(self.__meta_path, image.name + ".complete")
- if flag:
- open(path, "w").close() # pylint: disable=consider-using-with
- else:
- try:
- os.remove(path)
- except FileNotFoundError:
- pass
+ return Image(name, path, (self if in_storage else None))
def get_space(self, fatal: bool) -> (StorageSpace | None):
try: