diff options
author | Narayan Desai <desai@mcs.anl.gov> | 2007-12-29 04:57:53 +0000 |
---|---|---|
committer | Narayan Desai <desai@mcs.anl.gov> | 2007-12-29 04:57:53 +0000 |
commit | 3610288cbcbf4d1adedefa03166cd77ee15aad96 (patch) | |
tree | 1588fb78ae1c6e51e4e4ea2dab46a006a3ece0d3 /src/lib/Server/Admin/__init__.py | |
parent | 6bf7875bc299a1f81061782c8646c90972e06e5a (diff) | |
download | bcfg2-3610288cbcbf4d1adedefa03166cd77ee15aad96.tar.gz bcfg2-3610288cbcbf4d1adedefa03166cd77ee15aad96.tar.bz2 bcfg2-3610288cbcbf4d1adedefa03166cd77ee15aad96.zip |
Refactor of bcfg2-admin (all modes moved to discrete modules in Bcfg2.Server.Admin
git-svn-id: https://svn.mcs.anl.gov/repos/bcfg/trunk/bcfg2@4125 ce84e21b-d406-0410-9b95-82705330c041
Diffstat (limited to 'src/lib/Server/Admin/__init__.py')
-rw-r--r-- | src/lib/Server/Admin/__init__.py | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/src/lib/Server/Admin/__init__.py b/src/lib/Server/Admin/__init__.py new file mode 100644 index 000000000..d059e0a1d --- /dev/null +++ b/src/lib/Server/Admin/__init__.py @@ -0,0 +1,45 @@ +__revision__ = '$Revision: $' + +__all__ = ['Mode', 'Client', 'Compare', 'Fingerprint', 'Init', 'Minestruct', + 'Pull', 'Tidy', 'Viz'] + +import ConfigParser, lxml.etree, logging + +class Mode(object): + '''Help message has not yet been added for mode''' + __shorthelp__ = 'Shorthelp not defined yet' + __longhelp__ = 'Longhelp not defined yet' + __args__ = [] + def __init__(self, configfile): + self.configfile = configfile + self.__cfp = False + self.log = logging.getLogger('Bcfg2.Server.Admin.Mode') + + def getCFP(self): + if not self.__cfp: + self.__cfp = ConfigParser.ConfigParser() + self.__cfp.read(self.configfile) + return self.__cfp + + cfp = property(getCFP) + + def __call__(self, args): + if args[0] == 'help': + print self.__longhelp__ + raise SystemExit(0) + + def errExit(self, emsg): + print emsg + raise SystemExit(1) + + def get_repo_path(self): + '''return repository path''' + return self.cfp.get('server', 'repository') + + def load_stats(self, client): + stats = lxml.etree.parse("%s/etc/statistics.xml" % (self.get_repo_path())) + hostent = stats.xpath('//Node[@name="%s"]' % client) + if not hostent: + self.errExit("Could not find stats for client %s" % (client)) + return hostent[0] + |