summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/lib/Server/Core.py5
-rw-r--r--src/lib/Server/Plugins/Metadata.py7
2 files changed, 9 insertions, 3 deletions
diff --git a/src/lib/Server/Core.py b/src/lib/Server/Core.py
index 6bdf2c930..6a6264e9a 100644
--- a/src/lib/Server/Core.py
+++ b/src/lib/Server/Core.py
@@ -241,7 +241,10 @@ class Core(object):
except:
logger.error("Unexpected instantiation failure for plugin %s" % (plugin), exc_info=1)
- self.metadata = self.plugins['Metadata']
+ if 'Metadata' in self.plugins:
+ self.metadata = self.plugins['Metadata']
+ else:
+ raise CoreInitError, "No Metadata plugin loaded"
for plugin in structures:
if self.plugins.has_key(plugin):
self.structures.append(self.plugins[plugin])
diff --git a/src/lib/Server/Plugins/Metadata.py b/src/lib/Server/Plugins/Metadata.py
index 851c3bc51..15e4177e8 100644
--- a/src/lib/Server/Plugins/Metadata.py
+++ b/src/lib/Server/Plugins/Metadata.py
@@ -66,8 +66,11 @@ class Metadata(Bcfg2.Server.Plugin.Plugin):
def __init__(self, core, datastore):
Bcfg2.Server.Plugin.Plugin.__init__(self, core, datastore)
self.__name__ = 'Metadata'
- core.fam.AddMonitor("%s/%s" % (self.data, "groups.xml"), self)
- core.fam.AddMonitor("%s/%s" % (self.data, "clients.xml"), self)
+ try:
+ core.fam.AddMonitor("%s/%s" % (self.data, "groups.xml"), self)
+ core.fam.AddMonitor("%s/%s" % (self.data, "clients.xml"), self)
+ except:
+ raise Bcfg2.Server.Plugin.PluginInitError
self.states = {'groups.xml':False, 'clients.xml':False}
self.addresses = {}
self.clients = {}