diff options
Diffstat (limited to 'pyload/manager')
-rw-r--r-- | pyload/manager/PluginManager.py | 100 | ||||
-rw-r--r-- | pyload/manager/thread/InfoThread.py | 33 |
2 files changed, 79 insertions, 54 deletions
diff --git a/pyload/manager/PluginManager.py b/pyload/manager/PluginManager.py index 8f837587a..79c3d6be6 100644 --- a/pyload/manager/PluginManager.py +++ b/pyload/manager/PluginManager.py @@ -5,7 +5,7 @@ import sys from itertools import chain from os import listdir, makedirs -from os.path import isfile, join, exists, abspath +from os.path import isdir, isfile, join, exists, abspath from sys import version_info from traceback import print_exc @@ -15,7 +15,7 @@ from SafeEval import const_eval as literal_eval class PluginManager: ROOT = "pyload.plugins." USERROOT = "userplugins." - TYPES = ("account", "addon", "container", "crypter", "hook", "hoster", "internal", "ocr") + TYPES = [] PATTERN = re.compile(r'__pattern__\s*=\s*u?r("|\')([^"\']+)') VERSION = re.compile(r'__version__\s*=\s*("|\')([\d.]+)') @@ -33,11 +33,27 @@ class PluginManager: sys.meta_path.append(self) + def initTYPES(self): + rootdir = join(pypath, "pyload", "plugins") + userdir = "userplugins" + + tmpset = set() + for p in (rootdir, userdir): + tmpset += set([d for d in listdir(p) if isdir(join(p, d))]) + + self.TYPES = list(tmpset) + + def createIndex(self): """create information for all plugins available""" sys.path.append(abspath("")) + self.initTYPES() + + if not self.TYPES: + self.log.critical(_("No TYPES, no fun!")) + for type in set(self.TYPES): self.plugins[type] = self.parse(type) setattr(self, "%sPlugins" % type, self.plugins[type]) @@ -177,61 +193,70 @@ class PluginManager: """parse plugins for given list of urls""" last = None - res = [] # tupels of (url, plugin) + res = [] #: tupels of (url, plugintype, pluginname) for url in urls: - if type(url) not in (str, unicode, buffer): continue - found = False + if type(url) not in (str, unicode, buffer): + continue - if last and last[1]['re'].match(url): - res.append((url, last[0])) + if last and last[2]['re'].match(url): + res.append((url, last[0], last[1])) continue - for name, value in (self.crypterPlugins.iteritems(), - self.hosterPlugins.iteritems(), - self.containerPlugins.iteritems()): - try: - m = value['re'].match(url) - except KeyError: - self.core.log.error("Plugin %s skipped due broken pattern" % name) + for type in self.TYPES: + for name, plugin in self.plugins[type]: + m = None + try: + if 'pattern' in plugin: + m = plugin['re'].match(url) - if m: - res.append((url, name)) - last = (name, value) - found = True - break + except KeyError: + self.core.log.error(_("Plugin [%(type)s] %(name)s skipped due broken pattern") + % {'name': name, 'type': type}) - if not found: - res.append((url, "BasePlugin")) + if m: + res.append((url, type, name)) + last = (type, name, plugin) + break + else: + res.append((url, "internal", "BasePlugin")) return res - def findPlugin(self, name, pluginlist=("hoster", "crypter", "container")): - for ptype in pluginlist: - if name in self.plugins[ptype]: - return self.plugins[ptype][name], ptype - return None, None + def findPlugin(self, type, name): + if type not in self.plugins: + return None + + elif name not in self.plugins[type]: + self.core.log.warning(_("Plugin [%(type)s] %(name)s not found | Using plugin: [internal] BasePlugin") + % {'name': name, 'type': type}) + return self.internalPlugins["BasePlugin"] + + else: + return self.plugins[type][name] - def getPlugin(self, name, original=False): + def getPlugin(self, type, name, original=False): """return plugin module from hoster|decrypter|container""" - plugin, type = self.findPlugin(name) + plugin = self.findPlugin(type, name) - if not plugin: - self.core.log.warning("Plugin %s not found" % name) - plugin = self.internalPlugins['BasePlugin'] + if plugin is None: + return {} if "new_module" in plugin and not original: return plugin['new_module'] - - return self.loadModule(type, name) + else: + return self.loadModule(type, name) - def getPluginName(self, name): + def getPluginName(self, type, name): """ used to obtain new name if other plugin was injected""" - plugin, type = self.findPlugin(name) + plugin = self.findPlugin(type, name) + + if plugin is None: + return "" if "new_name" in plugin: return plugin['new_name'] @@ -246,6 +271,7 @@ class PluginManager: :param name: """ plugins = self.plugins[type] + if name in plugins: if "module" in plugins[name]: return plugins[name]['module'] @@ -256,7 +282,7 @@ class PluginManager: except Exception, e: self.core.log.error(_("Error importing plugin: [%(type)s] %(name)s (v%(version).2f) | %(errmsg)s") - % {'name': name, 'type': type, 'version': plugins[name]['version'], "errmsg": str(e)}) + % {'name': name, 'type': type, 'version': plugins[name]['version'], "errmsg": str(e)}) if self.core.debug: print_exc() @@ -264,7 +290,7 @@ class PluginManager: plugins[name]['module'] = module #: cache import, maybe unneeded self.core.log.debug(_("Loaded plugin: [%(type)s] %(name)s (v%(version).2f)") - % {'name': name, 'type': type, 'version': plugins[name]['version']}) + % {'name': name, 'type': type, 'version': plugins[name]['version']}) return module diff --git a/pyload/manager/thread/InfoThread.py b/pyload/manager/thread/InfoThread.py index 1916b4b36..1775e2a86 100644 --- a/pyload/manager/thread/InfoThread.py +++ b/pyload/manager/thread/InfoThread.py @@ -61,12 +61,11 @@ class InfoThread(PluginThread): plugins = {} container = [] - for url, plugin in self.data: - if plugin in plugins: - plugins[plugin].append(url) - else: - plugins[plugin] = [url] - + for url, plugintype, pluginname in data: + try: + plugins[plugintype][pluginname].append(url) + except: + plugins[plugintype][pluginname] = [url] # filter out container plugins for name in self.m.core.pluginManager.containerPlugins: @@ -77,15 +76,15 @@ class InfoThread(PluginThread): #directly write to database if self.pid > -1: - for pluginname, urls in plugins.iteritems(): - plugin = self.m.core.pluginManager.getPlugin(pluginname, True) + for plugintype, pluginname, urls in plugins.iteritems(): + plugin = self.m.core.pluginManager.getPlugin(plugintype, pluginname, True) if hasattr(plugin, "getInfo"): self.fetchForPlugin(pluginname, plugin, urls, self.updateDB) self.m.core.files.save() elif self.add: - for pluginname, urls in plugins.iteritems(): - plugin = self.m.core.pluginManager.getPlugin(pluginname, True) + for plugintype, pluginname, urls in plugins.iteritems(): + plugin = self.m.core.pluginManager.getPlugin(plugintype, pluginname, True) if hasattr(plugin, "getInfo"): self.fetchForPlugin(pluginname, plugin, urls, self.updateCache, True) @@ -117,16 +116,16 @@ class InfoThread(PluginThread): self.m.log.error("Could not decrypt container.") data = [] - for url, plugin in data: - if plugin in plugins: - plugins[plugin].append(url) - else: - plugins[plugin] = [url] + for url, plugintype, pluginname in data: + try: + plugins[plugintype][pluginname].append(url) + except: + plugins[plugintype][pluginname] = [url] self.m.infoResults[self.rid] = {} - for pluginname, urls in plugins.iteritems(): - plugin = self.m.core.pluginManager.getPlugin(pluginname, True) + for plugintype, pluginname, urls in plugins.iteritems(): + plugin = self.m.core.pluginManager.getPlugin(plugintype, pluginname, True) if hasattr(plugin, "getInfo"): self.fetchForPlugin(pluginname, plugin, urls, self.updateResult, True) |