diff options
| author | 2015-02-16 10:46:28 +0100 | |
|---|---|---|
| committer | 2015-02-16 10:46:28 +0100 | |
| commit | ce1c2b6b05c08b669357947e61ae40efce7fc50f (patch) | |
| tree | 0b5f7996960cf35c4eface53a89eba18a37519b7 /module/plugins/crypter/LixIn.py | |
| parent | Fix filename case (diff) | |
| download | pyload-ce1c2b6b05c08b669357947e61ae40efce7fc50f.tar.xz | |
module temp
Diffstat (limited to 'module/plugins/crypter/LixIn.py')
| -rw-r--r-- | module/plugins/crypter/LixIn.py | 62 | 
1 files changed, 62 insertions, 0 deletions
| diff --git a/module/plugins/crypter/LixIn.py b/module/plugins/crypter/LixIn.py new file mode 100644 index 000000000..0b4329d35 --- /dev/null +++ b/module/plugins/crypter/LixIn.py @@ -0,0 +1,62 @@ +# -*- coding: utf-8 -*- + +import re + +from pyload.plugin.Crypter import Crypter + + +class LixIn(Crypter): +    __name__    = "LixIn" +    __type__    = "crypter" +    __version__ = "0.22" + +    __pattern__ = r'http://(?:www\.)?lix\.in/(?P<ID>.+)' +    __config__  = [("use_subfolder", "bool", "Save package to subfolder", True), +                   ("subfolder_per_package", "bool", "Create a subfolder for each package", True)] + +    __description__ = """Lix.in decrypter plugin""" +    __license__     = "GPLv3" +    __authors__     = [("spoob", "spoob@pyload.org")] + + +    CAPTCHA_PATTERN = r'<img src="(?P<image>captcha_img\.php\?.*?)"' +    SUBMIT_PATTERN = r'value=\'continue.*?\'' +    LINK_PATTERN = r'name="ifram" src="(?P<link>.*?)"' + + +    def decrypt(self, pyfile): +        url = pyfile.url + +        m = re.match(self.__pattern__, url) +        if m is None: +            self.error(_("Unable to identify file ID")) + +        id = m.group("ID") +        self.logDebug("File id is %s" % id) + +        self.html = self.load(url, decode=True) + +        m = re.search(self.SUBMIT_PATTERN, self.html) +        if m is None: +            self.error(_("Link doesn't seem valid")) + +        m = re.search(self.CAPTCHA_PATTERN, self.html) +        if m: +            for _i in xrange(5): +                m = re.search(self.CAPTCHA_PATTERN, self.html) +                if m: +                    self.logDebug("Trying captcha") +                    captcharesult = self.decryptCaptcha("http://lix.in/" + m.group("image")) +                self.html = self.load(url, decode=True, +                                          post={"capt": captcharesult, "submit": "submit", "tiny": id}) +            else: +                self.logDebug("No captcha/captcha solved") +        else: +            self.html = self.load(url, decode=True, post={"submit": "submit", "tiny": id}) + +        m = re.search(self.LINK_PATTERN, self.html) +        if m is None: +            self.error(_("Unable to find destination url")) +        else: +            self.urls = [m.group("link")] +            self.logDebug("Found link %s, adding to package" % self.urls[0]) | 
