From: Nicolas Emiliani Date: Wed, 10 Oct 2007 18:31:07 +0000 (-0300) Subject: Merge or3st3s@azazel:/home/luca/repos/pymin X-Git-Url: https://git.llucax.com/software/pymin.git/commitdiff_plain/b1c83f0151bd8a0de3d56778c64e2de368e64e58?hp=b386d5537adb61f101a6fc82ca01e13de5b7b15f Merge or3st3s@azazel:/home/luca/repos/pymin --- diff --git a/config.py b/config.py index ca0cc65..9f2d257 100644 --- a/config.py +++ b/config.py @@ -25,6 +25,9 @@ class Root(Handler): 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')) bind_addr = \ ( diff --git a/pymin/services/__init__.py b/pymin/services/__init__.py index a9f8d03..1d1ab1c 100644 --- a/pymin/services/__init__.py +++ b/pymin/services/__init__.py @@ -5,4 +5,5 @@ from pymin.services.dns import DnsHandler from pymin.services.firewall import FirewallHandler from pymin.services.ip import IpHandler from pymin.services.proxy import ProxyHandler +from pymin.services.vrrp import VrrpHandler diff --git a/pymin/services/vrrp/__init__.py b/pymin/services/vrrp/__init__.py new file mode 100644 index 0000000..8f5a003 --- /dev/null +++ b/pymin/services/vrrp/__init__.py @@ -0,0 +1,59 @@ +# vim: set encoding=utf-8 et sw=4 sts=4 : + +from os import path +from subprocess import Popen, PIPE + +from pymin.seqtools import Sequence +from pymin.dispatcher import Handler, handler, HandlerError +from pymin.services.util import Restorable, TransactionalHandler, ParametersHandler, call + +__ALL__ = ('VrrpHandler') + +pid_filename = 'vrrp.pid' + +class VrrpHandler(Restorable, ParametersHandler, TransactionalHandler): + handler_help = u"Manage VRRP service" + + _persistent_attrs = 'params' + + _restorable_defaults = dict( + params = dict( ipaddress='192.168.0.1', + id = '1', + prio = '', + dev = 'eth0', + ), + ) + + def __init__(self, pickle_dir='.', config_dir='.', pid_dir='.'): + self._persistent_dir = pickle_dir + self._pid_dir = pid_dir + self._restore() + + @handler('Starts the service') + def start(self): + if self.params['prio'] != '': + #call(('vrrp','-i',self.params[dev],'-v',self.params[id],'-p',self.params[prio],self.params[ipaddress])) + print ('vrrp','-i',self.params['dev'],'-v',self.params['id'],'-p',self.params['prio'],self.params['ipaddress']) + else: + #call(('vrrp','-i',self.params[dev],'-v',self.params[id],self.params[ipaddress])) + print ('vrrp','-i',self.params['dev'],'-v',self.params['id'],self.params['ipaddress']) + + @handler('Stop the service') + def stop(self): + try : + f = file(path.join(self._pid_dir, pid_filename ), 'r') + #call(('kill','<',f.read())) + print(('kill','<',f.read())) + except IOError: + pass + + @handler('Reloads the service') + def reload(self): + self.stop() + self.start() + + +if __name__ == '__main__': + v = VrrpHandler() + v.set('prio','10') + v.commit() \ No newline at end of file