diff options
author | zoidberg10 <zoidberg@mujmail.cz> | 2012-08-13 23:34:37 +0200 |
---|---|---|
committer | zoidberg10 <zoidberg@mujmail.cz> | 2012-08-13 23:34:37 +0200 |
commit | c398ca710131abf539a3a7167172585a1cb3823f (patch) | |
tree | 5689d9cbf09bc392f324210b83aa23a2c30aecbd /module/plugins/hoster | |
parent | update multishare account, xfilesharingpro (diff) | |
download | pyload-c398ca710131abf539a3a7167172585a1cb3823f.tar.xz |
share-online.biz error handling - should fix #649
Diffstat (limited to 'module/plugins/hoster')
-rw-r--r-- | module/plugins/hoster/ShareonlineBiz.py | 46 |
1 files changed, 31 insertions, 15 deletions
diff --git a/module/plugins/hoster/ShareonlineBiz.py b/module/plugins/hoster/ShareonlineBiz.py index b94389008..377ba5671 100644 --- a/module/plugins/hoster/ShareonlineBiz.py +++ b/module/plugins/hoster/ShareonlineBiz.py @@ -43,10 +43,12 @@ class ShareonlineBiz(Hoster): __name__ = "ShareonlineBiz" __type__ = "hoster" __pattern__ = r"http://[\w\.]*?(share\-online\.biz|egoshare\.com)/(download.php\?id\=|dl/)[\w]+" - __version__ = "0.31" + __version__ = "0.32" __description__ = """Shareonline.biz Download Hoster""" __author_name__ = ("spoob", "mkaay", "zoidberg") __author_mail__ = ("spoob@pyload.org", "mkaay@mkaay.de", "zoidberg@mujmail.cz") + + ERROR_INFO_PATTERN = r'<p class="b">Information:</p>\s*<div>\s*<strong>(.*?)</strong>' def setup(self): # range request not working? @@ -67,17 +69,13 @@ class ShareonlineBiz(Hoster): else: self.handleFree() - check = self.checkDownload({"invalid" : re.compile("<strong>(This download ticket is.*?)</strong>"), - "error" : re.compile("(Es ist ein unbekannter Fehler aufgetreten|An unknown error has occurred)"), - "cookie" : re.compile(r"<span class='udl'>Ihr Browser</span> verfügt leider nicht über einen gültigen <span class='udl'>Sitzungs Cookie</span>"), - "login" : re.compile(r"<title>Share-Online"),}) - if check in ("invalid", "error", "cookie", "login"): - self.logError(self.lastCheck.group(1)) + check = self.checkDownload({"failure": re.compile(self.ERROR_INFO_PATTERN)}) + if check == "failure": if self.premium: self.account.getAccountInfo(self.user, True) - self.retry(reason=_("Invalid download ticket")) + self.retry(reason = " ".join(self.lastCheck.groups()) or "Unknown error") - if self.api_data: + if self.api_data: self.check_data = {"size": int(self.api_data['size']), "md5": self.api_data['md5']} def downloadAPIData(self): @@ -103,12 +101,8 @@ class ShareonlineBiz(Hoster): self.setWait(3) self.wait() - self.html = self.load("%s/free/" % self.pyfile.url, post={"dl_free":"1", "choice": "free"}, cookies = True, ref = True) - if re.search(r"/failure/full/1", self.req.lastEffectiveURL): - self.setWait(120) - self.log.info("%s: no free slots, waiting 120 seconds" % self.__name__) - self.wait() - self.retry(max_tries=60) + self.html = self.load("%s/free/" % self.pyfile.url, post={"dl_free":"1", "choice": "free"}, cookies = True, ref = True) + self.checkErrors() found = re.search(r'var wait=(\d+);', self.html) @@ -134,6 +128,28 @@ class ShareonlineBiz(Hoster): self.wait() self.download(download_url) + def checkErrors(self): + found = re.search(r"/failure/(.*?)/1", self.req.lastEffectiveURL) + if found: + err = found.group(1) + found = re.search(self.ERROR_INFO_PATTERN, self.html) + msg = found.group(1) if found else "" + self.logError(err, msg or "Unknown error occurred") + + if err in ('freelimit', 'size'): + self.fail(msg or "File too big") + if err in ('invalid'): + self.fail(msg or "File not available") + elif err in ('server'): + self.setWait(600, False) + elif err in ('expired'): + self.setWait(30, False) + else: + self.setWait(300, True) + + self.wait() + self.retry(max_tries=25, reason = msg) + def handleAPIPremium(self): #should be working better self.account.getAccountInfo(self.user, True) src = self.load("http://api.share-online.biz/account.php?username=%s&password=%s&act=download&lid=%s" % (self.user, self.account.accounts[self.user]["password"], self.file_id), post={}) |