diff options
author | Devaev Maxim <[email protected]> | 2019-10-24 01:21:34 +0300 |
---|---|---|
committer | Devaev Maxim <[email protected]> | 2019-10-24 01:21:34 +0300 |
commit | 97e2d9128c37805ba649807f5f923d1d1e92907f (patch) | |
tree | 36ddaa7318cea97edf55ef994052b14a28e36305 /kvmd/validators | |
parent | 372bf2a4afc93726ad63090202b517c939a183d9 (diff) |
strict file validation
Diffstat (limited to 'kvmd/validators')
-rw-r--r-- | kvmd/validators/os.py | 44 |
1 files changed, 34 insertions, 10 deletions
diff --git a/kvmd/validators/os.py b/kvmd/validators/os.py index d37ae5d4..3fcca5c1 100644 --- a/kvmd/validators/os.py +++ b/kvmd/validators/os.py @@ -21,6 +21,7 @@ import os +import stat from typing import List from typing import Any @@ -33,22 +34,45 @@ from .basic import valid_string_list # ===== -def valid_abs_path(arg: Any, exists: bool=False, name: str="") -> str: - if not name: - name = ("existent absolute path" if exists else "absolute path") +def valid_abs_path(arg: Any, type: str="", name: str="") -> str: # pylint: disable=redefined-builtin + if type: + if not name: + name = f"absolute path to existent {type}" + type = { + "file": "reg", + "dir": "dir", + "link": "lnk", + "sock": "sock", + "fifo": "fifo", + "char": "chr", + "block": "blk", + }[type] + else: + if not name: + name = "absolute path" if len(str(arg).strip()) == 0: arg = None - arg = check_not_none_string(arg, name) + arg = os.path.abspath(check_not_none_string(arg, name)) + + if type: + try: + st = os.stat(arg) + except Exception as err: + raise_error(arg, f"{name}: {err}") + else: + if not getattr(stat, f"S_IS{type.upper()}")(st.st_mode): + raise_error(arg, name) - arg = os.path.abspath(arg) - if exists and not os.access(arg, os.F_OK): - raise_error(arg, name) return arg -def valid_abs_path_exists(arg: Any, name: str="") -> str: - return valid_abs_path(arg, exists=True, name=name) +def valid_abs_file(arg: Any, name: str="") -> str: + return valid_abs_path(arg, type="file", name=name) + + +def valid_abs_dir(arg: Any, name: str="") -> str: + return valid_abs_path(arg, type="dir", name=name) def valid_printable_filename(arg: Any, name: str="") -> str: @@ -78,5 +102,5 @@ def valid_command(arg: Any) -> List[str]: cmd = valid_string_list(arg, delim=r"[,\t]+", name="command") if len(cmd) == 0: raise_error(arg, "command") - cmd[0] = valid_abs_path_exists(cmd[0], name="command entry point") + cmd[0] = valid_abs_file(cmd[0], name="command entry point") return cmd |