summaryrefslogtreecommitdiffstats
path: root/module
diff options
context:
space:
mode:
authorGravatar Nitzo <nitzo2001@yahoo.com> 2016-06-23 23:22:17 +0200
committerGravatar Nitzo <nitzo2001@yahoo.com> 2016-06-23 23:22:17 +0200
commit1fb6d370349b66ca6c033274272fcb2195b13a3c (patch)
tree18853ecf42c2b26a89077bf14231b66a4f7483df /module
parent[YoutubeCom] fix #2515 (diff)
downloadpyload-1fb6d370349b66ca6c033274272fcb2195b13a3c.tar.xz
[RelinkUs] fix #2513
Diffstat (limited to 'module')
-rw-r--r--module/plugins/crypter/RelinkUs.py86
1 files changed, 49 insertions, 37 deletions
diff --git a/module/plugins/crypter/RelinkUs.py b/module/plugins/crypter/RelinkUs.py
index e6f764119..7cf4bf3cf 100644
--- a/module/plugins/crypter/RelinkUs.py
+++ b/module/plugins/crypter/RelinkUs.py
@@ -8,17 +8,18 @@ import re
import Crypto.Cipher.AES
+from module.plugins.internal.Captcha import Captcha
from module.plugins.internal.Crypter import Crypter
-from module.plugins.internal.misc import fsjoin
+from module.plugins.internal.misc import fsjoin, replace_patterns
class RelinkUs(Crypter):
__name__ = "RelinkUs"
__type__ = "crypter"
- __version__ = "3.18"
+ __version__ = "3.19"
__status__ = "testing"
- __pattern__ = r'http://(?:www\.)?relink\.us/(f/|((view|go)\.php\?id=))(?P<ID>.+)'
+ __pattern__ = r'http://(?:www\.)?relink\.(?:us|to)/(f/|((view|go)\.php\?id=))(?P<ID>.+)'
__config__ = [("activated" , "bool" , "Activated" , True ),
("use_premium" , "bool" , "Use premium account if available", True ),
("folder_per_package", "Default;Yes;No", "Create folder for each package" , "Default")]
@@ -29,39 +30,42 @@ class RelinkUs(Crypter):
("AndroKev", "neureither.kevin@gmail.com")]
+ URL_REPLACEMENTS = [(__pattern__ + '.*', r'http://www.relink.to/f/\g<ID>')]
+
PREFERRED_LINK_SOURCES = ["cnl2", "dlc", "web"]
OFFLINE_TOKEN = r'<title>Tattooside'
PASSWORD_TOKEN = r'container_password.php'
PASSWORD_ERROR_ROKEN = r'You have entered an incorrect password'
- PASSWORD_SUBMIT_URL = r'http://www.relink.us/container_password.php'
+ PASSWORD_SUBMIT_URL = r'http://www.relink.to/container_password.php'
CAPTCHA_TOKEN = r'container_captcha.php'
+ CAPTCHA_ID_PATTERN = r'id="captcha_id" value="(\w+?)"'
CAPTCHA_ERROR_ROKEN = r'You have solved the captcha wrong'
- CAPTCHA_IMG_URL = r'http://www.relink.us/core/captcha/circlecaptcha.php'
- CAPTCHA_SUBMIT_URL = r'http://www.relink.us/container_captcha.php'
+ CAPTCHA_IMG_URL = r'http://www.relink.to/core/captcha/circlecaptcha.php'
+ CAPTCHA_SUBMIT_URL = r'http://www.relink.to/container_captcha.php'
- FILE_TITLE_REGEX = r'<th>Title</th><td>(.*)</td></tr>'
+ FILE_TITLE_PATTERN = r'<th>Title</th><td>(.*)</td></tr>'
FILE_NOTITLE = r'No title'
- CNL2_FORM_REGEX = r'<form id="cnl_form-(.*?)</form>'
- CNL2_FORMINPUT_REGEX = r'<input.*?name="%s".*?value="(.*?)"'
+ CNL2_FORM_PATTERN = r'<form id="cnl_form-(.*?)</form>'
+ CNL2_FORMINPUT_PATTERN = r'<input.*?name="%s".*?value="(.*?)"'
CNL2_JK_KEY = "jk"
CNL2_CRYPTED_KEY = "crypted"
- DLC_LINK_REGEX = r'<a href=".*?" class="dlc_button" target="_blank">'
- DLC_DOWNLOAD_URL = r'http://www.relink.us/download.php'
+ DLC_LINK_PATTERN = r'<a href=".*?" class="dlc_button" target="_blank">'
+ DLC_DOWNLOAD_URL = r'http://www.relink.to/download.php'
- WEB_FORWARD_REGEX = r'getFile\(\'(.+)\'\)'
- WEB_FORWARD_URL = r'http://www.relink.us/frame.php'
- WEB_LINK_REGEX = r'<iframe name="Container" height="100%" frameborder="no" width="100%" src="(.+)"></iframe>'
+ WEB_FORWARD_PATTERN = r'getFile\(\'(.+)\'\)'
+ WEB_FORWARD_URL = r'http://www.relink.to/frame.php'
+ WEB_LINK_PATTERN = r'<iframe name="Container" height="100%" frameborder="no" width="100%" src="(.+)"></iframe>'
def setup(self):
- self.fileid = None
+ self.file_id = None
self.package = None
- self.captcha = False
+ self.captcha = Captcha(self.pyfile)
def decrypt(self, pyfile):
@@ -81,12 +85,11 @@ class RelinkUs(Crypter):
self.handle_errors()
if self.is_captcha_protected():
- self.captcha = True
self.unlock_captcha_protection()
self.handle_errors()
#: Get package name and folder
- (pack_name, folder_name) = self.get_package_info()
+ pack_name, folder_name = self.get_package_info()
#: Extract package links
pack_links = []
@@ -102,7 +105,8 @@ class RelinkUs(Crypter):
def init_package(self, pyfile):
- self.fileid = re.match(self.__pattern__, pyfile.url).group('ID')
+ pyfile.url = replace_patterns(pyfile.url, self.URL_REPLACEMENTS)
+ self.file_id = re.match(self.__pattern__, pyfile.url).group('ID')
self.package = pyfile.package()
@@ -136,26 +140,34 @@ class RelinkUs(Crypter):
self.log_debug("Submitting password [%s] for protected links" % password)
if password:
- passwd_url = self.PASSWORD_SUBMIT_URL + "?id=%s" % self.fileid
- passwd_data = {'id': self.fileid, 'password': password, 'pw': 'submit'}
+ passwd_url = self.PASSWORD_SUBMIT_URL + "?id=%s" % self.file_id
+ passwd_data = {'id': self.file_id, 'password': password, 'pw': 'submit'}
self.data = self.load(passwd_url, post=passwd_data)
def unlock_captcha_protection(self):
self.log_debug("Request user positional captcha resolving")
- captcha_img_url = self.CAPTCHA_IMG_URL + "?id=%s" % self.fileid
- coords = self.captcha.decrypt(captcha_img_url, input_type="png", output_type='positional', ocr="CircleCaptcha")
- self.log_debug("Captcha resolved, coords %s" % coords)
- captcha_post_url = self.CAPTCHA_SUBMIT_URL + "?id=%s" % self.fileid
- captcha_post_data = {'button.x': coords[0], 'button.y': coords[1], 'captcha': 'submit'}
- self.data = self.load(captcha_post_url, post=captcha_post_data)
+ captcha_id = re.search(self.CAPTCHA_ID_PATTERN, self.data).group(1)
+
+ coords = self.captcha.decrypt(self.CAPTCHA_IMG_URL, get={'id': captcha_id}, input_type="png", output_type='positional') # , ocr="CircleCaptcha")
+ self.log_debug("Captcha resolved, coords (%s,%s)" % (coords[0], coords[1]))
+
+ self.data = self.load(self.CAPTCHA_SUBMIT_URL,
+ # ref=self.CAPTCHA_SUBMIT_URL + "&id=" + self.file_id,
+ get={'id': self.file_id},
+ post={'button.x' : coords[0],
+ 'button.y' : coords[1],
+ 'captcha_id' : captcha_id,
+ 'captcha_type': "RelinkCircle",
+ 'captcha' : "submit"})
def get_package_info(self):
name = folder = None
#: Try to get info from web
- m = re.search(self.FILE_TITLE_REGEX, self.data)
+ # self.data = self.load(self.pyfile.url)
+ m = re.search(self.FILE_TITLE_PATTERN, self.data)
if m is not None:
title = m.group(1).strip()
if not self.FILE_NOTITLE in title:
@@ -176,7 +188,7 @@ class RelinkUs(Crypter):
if self.PASSWORD_ERROR_ROKEN in self.data:
self.fail(_("Wrong password"))
- if self.captcha:
+ if self.captcha.task:
if self.CAPTCHA_ERROR_ROKEN in self.data:
self.retry_captcha()
else:
@@ -197,7 +209,7 @@ class RelinkUs(Crypter):
def handle_CNL2Links(self):
self.log_debug("Search for CNL2 links")
pack_links = []
- m = re.search(self.CNL2_FORM_REGEX, self.data, re.S)
+ m = re.search(self.CNL2_FORM_PATTERN, self.data, re.S)
if m is not None:
cnl2_form = m.group(1)
try:
@@ -214,13 +226,13 @@ class RelinkUs(Crypter):
def handle_DLC_links(self):
self.log_debug("Search for DLC links")
pack_links = []
- m = re.search(self.DLC_LINK_REGEX, self.data)
+ m = re.search(self.DLC_LINK_PATTERN, self.data)
if m is not None:
- container_url = self.DLC_DOWNLOAD_URL + "?id=%s&dlc=1" % self.fileid
+ container_url = self.DLC_DOWNLOAD_URL + "?id=%s&dlc=1" % self.file_id
self.log_debug("Downloading DLC container link [%s]" % container_url)
try:
dlc = self.load(container_url)
- dlc_filename = self.fileid + ".dlc"
+ dlc_filename = self.file_id + ".dlc"
dlc_filepath = fsjoin(self.pyload.config.get('general', 'download_folder'), dlc_filename)
with open(dlc_filepath, "wb") as f:
f.write(dlc)
@@ -236,7 +248,7 @@ class RelinkUs(Crypter):
self.log_debug("Search for WEB links")
pack_links = []
- params = re.findall(self.WEB_FORWARD_REGEX, self.data)
+ params = re.findall(self.WEB_FORWARD_PATTERN, self.data)
self.log_debug("Decrypting %d Web links" % len(params))
@@ -247,7 +259,7 @@ class RelinkUs(Crypter):
self.log_debug("Decrypting Web link %d, %s" % (index + 1, url))
res = self.load(url)
- link = re.search(self.WEB_LINK_REGEX, res).group(1)
+ link = re.search(self.WEB_LINK_PATTERN, res).group(1)
pack_links.append(link)
@@ -261,11 +273,11 @@ class RelinkUs(Crypter):
def _get_cipher_params(self, cnl2_form):
#: Get jk
- jk_re = self.CNL2_FORMINPUT_REGEX % self.CNL2_JK_KEY
+ jk_re = self.CNL2_FORMINPUT_PATTERN % self.CNL2_JK_KEY
vjk = re.findall(jk_re, cnl2_form, re.I)
#: Get crypted
- crypted_re = self.CNL2_FORMINPUT_REGEX % RelinkUs.CNL2_CRYPTED_KEY
+ crypted_re = self.CNL2_FORMINPUT_PATTERN % RelinkUs.CNL2_CRYPTED_KEY
vcrypted = re.findall(crypted_re, cnl2_form, re.I)
#: Log and return