summaryrefslogtreecommitdiffstats
path: root/module
diff options
context:
space:
mode:
Diffstat (limited to 'module')
-rw-r--r--module/config/default.conf2
-rw-r--r--module/plugins/hooks/UpdateManager.py62
2 files changed, 51 insertions, 13 deletions
diff --git a/module/config/default.conf b/module/config/default.conf
index 915604084..deb780142 100644
--- a/module/config/default.conf
+++ b/module/config/default.conf
@@ -7,7 +7,7 @@ remote - "Remote":
str password : "Password" = pwhere
ssl - "SSL":
bool activated : "Activated"= False
- str cert : "SSL Certificate" = ssl.crt
+ str cert : "SSL Certificate" = ssl.srt
str key : "SSL Key" = ssl.key
webinterface - "Webinterface":
bool activated : "Activated" = True
diff --git a/module/plugins/hooks/UpdateManager.py b/module/plugins/hooks/UpdateManager.py
index 2981df9a0..8e2c4368b 100644
--- a/module/plugins/hooks/UpdateManager.py
+++ b/module/plugins/hooks/UpdateManager.py
@@ -25,35 +25,73 @@ class UpdateManager(Hook):
__name__ = "UpdateManager"
__version__ = "0.1"
__description__ = """checks for updates"""
- __config__ = [ ("activated", "bool", "Activated" , "True"),
- ("interval", "int", "Check interval in minutes" , "180")]
+ __config__ = [("activated", "bool", "Activated", "True"),
+ ("interval", "int", "Check interval in minutes", "180")]
__author_name__ = ("RaNaN")
__author_mail__ = ("ranan@pyload.org")
def setup(self):
self.interval = self.getConfig("interval") * 60
-
+ self.updated = False
+
def coreReady(self):
- #@TODO check plugins, restart, and other stuff
+ #@TODO check plugins, restart, and other stuff
pass
-
+
def periodical(self):
- self.checkForUpdate()
-
-
+ update = self.checkForUpdate()
+ if self.updated:
+ self.log.info(_("*** Plugins were updated, please restart pyLoad ***"))
+ if not update:
+ self.checkPlugins()
+
+
def checkForUpdate(self):
""" checks if an update is available"""
-
+
try:
- version_check = getURL("http://get.pyload.org/check/%s/" % self.core.server_methods.get_server_version() )
+ version_check = getURL("http://get.pyload.org/check/%s/" % self.core.server_methods.get_server_version())
if version_check == "":
self.log.info(_("No Updates for pyLoad"))
return False
else:
self.log.info(_("*** New pyLoad Version %s available ***") % version_check)
- self.log.info(_("*** Get it here: http://get.pyload.org/get/ ***"))
+ self.log.info(_("*** Get it here: http://pyload.org/download ***"))
return True
except:
self.log.error(_("Not able to connect server"))
+ return False
+
+
+ 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})
+ except:
+ self.log.warning(_("Plugins could not be updated"))
+ updates = ""
+
+ updates = updates.splitlines()
+
+ for plugin in updates:
+ type, name, url = plugin.split("|")
+ print type, name, url
+ #@TODO save url content to disk
+
+ 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"])
- \ No newline at end of file
+ return string \ No newline at end of file