summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--module/plugins/hooks/UpdateManager.py59
1 files changed, 29 insertions, 30 deletions
diff --git a/module/plugins/hooks/UpdateManager.py b/module/plugins/hooks/UpdateManager.py
index 11e93c04d..5f88ea6d0 100644
--- a/module/plugins/hooks/UpdateManager.py
+++ b/module/plugins/hooks/UpdateManager.py
@@ -1,26 +1,9 @@
# -*- coding: utf-8 -*-
-"""
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 3 of the License,
- or (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- See the GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program; if not, see <http://www.gnu.org/licenses/>.
-
- @author: RaNaN
-"""
-
import sys
import re
-from os import stat
-from os.path import join, exists
+from os import remove, stat
+from os.path import join, isfile
from time import time
from module.ConfigParser import IGNORE
@@ -30,15 +13,15 @@ from module.plugins.Hook import threaded, Expose, Hook
class UpdateManager(Hook):
__name__ = "UpdateManager"
- __version__ = "0.15"
+ __version__ = "0.16"
__description__ = """Checks for updates"""
__config__ = [("activated", "bool", "Activated", True),
("interval", "int", "Check interval in minutes", 480),
("debug", "bool", "Check for plugin changes when in debug mode", False)]
- __author_name__ = "RaNaN"
- __author_mail__ = "ranan@pyload.org"
+ __author_name__ = ("RaNaN", "stickell")
+ __author_mail__ = ("ranan@pyload.org", "l.stickell@yahoo.it")
- URL = "http://get.pyload.org/check2/%s/"
+ URL = "http://updatemanager.pyload.org"
MIN_TIME = 3 * 60 * 60 # 3h minimum check interval
@property
@@ -64,7 +47,6 @@ class UpdateManager(Hook):
@threaded
def periodical(self):
-
updates = self.checkForUpdate()
if updates:
self.checkPlugins(updates)
@@ -85,10 +67,9 @@ class UpdateManager(Hook):
def checkForUpdate(self):
"""checks if an update is available, return result"""
-
try:
if self.version == "None": # No updated known
- version_check = getURL(self.URL % self.core.api.getServerVersion()).splitlines()
+ version_check = getURL(self.URL, get={'v': self.core.api.getServerVersion()}).splitlines()
self.version = version_check[0]
# Still no updates, plugins will be checked
@@ -99,7 +80,6 @@ class UpdateManager(Hook):
self.info["pyload"] = True
self.logInfo(_("*** New pyLoad Version %s available ***") % self.version)
self.logInfo(_("*** Get it here: http://pyload.org/download ***"))
-
except:
self.logWarning(_("Not able to connect server for updates"))
@@ -117,7 +97,12 @@ class UpdateManager(Hook):
vre = re.compile(r'__version__.*=.*("|\')([0-9.]+)')
url = updates[0]
schema = updates[1].split("|")
- updates = updates[2:]
+ if 'BLACKLIST' in updates:
+ blacklist = updates[updates.index('BLACKLIST') + 1:]
+ updates = updates[2:updates.index('BLACKLIST')]
+ else:
+ blacklist = None
+ updates = updates[2:]
for plugin in updates:
info = dict(zip(schema, plugin.split("|")))
@@ -169,10 +154,24 @@ class UpdateManager(Hook):
reloads.append((prefix, name))
+ if blacklist:
+ self.executeBlacklist(blacklist)
+
self.reloaded = self.core.pluginManager.reloadPlugins(reloads)
- def checkChanges(self):
+ def executeBlacklist(self, blacklist):
+ for b in blacklist:
+ type, name = b.split('|')
+ if isfile(join("userplugins", type, name)):
+ self.logInfo(_("Removing blacklisted plugin %(type)s|%(name)s") % {
+ "type": type,
+ "name": name
+ })
+ remove(join("userplugins", type, name))
+ if isfile(join("userplugins", type, name.replace('.py', '.pyc'))):
+ remove(join("userplugins", type, name.replace('.py', '.pyc')))
+ def checkChanges(self):
if self.last_check + max(self.getConfig("interval") * 60, self.MIN_TIME) < time():
self.old_periodical()
self.last_check = time()
@@ -188,7 +187,7 @@ class UpdateManager(Hook):
id = (type, name)
if type in self.core.pluginManager.plugins:
f = m.__file__.replace(".pyc", ".py")
- if not exists(f):
+ if not isfile(f):
continue
mtime = stat(f).st_mtime