summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--module/plugins/hoster/FilefactoryCom.py7
-rw-r--r--module/plugins/hoster/IfileIt.py3
-rw-r--r--module/plugins/hoster/ShareonlineBiz.py57
3 files changed, 38 insertions, 29 deletions
diff --git a/module/plugins/hoster/FilefactoryCom.py b/module/plugins/hoster/FilefactoryCom.py
index 17520a6c3..33e055175 100644
--- a/module/plugins/hoster/FilefactoryCom.py
+++ b/module/plugins/hoster/FilefactoryCom.py
@@ -34,7 +34,7 @@ class FilefactoryCom(Hoster):
__name__ = "FilefactoryCom"
__type__ = "hoster"
__pattern__ = r"http://(?:www\.)?filefactory\.com/file/(?P<id>[a-zA-Z0-9]+).*" # URLs given out are often longer but this is the requirement
- __version__ = "0.31"
+ __version__ = "0.32"
__description__ = """Filefactory.Com File Download Hoster"""
__author_name__ = ("paulking", "zoidberg")
@@ -85,7 +85,10 @@ class FilefactoryCom(Hoster):
return False
- def handleFree(self):
+ def handleFree(self):
+ if "Currently only Premium Members can download files larger than" in self.html:
+ self.fail("File too large for free download")
+
# Check Id
self.check = re.search(self.FILE_CHECK_PATTERN, self.html).group('check')
self.log.debug("%s: File check code is [%s]" % (self.__name__, self.check))
diff --git a/module/plugins/hoster/IfileIt.py b/module/plugins/hoster/IfileIt.py
index ec830f3b2..cdb5a7919 100644
--- a/module/plugins/hoster/IfileIt.py
+++ b/module/plugins/hoster/IfileIt.py
@@ -26,7 +26,7 @@ class IfileIt(SimpleHoster):
__name__ = "IfileIt"
__type__ = "hoster"
__pattern__ = r"http://(?:\w*\.)*(?:ifile\.it|mihd\.net)/(\w+).*"
- __version__ = "0.24"
+ __version__ = "0.25"
__description__ = """Ifile.it"""
__author_name__ = ("zoidberg")
@@ -36,6 +36,7 @@ class IfileIt(SimpleHoster):
RECAPTCHA_KEY_PATTERN = r"var __recaptcha_public\s*=\s*'([^']+)';"
FILE_INFO_PATTERN = r'<span style="cursor: default;[^>]*>\s*(?P<N>.*?)\s*&nbsp;\s*<strong>\s*(?P<S>[0-9.]+)\s*(?P<U>[kKMG])i?B\s*</strong>\s*</span>'
FILE_OFFLINE_PATTERN = r'$\("#errorPnl"\)\.empty\(\)\.append\( "no such file" \);'
+ TEMP_OFFLINE_PATTERN = r'<span class="msg_red">Downloading of this file is temporarily disabled</span>'
def handleFree(self):
ukey = re.search(self.__pattern__, self.pyfile.url).group(1)
diff --git a/module/plugins/hoster/ShareonlineBiz.py b/module/plugins/hoster/ShareonlineBiz.py
index d355eeffe..25903f2e2 100644
--- a/module/plugins/hoster/ShareonlineBiz.py
+++ b/module/plugins/hoster/ShareonlineBiz.py
@@ -5,12 +5,12 @@ import re
from base64 import b64decode
import hashlib
import random
-from time import sleep
+from time import time, sleep
from module.plugins.Hoster import Hoster
from module.network.RequestFactory import getURL
from module.plugins.Plugin import chunks
-
+from module.plugins.ReCaptcha import ReCaptcha
def getInfo(urls):
api_url_base = "http://api.share-online.biz/linkcheck.php"
@@ -38,10 +38,10 @@ class ShareonlineBiz(Hoster):
__name__ = "ShareonlineBiz"
__type__ = "hoster"
__pattern__ = r"http://[\w\.]*?(share\-online\.biz|egoshare\.com)/(download.php\?id\=|dl/)[\w]+"
- __version__ = "0.22"
+ __version__ = "0.23"
__description__ = """Shareonline.biz Download Hoster"""
- __author_name__ = ("spoob", "mkaay")
- __author_mail__ = ("spoob@pyload.org", "mkaay@mkaay.de")
+ __author_name__ = ("spoob", "mkaay", "zoidberg")
+ __author_mail__ = ("spoob@pyload.org", "mkaay@mkaay.de", "zoidberg@mujmail.cz")
def setup(self):
# range request not working?
@@ -83,42 +83,47 @@ class ShareonlineBiz(Hoster):
def handleFree(self):
self.resumeDownload = False
- self.html = self.load(self.pyfile.url) #refer, stuff
- self.html = self.load("%s/free/" % self.pyfile.url, post={"dl_free":"1", "choice": "free"})
+ self.html = self.load(self.pyfile.url, cookies = True) #refer, stuff
+ 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)
- if "Captcha number error or expired" in self.html:
- captcha = self.decryptCaptcha("http://www.share-online.biz/captcha.php", get={"rand":"0.%s" % random.randint(10**15,10**16)})
+ found = re.search(r'var wait=(\d+);', self.html)
- self.log.debug("%s Captcha: %s" % (self.__name__, captcha))
- sleep(3)
+ recaptcha = ReCaptcha(self)
+ for i in range(5):
+ #found = re.search(r'var dl="(.*?)";', self.html)
+ #captcha = found.group(1).decode("base64").split('|')[-1]}
+ challenge, response = recaptcha.challenge("6LdatrsSAAAAAHZrB70txiV5p-8Iv8BtVxlTtjKX")
+ self.setWait(int(found.group(1)) if found else 30)
+ response = self.load("%s/free/captcha/%d" % (self.pyfile.url, int(time() * 1000)), post = {
+ 'dl_free': '1',
+ 'recaptcha_challenge_field': challenge,
+ 'recaptcha_response_field': response})
- self.html = self.load(self.pyfile.url, post={"captchacode": captcha})
-
- if r"Der Download ist Ihnen zu langsam" not in self.html and r"The download is too slow for you" not in self.html:
- self.fail("Plugin defect. Save dumps and report.")
-
- if "Kein weiterer Download-Thread möglich!" in self.html: #TODO corresponding translation
- self.retry(wait_time=30, reason=_("Parallel download issue"))
+ if not response == '0':
+ break
- m = re.search("var wait=(\d+);", self.html[1])
- wait_time = int(m.group(1)) if m else 30
- self.setWait(wait_time)
- self.log.debug("%s: Waiting %d seconds." % (self.__name__, wait_time))
- self.wait()
+ else: self.fail("No valid captcha solution received")
- file_url_pattern = r'var\sdl="(.*?)"'
- download_url = b64decode(re.search(file_url_pattern, self.html).group(1))
+ download_url = response.decode("base64")
+ self.logDebug(download_url)
+ if not download_url.startswith("http://"):
+ self.parseError("download url")
+ self.wait()
self.download(download_url)
- check = self.checkDownload({"invalid" : "Dieses Download-Ticket ist ungültig!",
+ check = self.checkDownload({"invalid" : re.compile("<strong>(This download ticket is.*?)</strong>"),
"error" : "Es ist ein unbekannter Fehler aufgetreten"})
if check == "invalid":
+ self.logError(self.lastCheck.group(1))
self.retry(reason=_("Invalid download ticket"))
elif check == "error":
self.fail(reason=_("ShareOnline internal problems"))