diff options
author | Maxim Devaev <[email protected]> | 2022-11-07 03:23:06 +0300 |
---|---|---|
committer | Maxim Devaev <[email protected]> | 2022-11-07 03:23:06 +0300 |
commit | 53f8b052de48843ece433362ba66633c8b16b7f6 (patch) | |
tree | 1d3ced9fd2f44bbb91c1604478eacd7bace1e6f5 | |
parent | 648316931a8c5204945a5100a5530c15f7515a23 (diff) |
common fstab and libc funcs
-rw-r--r-- | kvmd/fstab.py | 50 | ||||
-rw-r--r-- | kvmd/helpers/remount/__init__.py | 38 | ||||
-rw-r--r-- | kvmd/helpers/swapfiles/__init__.py | 16 | ||||
-rw-r--r-- | kvmd/inotify.py | 3 | ||||
-rw-r--r-- | kvmd/libc.py | 5 | ||||
-rw-r--r-- | kvmd/plugins/msd/otg/__init__.py | 8 |
6 files changed, 64 insertions, 56 deletions
diff --git a/kvmd/fstab.py b/kvmd/fstab.py new file mode 100644 index 00000000..b8c26e68 --- /dev/null +++ b/kvmd/fstab.py @@ -0,0 +1,50 @@ +# ========================================================================== # +# # +# KVMD - The main PiKVM daemon. # +# # +# Copyright (C) 2018-2022 Maxim Devaev <[email protected]> # +# # +# This program is free software: you can redistribute it and/or modify # +# it under the terms of the GNU General Public License as published by # +# the Free Software Foundation, either version 3 of the License, or # +# (at your option) any later version. # +# # +# This program is distributed in the hope that it will be useful, # +# but WITHOUT ANY WARRANTY; without even the implied warranty of # +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # +# GNU General Public License for more details. # +# # +# You should have received a copy of the GNU General Public License # +# along with this program. If not, see <https://www.gnu.org/licenses/>. # +# # +# ========================================================================== # + + +import re +import dataclasses + + +# ===== [email protected](frozen=True) +class FstabStorage: + mount_path: str + root_path: str + user: str + + +def find_storage(target: str) -> FstabStorage: + fstab_path = "/etc/fstab" + with open(fstab_path) as file: + for line in file.read().split("\n"): + line = line.strip() + if line and not line.startswith("#"): + parts = line.split() + if len(parts) == 6: + options = dict(re.findall(r"X-kvmd\.%s-(root|user)(?:=([^,]+))?" % (target), parts[3])) + if options: + return FstabStorage( + mount_path=parts[1], + root_path=(options.get("root", "") or parts[1]), + user=options.get("user", ""), + ) + raise RuntimeError(f"Can't find {target!r} mountpoint in {fstab_path}") diff --git a/kvmd/helpers/remount/__init__.py b/kvmd/helpers/remount/__init__.py index 80e683f5..acbbadd9 100644 --- a/kvmd/helpers/remount/__init__.py +++ b/kvmd/helpers/remount/__init__.py @@ -22,23 +22,10 @@ import sys import os -import re import shutil -import dataclasses import subprocess - -# ==== -_MOUNT_PATH = "/bin/mount" -_FSTAB_PATH = "/etc/fstab" - - -# ===== [email protected](frozen=True) -class _Storage: - mount_path: str - root_path: str - user: str +from ... import fstab # ===== @@ -46,29 +33,11 @@ def _log(msg: str) -> None: print(msg, file=sys.stderr) -def _find_storage(target: str) -> _Storage: - assert target - with open(_FSTAB_PATH) as fstab_file: - for line in fstab_file.read().split("\n"): - line = line.strip() - if line and not line.startswith("#"): - parts = line.split() - if len(parts) == 6: - options = dict(re.findall(r"X-kvmd\.%s-(root|user)(?:=([^,]+))?" % (target), parts[3])) - if options: - return _Storage( - mount_path=parts[1], - root_path=(options.get("root", "") or parts[1]), - user=options.get("user", ""), - ) - raise SystemExit(f"Can't find {target!r} mountpoint in {_FSTAB_PATH}") - - def _remount(path: str, rw: bool) -> None: mode = ("rw" if rw else "ro") _log(f"Remounting {path} to {mode.upper()}-mode ...") try: - subprocess.check_call([_MOUNT_PATH, "--options", f"remount,{mode}", path]) + subprocess.check_call(["/bin/mount", "--options", f"remount,{mode}", path]) except subprocess.CalledProcessError as err: raise SystemExit(f"Can't remount: {err}") @@ -109,7 +78,8 @@ def main() -> None: rw = (sys.argv[1] == "rw") - storage = _find_storage(target) + assert target + storage = fstab.find_storage(target) _remount(storage.mount_path, rw) if rw and storage.root_path: for name in dirs: diff --git a/kvmd/helpers/swapfiles/__init__.py b/kvmd/helpers/swapfiles/__init__.py index 3675d709..c0e271c4 100644 --- a/kvmd/helpers/swapfiles/__init__.py +++ b/kvmd/helpers/swapfiles/__init__.py @@ -22,12 +22,8 @@ import sys import os -import ctypes -import ctypes.util -from ctypes import c_int -from ctypes import c_uint -from ctypes import c_char_p +from ... import libc # ===== @@ -35,14 +31,6 @@ def main() -> None: if len(sys.argv) != 3: raise SystemExit(f"Usage: {sys.argv[0]} <file1> <file2>") - path = ctypes.util.find_library("c") - if not path: - raise SystemExit("Where is libc?") - assert path - libc = ctypes.CDLL(path) - libc.renameat2.restype = c_int - libc.renameat2.argtypes = [c_int, c_char_p, c_int, c_char_p, c_uint] - result = libc.renameat2( -100, # AT_FDCWD os.fsencode(sys.argv[1]), @@ -52,4 +40,4 @@ def main() -> None: ) if result != 0: - raise SystemExit(f"{sys.argv[0]}: {os.strerror(ctypes.get_errno())}") + raise SystemExit(f"{sys.argv[0]}: {os.strerror(libc.get_errno())}") diff --git a/kvmd/inotify.py b/kvmd/inotify.py index 0511f088..d76e73e3 100644 --- a/kvmd/inotify.py +++ b/kvmd/inotify.py @@ -25,7 +25,6 @@ import sys import os import asyncio -import ctypes import struct import dataclasses import types @@ -64,7 +63,7 @@ def _inotify_parsed_buffer(data: bytes) -> Generator[tuple[int, int, int, bytes] def _inotify_check(retval: int) -> int: if retval < 0: - c_errno = ctypes.get_errno() + c_errno = libc.get_errno() if c_errno == errno.ENOSPC: # pylint: disable=no-else-raise raise OSError(c_errno, "Inotify watch limit reached") elif c_errno == errno.EMFILE: diff --git a/kvmd/libc.py b/kvmd/libc.py index 46e6278c..41cb61dd 100644 --- a/kvmd/libc.py +++ b/kvmd/libc.py @@ -26,6 +26,7 @@ import ctypes import ctypes.util from ctypes import c_int +from ctypes import c_uint from ctypes import c_uint32 from ctypes import c_char_p from ctypes import c_void_p @@ -42,6 +43,7 @@ def _load_libc() -> ctypes.CDLL: ("inotify_init", c_int, []), ("inotify_add_watch", c_int, [c_int, c_char_p, c_uint32]), ("inotify_rm_watch", c_int, [c_int, c_uint32]), + ("renameat2", c_int, [c_int, c_char_p, c_int, c_char_p, c_uint]), ("free", c_int, [c_void_p]), ]: func = getattr(lib, name) @@ -56,7 +58,10 @@ _libc = _load_libc() # ===== +get_errno = ctypes.get_errno + inotify_init = _libc.inotify_init inotify_add_watch = _libc.inotify_add_watch inotify_rm_watch = _libc.inotify_rm_watch +renameat2 = _libc.renameat2 free = _libc.free diff --git a/kvmd/plugins/msd/otg/__init__.py b/kvmd/plugins/msd/otg/__init__.py index 7347a733..fa6c1fe9 100644 --- a/kvmd/plugins/msd/otg/__init__.py +++ b/kvmd/plugins/msd/otg/__init__.py @@ -38,12 +38,12 @@ from ....yamlconf import Option from ....validators.basic import valid_bool from ....validators.basic import valid_number -from ....validators.os import valid_abs_dir from ....validators.os import valid_printable_filename from ....validators.os import valid_command from .... import aiotools from .... import aiohelpers +from .... import fstab from .. import MsdError from .. import MsdIsBusyError @@ -143,8 +143,6 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes write_chunk_size: int, sync_chunk_size: int, - storage_path: str, - remount_cmd: list[str], initial: dict, @@ -162,7 +160,7 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes self.__initial_cdrom: bool = initial["cdrom"] self.__drive = Drive(gadget, instance=0, lun=0) - self.__storage = Storage(storage_path) + self.__storage = Storage(fstab.find_storage("otgmsd").root_path) self.__reader: (MsdFileReader | None) = None self.__writer: (MsdFileWriter | None) = None @@ -181,8 +179,6 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes "write_chunk_size": Option(65536, type=functools.partial(valid_number, min=1024)), "sync_chunk_size": Option(4194304, type=functools.partial(valid_number, min=1024)), - "storage": Option("/var/lib/kvmd/msd", type=valid_abs_dir, unpack_as="storage_path"), - "remount_cmd": Option([ "/usr/bin/sudo", "--non-interactive", "/usr/bin/kvmd-helper-otgmsd-remount", "{mode}", |