2020-01-23 00:54:45 +00:00
|
|
|
from typing import Any, Dict
|
|
|
|
|
2020-01-17 21:47:55 +00:00
|
|
|
from core.configservice.base import ConfigService, ConfigServiceMode
|
|
|
|
|
|
|
|
GROUP_NAME = "Security"
|
|
|
|
|
|
|
|
|
|
|
|
class VpnClient(ConfigService):
|
|
|
|
name = "VPNClient"
|
|
|
|
group = GROUP_NAME
|
|
|
|
directories = []
|
2020-01-20 23:02:04 +00:00
|
|
|
files = ["vpnclient.sh"]
|
2020-01-17 21:47:55 +00:00
|
|
|
executables = ["openvpn", "ip", "killall"]
|
|
|
|
dependencies = []
|
|
|
|
startup = ["sh vpnclient.sh"]
|
|
|
|
validate = ["pidof openvpn"]
|
|
|
|
shutdown = ["killall openvpn"]
|
|
|
|
validation_mode = ConfigServiceMode.BLOCKING
|
|
|
|
default_configs = []
|
2020-01-21 22:00:55 +00:00
|
|
|
modes = {}
|
2020-01-23 00:54:45 +00:00
|
|
|
|
|
|
|
|
|
|
|
class VPNServer(ConfigService):
|
|
|
|
name = "VPNServer"
|
|
|
|
group = GROUP_NAME
|
|
|
|
directories = []
|
|
|
|
files = ["vpnserver.sh"]
|
|
|
|
executables = ["openvpn", "ip", "killall"]
|
|
|
|
dependencies = []
|
|
|
|
startup = ["sh vpnserver.sh"]
|
|
|
|
validate = ["pidof openvpn"]
|
|
|
|
shutdown = ["killall openvpn"]
|
|
|
|
validation_mode = ConfigServiceMode.BLOCKING
|
|
|
|
default_configs = []
|
|
|
|
modes = {}
|
|
|
|
|
|
|
|
|
|
|
|
class IPsec(ConfigService):
|
|
|
|
name = "IPsec"
|
|
|
|
group = GROUP_NAME
|
|
|
|
directories = []
|
|
|
|
files = ["ipsec.sh"]
|
|
|
|
executables = ["racoon", "ip", "setkey", "killall"]
|
|
|
|
dependencies = []
|
|
|
|
startup = ["sh ipsec.sh"]
|
|
|
|
validate = ["pidof racoon"]
|
|
|
|
shutdown = ["killall racoon"]
|
|
|
|
validation_mode = ConfigServiceMode.BLOCKING
|
|
|
|
default_configs = []
|
|
|
|
modes = {}
|
|
|
|
|
|
|
|
|
|
|
|
class Firewall(ConfigService):
|
|
|
|
name = "Firewall"
|
|
|
|
group = GROUP_NAME
|
|
|
|
directories = []
|
|
|
|
files = ["firewall.sh"]
|
|
|
|
executables = ["iptables"]
|
|
|
|
dependencies = []
|
|
|
|
startup = ["sh firewall.sh"]
|
|
|
|
validate = []
|
|
|
|
shutdown = []
|
|
|
|
validation_mode = ConfigServiceMode.BLOCKING
|
|
|
|
default_configs = []
|
|
|
|
modes = {}
|
|
|
|
|
|
|
|
|
|
|
|
class Nat(ConfigService):
|
|
|
|
name = "NAT"
|
|
|
|
group = GROUP_NAME
|
|
|
|
directories = []
|
|
|
|
files = ["nat.sh"]
|
|
|
|
executables = ["iptables"]
|
|
|
|
dependencies = []
|
|
|
|
startup = ["sh nat.sh"]
|
|
|
|
validate = []
|
|
|
|
shutdown = []
|
|
|
|
validation_mode = ConfigServiceMode.BLOCKING
|
|
|
|
default_configs = []
|
|
|
|
modes = {}
|
|
|
|
|
|
|
|
def data(self) -> Dict[str, Any]:
|
|
|
|
ifnames = []
|
|
|
|
for ifc in self.node.netifs():
|
2020-01-23 19:27:05 +00:00
|
|
|
if getattr(ifc, "control", False):
|
2020-01-23 00:54:45 +00:00
|
|
|
continue
|
|
|
|
ifnames.append(ifc.name)
|
|
|
|
return dict(ifnames=ifnames)
|