diff options
-rw-r--r-- | module/plugins/hoster/LoadTo.py | 13 | ||||
-rw-r--r-- | module/plugins/internal/CaptchaService.py | 147 |
2 files changed, 91 insertions, 69 deletions
diff --git a/module/plugins/hoster/LoadTo.py b/module/plugins/hoster/LoadTo.py index 7e6804ceb..be330e246 100644 --- a/module/plugins/hoster/LoadTo.py +++ b/module/plugins/hoster/LoadTo.py @@ -13,7 +13,7 @@ from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo class LoadTo(SimpleHoster): __name__ = "LoadTo" __type__ = "hoster" - __version__ = "0.21" + __version__ = "0.22" __pattern__ = r'http://(?:www\.)?load\.to/\w+' @@ -49,17 +49,20 @@ class LoadTo(SimpleHoster): # Set Timer - may be obsolete m = re.search(self.WAIT_PATTERN, self.html) if m: - self.wait(int(m.group(1))) + self.wait(m.group(1)) # Load.to is using solvemedia captchas since ~july 2014: - solvemedia = SolveMedia(self) + solvemedia = SolveMedia(self) captcha_key = solvemedia.detect_key() if captcha_key is None: self.download(download_url) else: - response, challenge = solvemedia.challenge(captcha_key,None,pyfile.url) - self.download(download_url, post={"adcopy_challenge": challenge, "adcopy_response": response,"returnUrl":pyfile.url}) + response, challenge = solvemedia.challenge(captcha_key) + self.download(download_url, + post={'adcopy_challenge': challenge, + 'adcopy_response' : response, + 'returnUrl' : pyfile.url}) getInfo = create_getInfo(LoadTo) diff --git a/module/plugins/internal/CaptchaService.py b/module/plugins/internal/CaptchaService.py index ecf8385c8..664d10fb7 100644 --- a/module/plugins/internal/CaptchaService.py +++ b/module/plugins/internal/CaptchaService.py @@ -10,9 +10,9 @@ from urlparse import urljoin, urlparse from module.common.json_layer import json_loads -class CaptchaService: +class CaptchaService(object): __name__ = "CaptchaService" - __version__ = "0.22" + __version__ = "0.23" __description__ = """Base captcha service plugin""" __license__ = "GPLv3" @@ -40,7 +40,7 @@ class CaptchaService: class ReCaptcha(CaptchaService): __name__ = "ReCaptcha" - __version__ = "0.12" + __version__ = "0.13" __description__ = """ReCaptcha captcha service plugin""" __license__ = "GPLv3" @@ -73,21 +73,6 @@ class ReCaptcha(CaptchaService): def challenge(self, key=None, html=None, version=None): - if not html: - if hasattr(self.plugin, "html") and self.plugin.html: - html = self.plugin.html - else: - errmsg = _("ReCaptcha html not found") - self.plugin.fail(errmsg) - raise TypeError(errmsg) - - challenge = "challenge_v%s" % (version if version in (1, 2) else - 2 if re.search(self.KEY_V2_PATTERN, html) else 1) - - return getattr(self, challenge)(key, html) - - - def challenge_v1(self, key=None, html=None): if not key: if self.detect_key(html): key = self.key @@ -96,7 +81,22 @@ class ReCaptcha(CaptchaService): self.plugin.fail(errmsg) raise TypeError(errmsg) - html = self.plugin.req.load("http://www.google.com/recaptcha/api/challenge", get={'k': key}) + if version in (1, 2): + return getattr(self, "_challenge_v%s" % version)(key, html) + + elif not html and hasattr(self.plugin, "html") and self.plugin.html: + version = 2 if re.search(self.KEY_V2_PATTERN, self.plugin.html) else 1 + return self.challenge(key, self.plugin.html, version) + + else: + errmsg = _("ReCaptcha html not found") + self.plugin.fail(errmsg) + raise TypeError(errmsg) + + + def _challenge_v1(self, key): + html = self.plugin.req.load("http://www.google.com/recaptcha/api/challenge", + get={'k': key}) try: challenge = re.search("challenge : '(.+?)',", html).group(1) server = re.search("server : '(.+?)',", html).group(1) @@ -159,20 +159,13 @@ class ReCaptcha(CaptchaService): return millis, rpc - def challenge_v2(self, key=None, html=None): - if not key: - if self.detect_key(html): - key = self.key - else: - errmsg = _("ReCaptcha key not found") - self.plugin.fail(errmsg) - raise TypeError(errmsg) + def _challenge_v2(self, key, parent=None): + if parent is None: + try: + parent = urljoin("http://", urlparse(self.plugin.pyfile.url).netloc) - try: - parent = urljoin("http://", urlparse(self.plugin.pyfile.url).netloc) - - except Exception: - parent = "" + except Exception: + parent = "" botguardstring = "!A" vers, language, jsh = self._collectApiInfo() @@ -190,7 +183,7 @@ class ReCaptcha(CaptchaService): token1 = re.search(r'id="recaptcha-token" value="(.*?)">', html) self.plugin.logDebug("ReCaptcha token #1: %s" % token1.group(1)) - + html = self.plugin.req.load("https://www.google.com/recaptcha/api2/frame", get={'c' : token1.group(1), 'hl' : language, @@ -214,10 +207,12 @@ class ReCaptcha(CaptchaService): token4 = re.search(r'"rresp","(.*?)",', html) self.plugin.logDebug("ReCaptcha token #4: %s" % token4.group(1)) - + millis_captcha_loading = int(round(time.time() * 1000)) captcha_response = self.plugin.decryptCaptcha("https://www.google.com/recaptcha/api2/payload", - get={'c':token4.group(1), 'k':key}, forceUser=True) + get={'c':token4.group(1), 'k':key}, + cookies=True, + forceUser=True) response = b64encode('{"response":"%s"}' % captcha_response) self.plugin.logDebug("ReCaptcha result: %s" % response) @@ -236,7 +231,10 @@ class ReCaptcha(CaptchaService): token5 = re.search(r'"uvresp","(.*?)",', html) self.plugin.logDebug("ReCaptcha token #5: %s" % token5.group(1)) - return token5.group(1), None + result = token5.group(1) + + return result, None + class AdsCaptcha(CaptchaService): @@ -283,7 +281,9 @@ class AdsCaptcha(CaptchaService): PublicKey, CaptchaId = key - html = self.plugin.req.load("http://api.adscaptcha.com/Get.aspx", get={'CaptchaId': CaptchaId, 'PublicKey': PublicKey}) + html = self.plugin.req.load("http://api.adscaptcha.com/Get.aspx", + get={'CaptchaId': CaptchaId, + 'PublicKey': PublicKey}) try: challenge = re.search("challenge: '(.+?)',", html).group(1) server = re.search("server: '(.+?)',", html).group(1) @@ -311,7 +311,7 @@ class AdsCaptcha(CaptchaService): class SolveMedia(CaptchaService): __name__ = "SolveMedia" - __version__ = "0.09" + __version__ = "0.10" __description__ = """SolveMedia captcha service plugin""" __license__ = "GPLv3" @@ -331,7 +331,6 @@ class SolveMedia(CaptchaService): raise TypeError(errmsg) m = re.search(self.KEY_PATTERN, html) - magic = re.search(r'name="magic" value="(.*?)"',html) if m: self.key = m.group(1).strip() self.plugin.logDebug("SolveMedia key: %s" % self.key) @@ -341,7 +340,7 @@ class SolveMedia(CaptchaService): return None - def challenge(self, key=None, html=None, pyfile_url=""): + def challenge(self, key=None, html=None): if not key: if self.detect_key(html): key = self.key @@ -350,7 +349,8 @@ class SolveMedia(CaptchaService): self.plugin.fail(errmsg) raise TypeError(errmsg) - html = self.plugin.req.load("http://api.solvemedia.com/papi/challenge.noscript", get={'k': key}) + html = self.plugin.req.load("http://api.solvemedia.com/papi/challenge.noscript", + get={'k': key}) try: challenge = re.search(r'<input type=hidden name="adcopy_challenge" id="adcopy_challenge" value="([^"]+)">', html).group(1) @@ -362,37 +362,56 @@ class SolveMedia(CaptchaService): raise AttributeError(errmsg) self.plugin.logDebug("SolveMedia challenge: %s" % challenge) - + + result = self.result(server, challenge) + + if not self.verify(result, challenge, key): + self.plugin.logDebug("SolveMedia captcha code was invalid") + + return result, challenge + + + def verify(self, result, challenge, key, ref=None): + if ref is None: + try: + ref = self.plugin.pyfile.url + + except Exception: + ref = "" + try: - magic = re.search(r'name="magic" value="(.*?)"',html).group(1) + magic = re.search(r'name="magic" value="(.+?)"', html).group(1) + except AttributeError: - errmsg = _("SolveMedia magic string not found") + errmsg = _("SolveMedia magic key not found") self.plugin.fail(errmsg) raise AttributeError(errmsg) - result = self.result(server, challenge) - - html = self.plugin.req.load("http://api.solvemedia.com/papi/verify.noscript", - cookies=True, - post={"adcopy_response" : result, - "k" : key, - "l" : "en", - "t" : "img", - "s" : "standard", - "magic" : magic, - "adcopy_challenge" : challenge, - "ref" : pyfile_url}) + html = self.plugin.req.load("http://api.solvemedia.com/papi/verify.noscript", + post={'adcopy_response' : result, + 'k' : key, + 'l' : "en", + 't' : "img", + 's' : "standard", + 'magic' : magic, + 'adcopy_challenge' : challenge, + 'ref' : ref) try: - url = re.search(r'URL=(.*?)">',html).group(1) - html = self.plugin.req.load(url,cookies=True) - gibberish = re.search(r'id=gibberish>(.*?)</textarea>',html).group(1) - except: - self.plugin.logDebug("Wrong captcha answer!") - - return result,challenge + html = self.plugin.req.load(re.search(r'URL=(.+?)">', html).group(1)) + gibberish = re.search(r'id=gibberish>(.+?)</textarea>', html).group(1) + + except Exception: + return False + + else: + return True + def result(self, server, challenge): - result = self.plugin.decryptCaptcha(server, get={'c': challenge}, imgtype="gif") + result = self.plugin.decryptCaptcha(server, + get={'c': challenge}, + cookies=True, + imgtype="gif") self.plugin.logDebug("SolveMedia result: %s" % result) |