X-Git-Url: https://git.llucax.com/software/pymin.git/blobdiff_plain/026f5f3a6274709b7863c619c979dd32f0ee686f..c3862dc0f135a52327fbf9511c22392555e84f3f:/config.py diff --git a/config.py b/config.py index 93a6b7b..db3151b 100644 --- a/config.py +++ b/config.py @@ -1,13 +1,54 @@ # vim: set et sts=4 sw=4 encoding=utf-8 : -# XXX for testing only -def test_func(*args): - print 'func:', args +from pymin.services import * +from pymin.dispatcher import Handler +from os.path import join -routes = dict \ -( - test = test_func, -) +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): + + firewall = FirewallHandler( + pickle_dir = join(pickle_path, 'firewall'), + config_dir = '/tmp') + + nat = NatHandler(pickle_dir = join(pickle_path, 'nat')) + + ppp = PppHandler( + pickle_dir = join(pickle_path, 'ppp'), + config_dir = { + 'pap-secrets': '/etc/ppp', + 'chap-secrets': '/etc/ppp', + 'options.X': '/etc/ppp', + 'nameX': '/etc/ppp/peers', + }) + + 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': '/etc', + 'zoneX.zone': '/var/lib/named', + }) + + dhcp = DhcpHandler( + pickle_dir = join(pickle_path, 'dhcp'), + config_dir = '/etc') + + proxy = ProxyHandler( + pickle_dir = join(pickle_path, 'proxy'), + config_dir = '/etc/squid') + + vrrp = VrrpHandler( + pickle_dir = join(pickle_path, 'vrrp'), + config_dir = join(config_path, 'vrrp'), + pid_dir = '/var/run') bind_addr = \ (