X-Git-Url: https://git.llucax.com/software/pymin.git/blobdiff_plain/d46203541c7463746edf19344d3ddbd1fb412128..45d91d1b75b9aed9abbbae97ff962ab08f215177:/config.py?ds=sidebyside diff --git a/config.py b/config.py index 2addc68..a0b5498 100644 --- a/config.py +++ b/config.py @@ -1,21 +1,72 @@ # vim: set et sts=4 sw=4 encoding=utf-8 : -from services import * -from dispatcher import handler +from pymin.services import * +from pymin.dispatcher import Handler +from os.path import join -# XXX for testing only -@handler -def test_func(*args): - print 'func:', args +base_path = join('var', 'lib', 'pymin') +pickle_path = join(base_path, 'pickle') +# FIXME, this should be specific for each service +config_path = join(base_path, 'config') + +class Root(Handler): + + def __init__(self): + f = file("/proc/sys/net/ipv4/ip_forward","w") + f.write("1") + f.close() + #self.ip.device_up_hook(self.dns) + + firewall = FirewallHandler( + pickle_dir = join(pickle_path, 'firewall'), + config_dir = join(config_path, 'firewall')) + + nat = NatHandler(pickle_dir = join(pickle_path, 'nat')) + + ppp = PppHandler( + pickle_dir = join(pickle_path, 'ppp'), + config_dir = { + 'pap-secrets': join(config_path, 'ppp'), + 'chap-secrets': join(config_path, 'ppp'), + 'options.X': join(config_path, 'ppp'), + 'nameX': join(config_path, 'ppp', 'peers'), + }) + + vpn = VpnHandler( + pickle_dir = join(pickle_path, 'vpn'), + config_dir = join(config_path, 'vpn')) + + ip = IpHandler( + pickle_dir = join(pickle_path, 'ip'), + config_dir = join(config_path, 'ip')) + + dns = DnsHandler( + pickle_dir = join(pickle_path, 'dns'), + config_dir = { + 'named.conf': join(config_path, 'dns'), + 'zoneX.zone': join(config_path, 'dns', 'zones'), + }) -routes = dict \ -( - test = test_func, dhcp = DhcpHandler( - pickle_dir = 'var/lib/pymin/pickle/dhcp', - config_dir = 'var/lib/pymin/config/dhcp', - ), -) + pickle_dir = join(pickle_path, 'dhcp'), + config_dir = join(config_path, 'dhcp')) + + proxy = ProxyHandler( + pickle_dir = join(pickle_path, 'proxy'), + config_dir = join(config_path, 'proxy')) + + vrrp = VrrpHandler( + pickle_dir = join(pickle_path, 'vrrp'), + config_dir = join(config_path, 'vrrp'), + pid_dir = join(config_path, 'vrrp', 'run')) + + vpn = VpnHandler( + pickle_dir = join(pickle_path, 'vpn'), + config_dir = join(config_path, 'vpn')) + + #qos = QoSHandler( + # pickle_dir = join(pickle_path, 'qos'), + # config_dir = join(config_path, 'qos')) bind_addr = \ (