From 26f2687927ed180c82ed0d60ce5fb8fa90be65d0 Mon Sep 17 00:00:00 2001 From: Narayan Desai Date: Wed, 8 Oct 2008 20:22:41 +0000 Subject: Implement the balance of decision mode support (tested and working) git-svn-id: https://svn.mcs.anl.gov/repos/bcfg/trunk/bcfg2@4933 ce84e21b-d406-0410-9b95-82705330c041 --- src/lib/Server/Core.py | 10 ++++++++ src/lib/Server/Plugins/Decisions.py | 51 +++++++++++++++++++++++++++++++++++++ src/lib/Server/Plugins/__init__.py | 2 +- 3 files changed, 62 insertions(+), 1 deletion(-) create mode 100644 src/lib/Server/Plugins/Decisions.py (limited to 'src/lib/Server') diff --git a/src/lib/Server/Core.py b/src/lib/Server/Core.py index b29c9bf05..e6d71c3bd 100644 --- a/src/lib/Server/Core.py +++ b/src/lib/Server/Core.py @@ -234,3 +234,13 @@ class Core(object): logger.error('''Ran command "svn info %s"''' % (self.datastore)) logger.error("Got output: %s" % data) self.svn = False + + def GetDecisions(self, metadata, mode): + result = [] + for plugin in self.plugins.values(): + try: + if isinstance(plugin, Bcfg2.Server.Plugin.DecisionPlugin): + result += plugin.GetDecisions(metadata, mode) + except: + logger.error("Plugin: %s failed to generate decision list" % plugin.__name__, exc_info=1) + return result diff --git a/src/lib/Server/Plugins/Decisions.py b/src/lib/Server/Plugins/Decisions.py new file mode 100644 index 000000000..4b758cdd4 --- /dev/null +++ b/src/lib/Server/Plugins/Decisions.py @@ -0,0 +1,51 @@ +import Bcfg2.Server.Plugin, lxml.etree + +class DecisionFile(Bcfg2.Server.Plugin.SpecificData): + def handle_event(self, event): + Bcfg2.Server.Plugin.SpecificData.handle_event(self, event) + self.contents = lxml.etree.XML(self.data) + + def get_decisions(self): + return [(x.get('type'), x.get('name')) for x in self.contents.xpath('.//Decision')] + +class DecisionSet(Bcfg2.Server.Plugin.EntrySet): + def __init__(self, path, fam, encoding): + """Container for decision specification files + + Arguments: + - `path`: repository path + - `fam`: reference to the file monitor + - `encoding`: XML character encoding + """ + pattern = '(white|black)list' + Bcfg2.Server.Plugin.EntrySet.__init__(self, pattern, path, False, \ + DecisionFile, encoding) + fam.AddMonitor(path, self) + + def HandleEvent(self, event): + if event.filename != self.path: + return self.handle_event(event) + + def GetDecisions(self, metadata, mode): + ret = [] + candidates = [c for c in self.get_matching(metadata) + if c.name.split('/')[-1].startswith(mode)] + for c in candidates: + ret += c.get_decisions() + return ret + +class Decisions(DecisionSet, Bcfg2.Server.Plugin.DecisionPlugin): + __name__ = 'Decisions' + __version__ = '$Id: $' + __author__ = 'bcfg-dev@mcs.anl.gov' + + def __init__(self, core, datastore): + """Decisions plugins + + Arguments: + - `core`: Bcfg2.Core instance + - `datastore`: File repository location + """ + Bcfg2.Server.Plugin.DecisionPlugin.__init__(self, core, datastore) + DecisionSet.__init__(self, self.data, core.fam, core.encoding) + diff --git a/src/lib/Server/Plugins/__init__.py b/src/lib/Server/Plugins/__init__.py index 9707fbfeb..f80fa1b11 100644 --- a/src/lib/Server/Plugins/__init__.py +++ b/src/lib/Server/Plugins/__init__.py @@ -1,6 +1,6 @@ '''imports for Bcfg2.Server.Plugins''' __revision__ = '$Revision$' -__all__ = ['Account', 'Base', 'Bundler', 'Cfg', 'Hostbase', 'Metadata', 'NagiosGen', +__all__ = ['Account', 'Base', 'Bundler', 'Cfg', 'Decisions', 'Hostbase', 'Metadata', 'NagiosGen', 'Pkgmgr', 'Rules', 'SSHbase', 'Statistics', 'Svcmgr', 'TCheetah', 'SGenshi', 'TGenshi', 'Vhost'] -- cgit v1.2.3-1-g7c22