diff options
author | RaNaN <Mast3rRaNaN@hotmail.de> | 2010-08-29 17:58:16 +0200 |
---|---|---|
committer | RaNaN <Mast3rRaNaN@hotmail.de> | 2010-08-29 17:58:16 +0200 |
commit | ebff9ca1fbcc40ecb81b2051f68e179e505b47df (patch) | |
tree | 698ba545b9806be1547440f06cdb0baec09a417f /module/plugins | |
parent | some fixes (diff) | |
download | pyload-ebff9ca1fbcc40ecb81b2051f68e179e505b47df.tar.xz |
plugin updater
Diffstat (limited to 'module/plugins')
-rw-r--r-- | module/plugins/hooks/UpdateManager.py | 62 |
1 files changed, 35 insertions, 27 deletions
diff --git a/module/plugins/hooks/UpdateManager.py b/module/plugins/hooks/UpdateManager.py index f8e65c017..02ba6a6ff 100644 --- a/module/plugins/hooks/UpdateManager.py +++ b/module/plugins/hooks/UpdateManager.py @@ -17,6 +17,7 @@ @author: RaNaN @interface-version: 0.1 """ +from os.path import join from module.network.Request import getURL from module.plugins.Hook import Hook @@ -34,17 +35,14 @@ class UpdateManager(Hook): self.interval = self.getConfig("interval") * 60 self.updated = False - def coreReady(self): - #@TODO check plugins, restart, and other stuff - pass - def periodical(self): update = self.checkForUpdate() - if self.updated: - self.log.info(_("*** Plugins were updated, please restart pyLoad ***")) if not update: self.checkPlugins() - + if self.updated: + self.log.info(_("*** Plugins have been updated, please restart pyLoad ***")) + else: + self.log.info(_("No plugin updates available")) def checkForUpdate(self): """ checks if an update is available""" @@ -66,32 +64,42 @@ class UpdateManager(Hook): def checkPlugins(self): """ checks for plugins updates""" - string = "" - - string += self.createUpdateList(self.core.pluginManager.crypterPlugins, "crypter") - string += self.createUpdateList(self.core.pluginManager.hosterPlugins, "hoster") - string += self.createUpdateList(self.core.pluginManager.containerPlugins, "container") - string += self.createUpdateList(self.core.pluginManager.accountPlugins, "account") - string += self.createUpdateList(self.core.pluginManager.hookPlugins, "hook") - string += self.createUpdateList(self.core.pluginManager.captchaPlugins, "captcha") - try: - updates = getURL("updateurl", post={"plugins": string}) + updates = getURL("http://get.pyload.org/plugins/check/") except: self.log.warning(_("Plugins could not be updated")) - updates = "" + return False updates = updates.splitlines() for plugin in updates: - type, name, url = plugin.split("|") - print type, name, url - #@TODO save url content to disk + path, version = plugin.split(":") + prefix, name = path.split("/") + + if name.endswith(".pyc"): + tmp_name = name[:name.find("_")] + else: + tmp_name = name.replace(".py", "") + + if prefix.endswith("s"): + type = prefix[:-1] + else: + type = prefix + + plugins = getattr(self.core.pluginManager, "%sPlugins" % type) + + if plugins.has_key(tmp_name): + if float(plugins[tmp_name]["v"]) >= float(version): + continue - def createUpdateList(self, plugins, type): - """ create string list for update check """ - string = "" - for name,plugin in plugins.iteritems(): - string += "%s|%s|%s\n" % (type, name, plugin["v"]) + self.log.info(_("New version of %(type)s|%(name)s : %(version).2f") % { + "type": type, + "name": name, + "version": float(version) + }) - return string
\ No newline at end of file + content = getURL("http://get.pyload.org/plugins/get/" + path) + f = open(join("userplugins", prefix, name), "wb") + f.write(content) + f.close() + self.updated = True
\ No newline at end of file |