summaryrefslogtreecommitdiff
path: root/kvmd/apps/otgnet/netctl.py
diff options
context:
space:
mode:
authorDevaev Maxim <[email protected]>2020-10-10 16:06:06 +0300
committerDevaev Maxim <[email protected]>2020-10-10 16:06:06 +0300
commitf6ea1eda45346b248910f4b032666d583b6c4386 (patch)
tree6408ea1b64be4dc1daf7404d8c5ed82be79cc711 /kvmd/apps/otgnet/netctl.py
parent69509349bde314e89101f1825dfda9292fb5acb7 (diff)
kvmd-otgnet
Diffstat (limited to 'kvmd/apps/otgnet/netctl.py')
-rw-r--r--kvmd/apps/otgnet/netctl.py92
1 files changed, 92 insertions, 0 deletions
diff --git a/kvmd/apps/otgnet/netctl.py b/kvmd/apps/otgnet/netctl.py
new file mode 100644
index 00000000..874e904a
--- /dev/null
+++ b/kvmd/apps/otgnet/netctl.py
@@ -0,0 +1,92 @@
+# ========================================================================== #
+# #
+# KVMD - The main Pi-KVM daemon. #
+# #
+# Copyright (C) 2018 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 typing import Dict
+
+
+# =====
+class BaseCtl:
+ def get_command(self, direct: bool) -> List[str]:
+ raise NotImplementedError
+
+
+class IfaceUpCtl(BaseCtl):
+ def __init__(self, base_cmd: List[str], iface: str) -> None:
+ self.__base_cmd = base_cmd
+ self.__iface = iface
+
+ def get_command(self, direct: bool) -> List[str]:
+ return [*self.__base_cmd, "link", "set", self.__iface, ("up" if direct else "down")]
+
+
+class IfaceAddIpCtl(BaseCtl):
+ def __init__(self, base_cmd: List[str], iface: str, cidr: str) -> None:
+ self.__base_cmd = base_cmd
+ self.__iface = iface
+ self.__cidr = cidr
+
+ def get_command(self, direct: bool) -> List[str]:
+ return [*self.__base_cmd, "address", ("add" if direct else "del"), self.__cidr, "dev", self.__iface]
+
+
+class IptablesDropAllCtl(BaseCtl):
+ def __init__(self, base_cmd: List[str], iface: str) -> None:
+ self.__base_cmd = base_cmd
+ self.__iface = iface
+
+ def get_command(self, direct: bool) -> List[str]:
+ return [*self.__base_cmd, ("-A" if direct else "-D"), "INPUT", "-i", self.__iface, "-j", "DROP"]
+
+
+class IptablesAllowPortCtl(BaseCtl):
+ def __init__(self, base_cmd: List[str], iface: str, port: int, tcp: bool) -> None:
+ self.__base_cmd = base_cmd
+ self.__iface = iface
+ self.__port = port
+ self.__proto = ("tcp" if tcp else "udp")
+
+ def get_command(self, direct: bool) -> List[str]:
+ return [
+ *self.__base_cmd,
+ ("-A" if direct else "-D"), "INPUT", "-i", self.__iface, "-p", self.__proto,
+ "--dport", str(self.__port), "-j", "ACCEPT",
+ ]
+
+
+class CustomCtl(BaseCtl):
+ def __init__(
+ self,
+ direct_cmd: List[str],
+ reverse_cmd: List[str],
+ placeholders: Dict[str, str],
+ ) -> None:
+
+ self.__direct_cmd = direct_cmd
+ self.__reverse_cmd = reverse_cmd
+ self.__placeholders = placeholders
+
+ def get_command(self, direct: bool) -> List[str]:
+ return [
+ part.format(**self.__placeholders)
+ for part in (self.__direct_cmd if direct else self.__reverse_cmd)
+ ]