summaryrefslogtreecommitdiffstats
path: root/module/plugins
diff options
context:
space:
mode:
authorGravatar Walter Purcaro <vuolter@gmail.com> 2014-10-22 16:40:30 +0200
committerGravatar Walter Purcaro <vuolter@gmail.com> 2014-10-22 16:40:30 +0200
commit166a0c3e33cebc81ce9440a93042befa595e2a87 (patch)
tree396d3e50f4862d11d09a88f2ec8dc35c15d9a3dc /module/plugins
parent[CaptchaService] Fix KEY_PATTERN (diff)
downloadpyload-166a0c3e33cebc81ce9440a93042befa595e2a87.tar.xz
[Keep2shareCC] Fix CAPTCHA_PATTERN
Diffstat (limited to 'module/plugins')
-rw-r--r--module/plugins/hoster/Keep2shareCC.py19
1 files changed, 9 insertions, 10 deletions
diff --git a/module/plugins/hoster/Keep2shareCC.py b/module/plugins/hoster/Keep2shareCC.py
index 1da65f3c8..26a50bb61 100644
--- a/module/plugins/hoster/Keep2shareCC.py
+++ b/module/plugins/hoster/Keep2shareCC.py
@@ -11,13 +11,14 @@ from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo
class Keep2shareCC(SimpleHoster):
__name__ = "Keep2shareCC"
__type__ = "hoster"
- __version__ = "0.11"
+ __version__ = "0.12"
__pattern__ = r'https?://(?:www\.)?(keep2share|k2s|keep2s)\.cc/file/(?P<ID>\w+)'
__description__ = """Keep2share.cc hoster plugin"""
__license__ = "GPLv3"
- __authors__ = [("stickell", "l.stickell@yahoo.it")]
+ __authors__ = [("stickell", "l.stickell@yahoo.it"),
+ ("Walter Purcaro", "vuolter@gmail.com")]
FILE_NAME_PATTERN = r'File: <span>(?P<N>.+)</span>'
@@ -25,6 +26,7 @@ class Keep2shareCC(SimpleHoster):
OFFLINE_PATTERN = r'File not found or deleted|Sorry, this file is blocked or deleted|Error 404'
LINK_PATTERN = r'To download this file with slow speed, use <a href="([^"]+)">this link</a>'
+ CAPTCHA_PATTERN = r'src="(/file/captcha\.html.+?)"'
WAIT_PATTERN = r'Please wait ([\d:]+) to download this file'
MULTIDL_ERROR = r'Free account does not allow to download more than one file at the same time'
@@ -69,17 +71,14 @@ class Keep2shareCC(SimpleHoster):
def handleCaptcha(self):
- recaptcha = ReCaptcha(self)
+ m = re.search(self.CAPTCHA_PATTERN, self.html)
+ if m is None:
+ self.error("Captcha key not found")
- captcha_key = recaptcha.detect_key()
- if captcha_key is None:
- self.error("ReCaptcha key not found")
+ captcha_url = urljoin(self.base_url, m.group(1))
for _ in xrange(5):
- challenge, response = recaptcha.challenge(captcha_key)
- post_data = {'recaptcha_challenge_field': challenge,
- 'recaptcha_response_field': response,
- 'CaptchaForm%5Bcode%5D': '',
+ post_data = {'CaptchaForm[code]': self.decryptCaptcha(captcha_url),
'free': 1,
'freeDownloadRequest': 1,
'uniqueId': self.fid,