diff options
author | Walter Purcaro <vuolter@gmail.com> | 2015-01-30 18:07:47 +0100 |
---|---|---|
committer | Walter Purcaro <vuolter@gmail.com> | 2015-01-30 18:07:47 +0100 |
commit | d4025e2df8001e9217b7934c9e0afddfa27b7544 (patch) | |
tree | 974bc30c5456c5bca770f5cfea705e067b8d8a55 /module/plugins | |
parent | [ExtractArchive] Fix https://github.com/pyload/pyload/issues/1100 (diff) | |
parent | [CaptchaService.py] Fix ReCaptchaV2 (diff) | |
download | pyload-d4025e2df8001e9217b7934c9e0afddfa27b7544.tar.xz |
Merge pull request #1111 from zapp-brannigan/patch-4
[CaptchaService.py] Fix ReCaptchaV2
Diffstat (limited to 'module/plugins')
-rw-r--r-- | module/plugins/internal/CaptchaService.py | 19 |
1 files changed, 11 insertions, 8 deletions
diff --git a/module/plugins/internal/CaptchaService.py b/module/plugins/internal/CaptchaService.py index c6e83fe7d..c7dab2a0a 100644 --- a/module/plugins/internal/CaptchaService.py +++ b/module/plugins/internal/CaptchaService.py @@ -12,7 +12,7 @@ from module.common.json_layer import json_loads class CaptchaService: __name__ = "CaptchaService" - __version__ = "0.20" + __version__ = "0.21" __description__ = """Base captcha service plugin""" __license__ = "GPLv3" @@ -40,7 +40,7 @@ class CaptchaService: class ReCaptcha(CaptchaService): __name__ = "ReCaptcha" - __version__ = "0.11" + __version__ = "0.12" __description__ = """ReCaptcha captcha service plugin""" __license__ = "GPLv3" @@ -190,32 +190,34 @@ 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, 'v' : vers, 'bg' : botguardstring, + 'k' : key, 'usegapi': "1", 'jsh' : jsh}).decode('unicode-escape') token2 = re.search(r'"finput","(.*?)",', html) self.plugin.logDebug("ReCaptcha token #2: %s" % token2.group(1)) - token3 = re.search(r'."asconf".\s.\s,"(.*?)".', html) + token3 = re.search(r'."asconf".\s,".*?".\s,"(.*?)".', html) self.plugin.logDebug("ReCaptcha token #3: %s" % token3.group(1)) html = self.plugin.req.load("https://www.google.com/recaptcha/api2/reload", - post={'c' : token2.group(1), + post={'k' : key, + 'c' : token2.group(1), 'reason': "fi", 'fbg' : token3.group(1)}) 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)}, forceUser=True) + get={'c':token4.group(1), 'k':key}, forceUser=True) response = b64encode('{"response":"%s"}' % captcha_response) self.plugin.logDebug("ReCaptcha result: %s" % response) @@ -224,7 +226,8 @@ class ReCaptcha(CaptchaService): timeToSolveMore = timeToSolve + int(float("0." + str(randint(1, 99999999))) * 500) html = self.plugin.req.load("https://www.google.com/recaptcha/api2/userverify", - post={'c' : token4.group(1), + post={'k' : key, + 'c' : token4.group(1), 'response': response, 't' : timeToSolve, 'ct' : timeToSolveMore, |