# -*- coding: utf-8 -*-
"""
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, see .
@author: zoidberg
"""
import re
from module.plugins.Crypter import Crypter
class LinkdecrypterCom(Crypter):
__name__ = "LinkdecrypterCom"
__type__ = "crypter"
__version__ = "0.27"
__description__ = """linkdecrypter.com"""
__author_name__ = ("zoidberg", "flowlee")
TEXTAREA_PATTERN = r''
PASSWORD_PATTERN = r''
REDIR_PATTERN = r'(Click here if your browser does not redirect you).'
def decrypt(self, pyfile):
self.passwords = self.getPassword().splitlines()
# API not working anymore
new_links = self.decryptHTML()
if new_links:
self.core.files.addLinks(new_links, self.pyfile.package().id)
else:
self.fail('Could not extract any links')
def decryptAPI(self):
get_dict = {"t": "link", "url": self.pyfile.url, "lcache": "1"}
self.html = self.load('http://linkdecrypter.com/api', get=get_dict)
if self.html.startswith('http://'):
return self.html.splitlines()
if self.html == 'INTERRUPTION(PASSWORD)':
for get_dict['pass'] in self.passwords:
self.html = self.load('http://linkdecrypter.com/api', get=get_dict)
if self.html.startswith('http://'):
return self.html.splitlines()
self.logError('API', self.html)
if self.html == 'INTERRUPTION(PASSWORD)':
self.fail("No or incorrect password")
return None
def decryptHTML(self):
retries = 5
post_dict = {"link_cache": "on", "pro_links": self.pyfile.url, "modo_links": "text"}
self.html = self.load('http://linkdecrypter.com/', post=post_dict, cookies=True, decode=True)
while self.passwords or retries:
found = re.search(self.TEXTAREA_PATTERN, self.html, flags=re.DOTALL)
if found:
return [x for x in found.group(1).splitlines() if '[LINK-ERROR]' not in x]
found = re.search(self.CAPTCHA_PATTERN, self.html)
if found:
captcha_url = 'http://linkdecrypter.com/' + found.group(1)
result_type = "positional" if "getPos" in found.group(2) else "textual"
found = re.search(r"