summaryrefslogtreecommitdiffstats
path: root/module/plugins
diff options
context:
space:
mode:
Diffstat (limited to 'module/plugins')
-rw-r--r--module/plugins/internal/Base.py210
1 files changed, 87 insertions, 123 deletions
diff --git a/module/plugins/internal/Base.py b/module/plugins/internal/Base.py
index c57b58ef0..7737074b5 100644
--- a/module/plugins/internal/Base.py
+++ b/module/plugins/internal/Base.py
@@ -34,16 +34,6 @@ def create_getInfo(klass):
return get_info
-#@NOTE: `check_abort` decorator
-def check_abort(fn):
-
- def wrapper(self, *args, **kwargs):
- self.check_abort()
- return fn(self, *args, **kwargs)
-
- return wrapper
-
-
class Base(Plugin):
__name__ = "Base"
__type__ = "base"
@@ -176,6 +166,7 @@ class Base(Plugin):
self.req = self.pyload.requestFactory.getRequest(self.classname)
self.premium = False
+ self.grab_info()
self.setup_base()
self.setup()
@@ -195,22 +186,98 @@ class Base(Plugin):
self.account = False
+ def _update_name(self):
+ name = self.info.get('name')
+
+ if name and name is not self.info.get('url'):
+ self.pyfile.name = name
+ else:
+ name = self.pyfile.name
+
+ self.log_info(_("Link name: ") + name)
+
+
+ def _update_size(self):
+ size = self.info.get('size')
+
+ if size > 0:
+ self.pyfile.size = int(self.info['size']) #@TODO: Fix int conversion in 0.4.10
+ else:
+ size = self.pyfile.size
+
+ if size:
+ self.log_info(_("Link size: %s bytes") % size)
+ else:
+ self.log_info(_("Link size: N/D"))
+
+
+ def _update_status(self):
+ self.pyfile.status = self.info.get('status', 14)
+ self.pyfile.sync()
+
+ self.log_info(_("Link status: ") + self.pyfile.getStatusName())
+
+
+ def sync_info(self):
+ self._update_name()
+ self._update_size()
+ self._update_status()
+
+
+ def grab_info(self):
+ self.log_info(_("Grabbing link info..."))
+
+ old_info = dict(self.info)
+ new_info = self.get_info(self.pyfile.url, self.html)
+
+ self.info.update(new_info)
+
+ self.log_debug("Link info: %s" % self.info)
+ self.log_debug("Previous link info: %s" % old_info)
+
+ self.sync_info()
+
+
+ def check_status(self):
+ status = self.pyfile.status
+
+ if status is 1:
+ self.offline()
+
+ elif status is 4:
+ self.skip(self.pyfile.statusname)
+
+ elif status is 6:
+ self.temp_offline()
+
+ elif status is 8:
+ self.fail()
+
+ elif status is 9 or self.pyfile.abort:
+ self.abort()
+
+
def _process(self, thread):
"""
Handles important things to do before starting
"""
- self.thread = thread
+ self.log_debug("Plugin version: " + self.__version__)
+ self.log_debug("Plugin status: " + self.__status__)
+ if self.__status__ is "broken":
+ self.fail(_("Plugin is currently broken"))
+
+ self.thread = thread
self._setup()
# self.pyload.hookManager.downloadPreparing(self.pyfile) #@TODO: Recheck in 0.4.10
- self.check_abort()
+ self.check_status()
self.pyfile.setStatus("starting")
- self.log_debug("PROCESS URL " + self.pyfile.url,
- "PLUGIN VERSION %s" % self.__version__)
+ self.log_info(_("Processing url: ") + self.pyfile.url)
self.process(self.pyfile)
+ self.check_status()
#: Deprecated method, use `_process` instead (Remove in 0.4.10)
@@ -276,16 +343,16 @@ class Base(Plugin):
if self.wantReconnect:
self.log_info(_("Requiring reconnection..."))
if self.account:
- self.log_warning("Ignore reconnection due logged account")
+ self.log_warning("Reconnection ignored due logged account")
if not self.wantReconnect or self.account:
while pyfile.waitUntil > time.time():
- self.check_abort()
+ self.check_status()
time.sleep(2)
else:
while pyfile.waitUntil > time.time():
- self.check_abort()
+ self.check_status()
self.thread.m.reconnecting.wait(1)
if self.thread.m.reconnecting.isSet():
@@ -309,7 +376,7 @@ class Base(Plugin):
#@TODO: Remove in 0.4.10
- def fail(self, msg):
+ def fail(self, msg=""):
"""
Fail and give msg
"""
@@ -363,7 +430,7 @@ class Base(Plugin):
if not premium:
if self.premium:
- self.rst_free = True
+ self.restart_free = True
else:
self.fail("%s | %s" % (msg, _("Url was already processed as free")))
@@ -416,114 +483,11 @@ class Base(Plugin):
return fixurl(url, unquote)
- @check_abort
def load(self, *args, **kwargs):
+ self.check_status()
return super(Base, self).load(*args, **kwargs)
- def check_abort(self):
- if not self.pyfile.abort:
- return
-
- if self.pyfile.status is 8:
- self.fail()
-
- elif self.pyfile.status is 4:
- self.skip(self.pyfile.statusname)
-
- elif self.pyfile.status is 1:
- self.offline()
-
- elif self.pyfile.status is 6:
- self.temp_offline()
-
- else:
- self.abort()
-
-
- def direct_link(self, url, redirect=False):
- link = ""
-
- if not redirect:
- conn = 1
-
- elif type(redirect) is int:
- conn = max(redirect, 1)
-
- else:
- conn = self.get_config("maxredirs", 5, plugin="UserAgentSwitcher")
-
- for i in xrange(conn):
- try:
- self.log_debug("Redirect #%d to: %s" % (i, url))
- header = self.load(url, just_header=True)
-
- except Exception: #: Bad bad bad... rewrite this part in 0.4.10
- res = self.load(url,
- just_header=True,
- req=self.pyload.requestFactory.getRequest(self.classname))
-
- header = {'code': req.code}
- for line in res.splitlines():
- line = line.strip()
- if not line or ":" not in line:
- continue
-
- key, none, value = line.partition(":")
- key = key.lower().strip()
- value = value.strip()
-
- if key in header:
- header_key = header.get(key)
- if type(header_key) is list:
- header_key.append(value)
- else:
- header[key] = [header_key, value]
- else:
- header[key] = value
-
- if 'content-disposition' in header:
- link = url
-
- elif header.get('location'):
- location = self.fixurl(header.get('location'), url)
-
- if header.get('code') == 302:
- link = location
-
- if redirect:
- url = location
- continue
-
- else:
- extension = os.path.splitext(parse_name(url))[-1]
-
- if header.get('content-type'):
- mimetype = header.get('content-type').split(';')[0].strip()
-
- elif extension:
- mimetype = mimetypes.guess_type(extension, False)[0] or "application/octet-stream"
-
- else:
- mimetype = ""
-
- if mimetype and (link or 'html' not in mimetype):
- link = url
- else:
- link = ""
-
- break
-
- else:
- try:
- self.log_error(_("Too many redirects"))
-
- except Exception:
- pass
-
- return link
-
-
def parse_html_form(self, attr_str="", input_names={}):
return parse_html_form(attr_str, self.html, input_names)