summaryrefslogtreecommitdiff
path: root/kvmd/plugins/msd/otg/helpers.py
blob: 20ad572e4c1e0a187dc91e449356d2164f19b39c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
# ========================================================================== #
#                                                                            #
#    KVMD - The main PiKVM daemon.                                           #
#                                                                            #
#    Copyright (C) 2018-2021  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/>.  #
#                                                                            #
# ========================================================================== #


from typing import List

from ....logging import get_logger

from .... import aioproc

from .. import MsdError


# =====
async def remount_storage(base_cmd: List[str], rw: bool) -> None:
    logger = get_logger(0)
    mode = ("rw" if rw else "ro")
    cmd = [
        part.format(mode=mode)
        for part in base_cmd
    ]
    logger.info("Remounting internal storage to %s ...", mode.upper())
    try:
        await _run_helper(cmd)
    except Exception:
        logger.error("Can't remount internal storage")
        raise


async def unlock_drive(base_cmd: List[str]) -> None:
    logger = get_logger(0)
    logger.info("Unlocking the drive ...")
    try:
        await _run_helper(base_cmd)
    except Exception:
        logger.error("Can't unlock the drive")
        raise


# =====
async def _run_helper(cmd: List[str]) -> None:
    logger = get_logger(0)
    logger.info("Executing helper %s ...", cmd)
    proc = await aioproc.log_process(cmd, logger)
    if proc.returncode != 0:
        raise MsdError(f"Error while helper execution: pid={proc.pid}; retcode={proc.returncode}")