diff options
author | Chris St. Pierre <chris.a.st.pierre@gmail.com> | 2011-06-15 14:46:32 -0400 |
---|---|---|
committer | Chris St. Pierre <chris.a.st.pierre@gmail.com> | 2011-06-15 14:46:32 -0400 |
commit | bf5541fb963bfa01e0d9bdf03e80cf2d2a77bfd5 (patch) | |
tree | 2807a890c9fd5c7d3d0610943eaf856cfe2c5422 /src/lib/Server/Plugins | |
parent | 0366ab745df68660f5966c7fb901766bc2c2d4d4 (diff) | |
parent | eec6ed6c3295755d00abdd40d82b6cfd0a023c2e (diff) | |
download | bcfg2-bf5541fb963bfa01e0d9bdf03e80cf2d2a77bfd5.tar.gz bcfg2-bf5541fb963bfa01e0d9bdf03e80cf2d2a77bfd5.tar.bz2 bcfg2-bf5541fb963bfa01e0d9bdf03e80cf2d2a77bfd5.zip |
Merge branch 'work'
Diffstat (limited to 'src/lib/Server/Plugins')
-rw-r--r-- | src/lib/Server/Plugins/Properties.py | 39 |
1 files changed, 1 insertions, 38 deletions
diff --git a/src/lib/Server/Plugins/Properties.py b/src/lib/Server/Plugins/Properties.py index dea797a10..54c5def57 100644 --- a/src/lib/Server/Plugins/Properties.py +++ b/src/lib/Server/Plugins/Properties.py @@ -6,44 +6,7 @@ import Bcfg2.Server.Plugin class PropertyFile(Bcfg2.Server.Plugin.StructFile): """Class for properties files.""" - def Index(self): - """Build internal data structures.""" - if type(self.data) is not lxml.etree._Element: - try: - self.data = lxml.etree.XML(self.data) - except lxml.etree.XMLSyntaxError: - Bcfg2.Server.Plugin.logger.error("Failed to parse %s" % - self.name) - - self.fragments = {} - work = {lambda x: True: self.data.getchildren()} - while work: - (predicate, worklist) = work.popitem() - self.fragments[predicate] = \ - [item for item in worklist - if (item.tag != 'Group' and - item.tag != 'Client' and - not isinstance(item, - lxml.etree._Comment))] - for item in worklist: - cmd = None - if item.tag == 'Group': - if item.get('negate', 'false').lower() == 'true': - cmd = "lambda x:'%s' not in x.groups and predicate(x)" - else: - cmd = "lambda x:'%s' in x.groups and predicate(x)" - elif item.tag == 'Client': - if item.get('negate', 'false').lower() == 'true': - cmd = "lambda x:x.hostname != '%s' and predicate(x)" - else: - cmd = "lambda x:x.hostname == '%s' and predicate(x)" - # else, ignore item - if cmd is not None: - newpred = eval(cmd % item.get('name'), - {'predicate':predicate}) - work[newpred] = item.getchildren() - - + pass class PropDirectoryBacked(Bcfg2.Server.Plugin.DirectoryBacked): __child__ = PropertyFile |