From a0e67509e2d4c4b133ae6ff9c3f707ed46b96981 Mon Sep 17 00:00:00 2001 From: Narayan Desai Date: Wed, 7 Sep 2005 17:35:15 +0000 Subject: switch to new plugin API }(Logical change 1.300) git-svn-id: https://svn.mcs.anl.gov/repos/bcfg/trunk/bcfg2@1215 ce84e21b-d406-0410-9b95-82705330c041 --- src/lib/Server/Structures/Base.py | 59 --------------------------------------- 1 file changed, 59 deletions(-) delete mode 100644 src/lib/Server/Structures/Base.py (limited to 'src/lib/Server/Structures/Base.py') diff --git a/src/lib/Server/Structures/Base.py b/src/lib/Server/Structures/Base.py deleted file mode 100644 index b2c6be92a..000000000 --- a/src/lib/Server/Structures/Base.py +++ /dev/null @@ -1,59 +0,0 @@ -'''This module sets up a base list of configuration entries''' -__revision__ = '$Revision$' - -from copy import deepcopy -from syslog import syslog, LOG_ERR -from Bcfg2.Server.Generator import SingleXMLFileBacked -from Bcfg2.Server.Structure import Structure - -from elementtree.ElementTree import Element, XML -from xml.parsers.expat import ExpatError - -class BaseFile(SingleXMLFileBacked): - '''The Base file contains unstructured/independent configuration elements''' - - def Index(self): - '''Store XML data in reasonable structures''' - self.store = {'Class':{'all':[]}, 'Image':{'all':[]}, 'all':[]} - try: - xdata = XML(self.data) - except ExpatError: - syslog(LOG_ERR, "Failed to parse base.xml") - return - for entry in xdata.getchildren(): - self.store[entry.tag][entry.get('name')] = {'all':[], 'Class':{}, 'Image':{}} - if entry.tag in ['Image', 'Class']: - for child in entry.getchildren(): - if child.tag in ['Image', 'Class']: - self.store[entry.tag][entry.get('name')][child.tag][child.get('name')] = child.getchildren() - else: - self.store[entry.tag][entry.get('name')]['all'].append(child) - else: - self.store[entry.tag]['all'].append(child) - - def Construct(self, metadata): - '''Build structures for client described by metadata''' - ret = Element("Independant", version='2.0') - idata = self.store['Image'].get(metadata.image, {'all':[], 'Class':{}}) - for entry in idata['all']: - ret.append(deepcopy(entry)) - for cls in metadata.classes: - for entry in idata['Class'].get(cls, []): - ret.append(deepcopy(entry)) - cdata = self.store['Class'].get(cls, {'all':[], 'Image':{}}) - for entry in cdata['all']: - ret.append(deepcopy(entry)) - for entry in cdata['Image'].get(metadata.image, []): - ret.append(deepcopy(entry)) - return [ret] - -class Base(Structure): - '''This Structure is good for the pile of independent configs needed for most actual systems''' - __name__ = 'Base' - __version__ = '$Id$' - - '''base creates independent clauses based on client metadata''' - def __init__(self, core, datastore): - Structure.__init__(self, core, datastore) - self.base = BaseFile("%s/etc/base.xml"%(datastore), self.core.fam) - self.Construct = self.base.Construct -- cgit v1.2.3-1-g7c22