# -*- coding: utf-8 -*-
############################################################################
# This program is free software: you can redistribute it and/or modify #
# it under the terms of the GNU Affero General Public License as #
# published by the Free Software Foundation, either version 3 of the #
# License, or (at your option) any later version. #
# #
# This program is distributed in the hope that it will be useful, #
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
# GNU Affero General Public License for more details. #
# #
# You should have received a copy of the GNU Affero General Public License #
# along with this program. If not, see . #
############################################################################
# Test links (random.bin):
# http://k2s.cc/file/527111edfb9ba/random.bin
import re
from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo
from module.plugins.internal.CaptchaService import ReCaptcha
class Keep2shareCC(SimpleHoster):
__name__ = "Keep2shareCC"
__type__ = "hoster"
__pattern__ = r"https?://(?:www\.)?(keep2share|k2s|keep2s)\.cc/file/(?P[a-zA-Z0-9]{13})"
__version__ = "0.05"
__description__ = """Keep2share.cc hoster plugin"""
__author_name__ = ("stickell")
__author_mail__ = ("l.stickell@yahoo.it")
FILE_NAME_PATTERN = r'File: (?P.+)'
FILE_SIZE_PATTERN = r'Size: (?P[^<]+)'
FILE_OFFLINE_PATTERN = r'File not found or deleted|Sorry, this file is blocked or deleted'
DIRECT_LINK_PATTERN = r'To download this file with slow speed, use this link'
WAIT_PATTERN = r'Please wait ([\d:]+) to download this file'
RECAPTCHA_KEY = '6LcYcN0SAAAAABtMlxKj7X0hRxOY8_2U86kI1vbb'
FILE_URL_REPLACEMENTS = [(__pattern__, r"http://www.keep2share.cc/file/\g")]
def handleFree(self):
fid = re.search(r'', self.html).group(1)
self.html = self.load(self.pyfile.url, post={'yt0': '', 'slow_id': fid})
m = re.search(self.WAIT_PATTERN, self.html)
if m:
wait_string = m.group(1)
wait_time = int(wait_string[0:2]) * 60 * 60 + int(wait_string[3:5]) * 60 + int(wait_string[6:8])
self.setWait(wait_time, True)
self.wait()
self.process(self.pyfile)
recaptcha = ReCaptcha(self)
for i in xrange(5):
challenge, response = recaptcha.challenge(self.RECAPTCHA_KEY)
post_data = {'recaptcha_challenge_field': challenge,
'recaptcha_response_field': response,
'CaptchaForm%5Bcode%5D': '',
'free': 1,
'freeDownloadRequest': 1,
'uniqueId': fid,
'yt0': ''}
self.html = self.load(self.pyfile.url, post=post_data)
if 'recaptcha' not in self.html:
self.correctCaptcha()
self.setWait(30)
self.wait()
break
else:
self.logInfo('Wrong captcha')
self.invalidCaptcha()
else:
self.fail("All captcha attempts failed")
self.html = self.load(self.pyfile.url, post={'uniqueId': fid, 'free': 1})
dl = 'http://keep2share.cc'
m = re.search(self.DIRECT_LINK_PATTERN, self.html)
if not m:
self.parseError("Unable to detect direct link")
dl += m.group(1)
self.logDebug('Direct Link: ' + dl)
self.download(dl, disposition=True)
getInfo = create_getInfo(Keep2shareCC)