diff options
| author | 2013-01-14 18:42:56 +0100 | |
|---|---|---|
| committer | 2013-01-14 18:42:56 +0100 | |
| commit | 616c5d0e2357aeb985435e9ef0c1ead1b4feaf11 (patch) | |
| tree | f612e856aeabb1f255230c5347dad275ef1f8aa4 | |
| parent | Fixed offline regex (diff) | |
| parent | Merged in z00nx0/pyload/SecureUploadEu (pull request #47: Added SecureUploadE... (diff) | |
| download | pyload-616c5d0e2357aeb985435e9ef0c1ead1b4feaf11.tar.xz | |
Merged in z00nx0/pyload/CatShareNet (pull request #46: Added CatShareNet plugin)
| -rw-r--r-- | module/plugins/crypter/LetitbitNetFolder.py | 33 | ||||
| -rw-r--r-- | module/plugins/hoster/CloudzerNet.py | 65 | ||||
| -rw-r--r-- | module/plugins/hoster/SecureUploadEu.py | 18 | 
3 files changed, 116 insertions, 0 deletions
| diff --git a/module/plugins/crypter/LetitbitNetFolder.py b/module/plugins/crypter/LetitbitNetFolder.py new file mode 100644 index 000000000..68aad9dd7 --- /dev/null +++ b/module/plugins/crypter/LetitbitNetFolder.py @@ -0,0 +1,33 @@ +# -*- coding: utf-8 -*- + +import re +from module.plugins.Crypter import Crypter + + +class LetitbitNetFolder(Crypter): +    __name__ = "LetitbitNetFolder" +    __type__ = "crypter" +    __pattern__ = r"http://(?:www\.)?letitbit.net/folder/\w+" +    __version__ = "0.1" +    __description__ = """Letitbit.net Folder Plugin""" +    __author_name__ = ("DHMH", "z00nx") +    __author_mail__ = ("webmaster@pcProfil.de", "z00nx0@gmail.com") + +    FOLDER_PATTERN = r'<table>(.*)</table>' +    LINK_PATTERN = r'<a href="([^"]+)" target="_blank">' + +    def decrypt(self, pyfile): +        html = self.load(self.pyfile.url) + +        new_links = [] + +        folder = re.search(self.FOLDER_PATTERN, html, re.DOTALL) +        if folder is None: +            self.fail("Parse error (FOLDER)") + +        new_links.extend(re.findall(self.LINK_PATTERN, folder.group(0))) + +        if new_links: +            self.core.files.addLinks(new_links, self.pyfile.package().id) +        else: +            self.fail('Could not extract any links') diff --git a/module/plugins/hoster/CloudzerNet.py b/module/plugins/hoster/CloudzerNet.py new file mode 100644 index 000000000..74a61d038 --- /dev/null +++ b/module/plugins/hoster/CloudzerNet.py @@ -0,0 +1,65 @@ +# -*- coding: utf-8 -*- +import re +from module.plugins.internal.SimpleHoster import SimpleHoster, parseFileInfo +from module.common.json_layer import json_loads +from module.plugins.ReCaptcha import ReCaptcha +from module.network.RequestFactory import getURL + + +def getInfo(urls): +    for url in urls: +        header = getURL(url, just_header=True) +        if 'Location: http://cloudzer.net/404' in header: +            file_info = (url, 0, 1, url) +        else: +            file_info = parseFileInfo(CloudzerNet, url, getURL(url, decode=True)) +        yield file_info + + +class CloudzerNet(SimpleHoster): +    __name__ = "CloudzerNet" +    __type__ = "hoster" +    __pattern__ = r"http://(www\.)?(cloudzer\.net/file/|clz\.to/(file/)?)(?P<ID>\w+).*" +    __version__ = "0.01" +    __description__ = """Cloudzer.net hoster plugin""" +    __author_name__ = ("gs", "z00nx") +    __author_mail__ = ("I-_-I-_-I@web.de", "z00nx0@gmail.com") + +    FILE_INFO_PATTERN = '<b class="filename"[^>]+>(?P<N>[^<]+)</b>\s+<span class="size">(?P<S>[^<]+)</span>' +    WAIT_PATTERN = '<meta name="wait" content="(\d+)">' +    FILE_OFFLINE_PATTERN = r'Please check the URL for typing errors, respectively' +    CAPTCHA_KEY = '6Lcqz78SAAAAAPgsTYF3UlGf2QFQCNuPMenuyHF3' + +    def handleFree(self): +        found = re.search(self.WAIT_PATTERN, self.html) +        seconds = int(found.group(1)) +        self.logDebug("Found wait", seconds) +        self.setWait(seconds + 1) +        self.wait() +        response = self.load('http://cloudzer.net/io/ticket/slot/%s' % self.file_info['ID'], post=' ', cookies=True) +        self.logDebug("Download slot request response", response) +        response = json_loads(response) +        if response["succ"] is not True: +            self.fail("Unable to get a download slot") + +        recaptcha = ReCaptcha(self) +        challenge, response = recaptcha.challenge(self.CAPTCHA_KEY) +        post_data = {"recaptcha_challenge_field": challenge, "recaptcha_response_field": response} +        response = json_loads(self.load('http://cloudzer.net/io/ticket/captcha/%s' % self.file_info['ID'], post=post_data, cookies=True)) +        self.logDebug("Captcha check response", response) +        self.logDebug("First check") + +        if "err" in response: +            if response["err"] == "captcha": +                self.logDebug("Wrong captcha") +                self.invalidCaptcha() +                self.retry() +            elif "Sie haben die max" in response["err"] or "You have reached the max" in response["err"]: +                self.logDebug("Download limit reached, waiting an hour") +                self.setWait(3600) +                self.wait() +        if "type" in response: +            if response["type"] == "download": +                url = response["url"] +                self.logDebug("Download link", url) +                self.download(url, disposition=True) diff --git a/module/plugins/hoster/SecureUploadEu.py b/module/plugins/hoster/SecureUploadEu.py new file mode 100644 index 000000000..b9a900d96 --- /dev/null +++ b/module/plugins/hoster/SecureUploadEu.py @@ -0,0 +1,18 @@ +# -*- coding: utf-8 -*- +from module.plugins.hoster.XFileSharingPro import XFileSharingPro, create_getInfo + + +class SecureUploadEu(XFileSharingPro): +    __name__ = "SecureUploadEu" +    __type__ = "hoster" +    __pattern__ = r"http://(www\.)?secureupload\.eu/(\w){12}(/\w+)" +    __version__ = "0.01" +    __description__ = """SecureUpload.eu hoster plugin""" +    __author_name__ = ("z00nx") +    __author_mail__ = ("z00nx0@gmail.com") + +    HOSTER_NAME = "secureupload.eu" +    FILE_INFO_PATTERN = '<h3>Downloading (?P<N>[^<]+) \((?P<S>[^<]+)\)</h3>' +    FILE_OFFLINE_PATTERN = 'The file was removed|File Not Found' + +getInfo = create_getInfo(SecureUploadEu) | 
