summaryrefslogtreecommitdiffstats
path: root/module/plugins/internal
diff options
context:
space:
mode:
authorGravatar Walter Purcaro <vuolter@users.noreply.github.com> 2015-06-15 18:07:17 +0200
committerGravatar Walter Purcaro <vuolter@users.noreply.github.com> 2015-06-15 18:07:17 +0200
commita0d0d3ccd041097c01a100861d3b6d1b1460df16 (patch)
treef29d95158f2c7e298aacc3fcc2acedd73e7bfe9b /module/plugins/internal
parentHook plugin code cosmetics (2) (diff)
downloadpyload-a0d0d3ccd041097c01a100861d3b6d1b1460df16.tar.xz
Fix https://github.com/pyload/pyload/issues/1502
Diffstat (limited to 'module/plugins/internal')
-rw-r--r--module/plugins/internal/Hook.py87
1 files changed, 68 insertions, 19 deletions
diff --git a/module/plugins/internal/Hook.py b/module/plugins/internal/Hook.py
index 4f9a01bb3..deeb5a097 100644
--- a/module/plugins/internal/Hook.py
+++ b/module/plugins/internal/Hook.py
@@ -24,7 +24,7 @@ def threaded(fn):
class Hook(Base):
__name__ = "Hook"
__type__ = "hook"
- __version__ = "0.05"
+ __version__ = "0.06"
__config__ = [] #: [("name", "type", "desc", "default")]
__threaded__ = [] #@TODO: Remove in 0.4.10
@@ -39,17 +39,11 @@ class Hook(Base):
def __init__(self, core, manager):
super(Hook, self).__init__(core)
- #: Provide information in dict here, usable by API `getInfo`
- self.info = {}
-
- #: Callback of periodical job task, used by HookManager
- self.cb = None
- self.interval = 60
-
#: `HookManager`
self.manager = manager
- self.setup()
+ #: Provide information in dict here, usable by API `getInfo`
+ self.info = {}
#: automatically register event listeners for functions, attribute will be deleted dont use it yourself
self.event_map = {}
@@ -58,11 +52,16 @@ class Hook(Base):
#: List of events the plugin can handle, name the functions exactly like eventname.
self.event_list = [] #@NOTE: dont make duplicate entries in event_map
- self.initEvents()
- self.initPeriodical(10)
+ #: Callback of periodical job task, used by HookManager
+ self.cb = None
+ self.interval = 60
+
+ self.setup()
+ self.init_events()
+ self.init_periodical(10)
- def initEvents(self):
+ def init_events(self):
if self.event_map:
for event, funcs in self.event_map.iteritems():
if type(funcs) in (list, tuple):
@@ -83,10 +82,15 @@ class Hook(Base):
self.event_list = None
- def initPeriodical(self, delay=0, threaded=False):
+ def init_periodical(self, delay=0, threaded=False):
self.cb = self.core.scheduler.addJob(max(0, delay), self._periodical, [threaded], threaded=threaded)
+ #: Deprecated method, use `init_periodical` instead
+ def initPeriodical(self):
+ return self.init_periodical()
+
+
def _periodical(self, threaded):
if self.interval < 0:
self.cb = None
@@ -103,6 +107,10 @@ class Hook(Base):
self.cb = self.core.scheduler.addJob(self.interval, self._periodical, [threaded], threaded=threaded)
+ def periodical(self):
+ pass
+
+
def __repr__(self):
return "<Hook %s>" % self.__name__
@@ -112,11 +120,16 @@ class Hook(Base):
pass
- def isActivated(self):
+ def is_activated(self):
"""Checks if hook is activated"""
return self.getConfig("activated")
+ #: Deprecated method, use `is_activated` instead
+ def isActivated(self):
+ return self.is_activated()
+
+
def deactivate(self):
"""Called when hook was deactivated"""
pass
@@ -147,32 +160,58 @@ class Hook(Base):
return self.exit()
+ def download_preparing(self, pyfile):
+ pass
+
+
+ #: Deprecated method, use `download_preparing` instead
def downloadPreparing(self, pyfile):
+ return self.download_preparing(pyfile)
+
+
+ def download_finished(self, pyfile):
pass
+ #: Deprecated method, use `download_finished` instead
def downloadFinished(self, pyfile):
+ return self.download_finished(pyfile)
+
+
+ def download_failed(self, pyfile):
pass
+ #: Deprecated method, use `download_failed` instead
def downloadFailed(self, pyfile):
+ return self.download_failed(pyfile)
+
+
+ def package_finished(self, pypack):
pass
+ #: Deprecated method, use `package_finished` instead
def packageFinished(self, pypack):
+ return self.package_finished(pyfile)
+
+
+ def before_reconnect(self, ip):
pass
+ #: Deprecated method, use `before_reconnect` instead
def beforeReconnecting(self, ip):
- pass
+ return self.before_reconnect(ip)
- def afterReconnecting(self, ip):
+ def after_reconnect(self, ip, oldip):
pass
- def periodical(self):
- pass
+ #: Deprecated method, use `after_reconnect` instead
+ def afterReconnecting(self, ip):
+ return self.after_reconnect(ip, None)
def captcha_task(self, task):
@@ -185,9 +224,19 @@ class Hook(Base):
return self.captcha_task(task)
+ def captcha_correct(self, task):
+ pass
+
+
+ #: Deprecated method, use `captcha_correct` instead
def captchaCorrect(self, task):
+ return self.captcha_correct(task)
+
+
+ def captcha_invalid(self, task):
pass
+ #: Deprecated method, use `captcha_invalid` instead
def captchaInvalid(self, task):
- pass
+ return self.captcha_invalid(task)