summaryrefslogtreecommitdiffstats
path: root/module
diff options
context:
space:
mode:
Diffstat (limited to 'module')
-rw-r--r--module/HookManager.py19
-rw-r--r--module/XMLConfigParser.py7
-rw-r--r--module/config/core_default.xml1
-rw-r--r--module/config/gui_default.xml1
-rw-r--r--module/config/plugin_default.xml1
-rw-r--r--module/plugins/hooks/Hook.py8
6 files changed, 26 insertions, 11 deletions
diff --git a/module/HookManager.py b/module/HookManager.py
index a0caae728..d2196ec4f 100644
--- a/module/HookManager.py
+++ b/module/HookManager.py
@@ -24,9 +24,15 @@ from glob import glob
from threading import Lock
+from module.XMLConfigParser import XMLConfigParser
+
+
class HookManager():
def __init__(self, core):
self.core = core
+ self.configParser = XMLConfigParser(join("module","config","plugin.xml"))
+ self.configParser.loadData()
+ self.config = self.configParser.getConfig()
self.logger = logging.getLogger("log")
self.plugins = []
self.lock = Lock()
@@ -39,10 +45,17 @@ class HookManager():
for pluginFile in pluginFiles:
pluginName = basename(pluginFile).replace(".py", "")
if pluginName == "Hook" or pluginName == "__init__":
- continue
- module = __import__("module.plugins.hooks."+pluginName, globals(), locals(), [pluginName], -1)
+ continue
+ if pluginName in self.config.keys():
+ if not self.config[pluginName]["activated"]:
+ continue
+ else:
+ self.configParser.set(pluginName, {"option": "activated", "type": "bool", "name": "Activated"}, True)
+ module = __import__("module.plugins.hooks." + pluginName, globals(), locals(), [pluginName], -1)
pluginClass = getattr(module, pluginName)
- plugins.append(pluginClass(self.core))
+ pluginLoaded = pluginClass(self.core)
+ pluginLoaded.setup()
+ plugins.append(pluginLoaded)
self.logger.info("Installed Hook: %s" % pluginName)
self.plugins = plugins
diff --git a/module/XMLConfigParser.py b/module/XMLConfigParser.py
index 5f58c834b..678338b41 100644
--- a/module/XMLConfigParser.py
+++ b/module/XMLConfigParser.py
@@ -48,6 +48,7 @@ class XMLConfigParser():
if not self.xml.documentElement.getAttribute("version") == self.version:
print "Cant Update %s" % self.file
exit() #ok?
+ self.root = self.xml.documentElement
self._read_config()
def _copyConfig(self):
@@ -115,7 +116,6 @@ class XMLConfigParser():
if opt.nodeType == opt.ELEMENT_NODE:
if data["option"] == opt.tagName:
replace = opt
- self._setAttributes(node, data)
text = self.xml.createTextNode(str(value))
if replace:
replace.replaceChild(text, replace.firstChild)
@@ -128,13 +128,12 @@ class XMLConfigParser():
newSection = self.xml.createElement(section)
newSection.appendChild(newNode)
root.appendChild(newSection)
- self._setAttributes(newSection, data)
+ self._setAttributes(section, data)
self.saveData()
self.loadData()
def _setAttributes(self, node, data):
- node.setAttribute("name", node.tagName)
- option = node.getElementsByTagName(data["option"])[0]
+ option = self.root.getElementsByTagName(node)[0].getElementsByTagName(data["option"])[0]
option.setAttribute("name", data["name"])
option.setAttribute("type", data["type"])
try:
diff --git a/module/config/core_default.xml b/module/config/core_default.xml
index 07d4ddc1c..0d684890a 100644
--- a/module/config/core_default.xml
+++ b/module/config/core_default.xml
@@ -1,3 +1,4 @@
+<?xml version="1.0" ?>
<config name="Configuration" version="0.1">
<remote name="Remote">
<port type="int" name="Port">7227</port>
diff --git a/module/config/gui_default.xml b/module/config/gui_default.xml
index 9b6d75936..490af199e 100644
--- a/module/config/gui_default.xml
+++ b/module/config/gui_default.xml
@@ -1,3 +1,4 @@
+<?xml version="1.0" ?>
<root>
<connections>
<connection default="True" type="local" id="33965310e19b4a869112c43b39a16440">
diff --git a/module/config/plugin_default.xml b/module/config/plugin_default.xml
index 3f033fc04..773e4e46f 100644
--- a/module/config/plugin_default.xml
+++ b/module/config/plugin_default.xml
@@ -1,3 +1,4 @@
+<?xml version="1.0" ?>
<config name="Configuration" version="0.1">
<RapidshareCom>
<server input=";Cogent;Deutsche Telekom;Level(3);Level(3) #2;GlobalCrossing;Level(3) #3;Teleglobe;GlobalCrossing #2;TeliaSonera #2;Teleglobe #2;TeliaSonera #3;TeliaSonera"></server>
diff --git a/module/plugins/hooks/Hook.py b/module/plugins/hooks/Hook.py
index 739af3200..4b5f6751f 100644
--- a/module/plugins/hooks/Hook.py
+++ b/module/plugins/hooks/Hook.py
@@ -40,10 +40,10 @@ class Hook():
def readConfig(self):
self.configParser.loadData()
section = self.props['name']
- try:
- self.config = self.configParser.getConfig()[section]
- except:
- self.setup()
+ #~ try:
+ #~ self.config = self.configParser.getConfig()[section]
+ #~ except:
+ #~ self.setup()
def setup(self):
pass