diff options
Diffstat (limited to 'module/plugins/crypter')
| -rw-r--r-- | module/plugins/crypter/CCF.py | 42 | ||||
| -rw-r--r-- | module/plugins/crypter/HoerbuchIn.py | 8 | ||||
| -rw-r--r-- | module/plugins/crypter/HotfileFolderCom.py | 18 | ||||
| -rw-r--r-- | module/plugins/crypter/LinkList.py | 55 | ||||
| -rwxr-xr-x | module/plugins/crypter/OronComFolder.py | 28 | ||||
| -rw-r--r-- | module/plugins/crypter/RSDF.py | 49 | ||||
| -rw-r--r-- | module/plugins/crypter/XfilesharingProFolder.py | 34 | 
7 files changed, 216 insertions, 18 deletions
| diff --git a/module/plugins/crypter/CCF.py b/module/plugins/crypter/CCF.py new file mode 100644 index 000000000..ab7ff1099 --- /dev/null +++ b/module/plugins/crypter/CCF.py @@ -0,0 +1,42 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +import re +from urllib2 import build_opener + +from module.plugins.Crypter import Crypter +from module.lib.MultipartPostHandler import MultipartPostHandler + +from os import makedirs +from os.path import exists, join + +class CCF(Crypter): +    __name__ = "CCF" +    __version__ = "0.2" +    __pattern__ = r"(?!http://).*\.ccf$" +    __description__ = """CCF Container Convert Plugin""" +    __author_name__ = ("Willnix") +    __author_mail__ = ("Willnix@pyload.org") + +    def decrypt(self, pyfile): +     +        infile = pyfile.url.replace("\n", "") + +        opener = build_opener(MultipartPostHandler) +        params = {"src": "ccf", +            "filename": "test.ccf", +            "upload": open(infile, "rb")} +        tempdlc_content = opener.open('http://service.jdownloader.net/dlcrypt/getDLC.php', params).read() + +        download_folder = self.config['general']['download_folder'] +        location = download_folder #join(download_folder, self.pyfile.package().folder.decode(sys.getfilesystemencoding())) +        if not exists(location):  +            makedirs(location) +             +        tempdlc_name = join(location, "tmp_%s.dlc" % pyfile.name) +        tempdlc = open(tempdlc_name, "w") +        tempdlc.write(re.search(r'<dlc>(.*)</dlc>', tempdlc_content, re.DOTALL).group(1)) +        tempdlc.close() + +        self.packages.append((tempdlc_name, [tempdlc_name], tempdlc_name)) + diff --git a/module/plugins/crypter/HoerbuchIn.py b/module/plugins/crypter/HoerbuchIn.py index 4c26ba7f7..6f23b2eb9 100644 --- a/module/plugins/crypter/HoerbuchIn.py +++ b/module/plugins/crypter/HoerbuchIn.py @@ -10,7 +10,7 @@ class HoerbuchIn(Crypter):      __name__ = "HoerbuchIn"      __type__ = "container"      __pattern__ = r"http://(www\.)?hoerbuch\.in/(wp/horbucher/\d+/.+/|tp/out.php\?.+|protection/folder_\d+\.html)" -    __version__ = "0.6" +    __version__ = "0.7"      __description__ = """Hoerbuch.in Container Plugin"""      __author_name__ = ("spoob", "mkaay")      __author_mail__ = ("spoob@pyload.org", "mkaay@mkaay.de") @@ -46,10 +46,10 @@ class HoerbuchIn(Crypter):          src = self.req.load(url, post={"viewed": "adpg"})          links = [] -        pattern = re.compile("http://www\.hoerbuch\.in/protection/(\w+)/(.*?)\"") -        for hoster, lid in pattern.findall(src): +        pattern = re.compile(r'<div class="container"><a href="(.*?)"') +        for hoster_url in pattern.findall(src):              self.req.lastURL = url -            self.load("http://www.hoerbuch.in/protection/%s/%s" % (hoster, lid)) +            self.load(hoster_url)              links.append(self.req.lastEffectiveURL)          return links diff --git a/module/plugins/crypter/HotfileFolderCom.py b/module/plugins/crypter/HotfileFolderCom.py index 00771e2a3..ea7311e3c 100644 --- a/module/plugins/crypter/HotfileFolderCom.py +++ b/module/plugins/crypter/HotfileFolderCom.py @@ -9,17 +9,21 @@ class HotfileFolderCom(Crypter):      __name__ = "HotfileFolderCom"      __type__ = "crypter"      __pattern__ = r"http://(?:www\.)?hotfile.com/list/\w+/\w+" -    __version__ = "0.1" +    __version__ = "0.2"      __description__ = """HotfileFolder Download Plugin"""      __author_name__ = ("RaNaN")      __author_mail__ = ("RaNaN@pyload.org") -    def decrypt(self, pyfile): -        html = self.load(pyfile.url) +    def decryptURL(self, url): +        html = self.load(url) -        name = re.findall(r'<img src="/i/folder.gif" width="23" height="14" style="margin-bottom: -2px;" />([^<]+)', html, re.MULTILINE)[0].replace("/", "") -        new_links = re.findall(r'href="(http://(www.)?hotfile\.com/dl/\d+/[0-9a-zA-Z]+[^"]+)', html) +        new_links = [] +        for link in re.findall(r'href="(http://(www.)?hotfile\.com/dl/\d+/[0-9a-zA-Z]+[^"]+)', html): +            new_links.append(link[0]) -        new_links = [x[0] for x in new_links] +        if new_links: +            self.logDebug("Found %d new links" % len(new_links)) +            return new_links +        else: +            self.fail('Could not extract any links') -        self.packages.append((name, new_links, name))
\ No newline at end of file diff --git a/module/plugins/crypter/LinkList.py b/module/plugins/crypter/LinkList.py new file mode 100644 index 000000000..ebfa373eb --- /dev/null +++ b/module/plugins/crypter/LinkList.py @@ -0,0 +1,55 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +from module.plugins.Crypter import Crypter, Package + +class LinkList(Crypter): +    __name__ = "LinkList" +    __version__ = "0.11" +    __pattern__ = r".+\.txt$" +    __description__ = """Read Link Lists in txt format""" +    __author_name__ = ("spoob", "jeix") +    __author_mail__ = ("spoob@pyload.org", "jeix@hasnomail.com") + +    # method declaration is needed here +    def decryptURL(self, url): +        return Crypter.decryptURL(self, url) + +    def decryptFile(self, content): +        links = content.splitlines() + +        curPack = "default" +        packages = {curPack:[]} +         +        for link in links: +            link = link.strip() +            if not link: continue +             +            if link.startswith(";"): +                continue +            if link.startswith("[") and link.endswith("]"): +                # new package +                curPack = link[1:-1] +                packages[curPack] = [] +                continue +            packages[curPack].append(link) +         +        # empty packages fix +        delete = [] +         +        for key,value in packages.iteritems(): +            if not value: +                delete.append(key) +                 +        for key in delete: +            del packages[key] + +        urls = [] + +        for name, links in packages.iteritems(): +            if name == "default": +                urls.extend(links) +            else: +                urls.append(Package(name, links)) + +        return urls
\ No newline at end of file diff --git a/module/plugins/crypter/OronComFolder.py b/module/plugins/crypter/OronComFolder.py index 57b273163..726371966 100755 --- a/module/plugins/crypter/OronComFolder.py +++ b/module/plugins/crypter/OronComFolder.py @@ -8,25 +8,39 @@ class OronComFolder(Crypter):      __name__ = "OronComFolder"      __type__ = "crypter"      __pattern__ = r"http://(?:www\.)?oron.com/folder/\w+" -    __version__ = "0.1" +    __version__ = "0.2"      __description__ = """Oron.com Folder Plugin"""      __author_name__ = ("DHMH")      __author_mail__ = ("webmaster@pcProfil.de") -    FOLDER_PATTERN = r'<table width="100%" cellpadding="7" cellspacing="1" class="tbl2">(.*)</table>\n		</div>' +    FOLDER_PATTERN = r'<table(?:.*)class="tbl"(?:.*)>(?:.*)<table(?:.*)class="tbl2"(?:.*)>(?P<body>.*)</table>(?:.*)</table>'      LINK_PATTERN = r'<a href="([^"]+)" target="_blank">' -    def decrypt(self, pyfile): -        html = self.load(self.pyfile.url) +    def decryptURL(self, url): +        html = self.load(url)          new_links = [] +        if 'No such folder exist' in html: +            # Don't fail because if there's more than a folder for this package +            # and only one of them fails, no urls at all will be added. +            self.logWarning("Folder does not exist") +            return new_links +          folder = re.search(self.FOLDER_PATTERN, html, re.DOTALL) -        if folder is None: self.fail("Parse error (FOLDER)") +        if folder is None: +            # Don't fail because if there's more than a folder for this package +            # and only one of them fails, no urls at all will be added. +            self.logWarning("Parse error (FOLDER)") +            return new_links          new_links.extend(re.findall(self.LINK_PATTERN, folder.group(0)))          if new_links: -            self.core.files.addLinks(new_links, self.pyfile.package().id) +            self.logDebug("Found %d new links" % len(new_links)) +            return new_links          else: -            self.fail('Could not extract any links')
\ No newline at end of file +            # Don't fail because if there's more than a folder for this package +            # and only one of them fails, no urls at all will be added. +            self.logWarning('Could not extract any links') +            return new_links diff --git a/module/plugins/crypter/RSDF.py b/module/plugins/crypter/RSDF.py new file mode 100644 index 000000000..cbc9864b1 --- /dev/null +++ b/module/plugins/crypter/RSDF.py @@ -0,0 +1,49 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +import base64 +import binascii +import re + +from module.plugins.Crypter import Crypter + +class RSDF(Crypter): +    __name__ = "RSDF" +    __version__ = "0.21" +    __pattern__ = r".*\.rsdf" +    __description__ = """RSDF Container Decode Plugin""" +    __author_name__ = ("RaNaN", "spoob") +    __author_mail__ = ("RaNaN@pyload.org", "spoob@pyload.org") + +     +    def decrypt(self, pyfile): +     +        from Crypto.Cipher import AES + +        infile = pyfile.url.replace("\n", "") +        Key = binascii.unhexlify('8C35192D964DC3182C6F84F3252239EB4A320D2500000000') + +        IV = binascii.unhexlify('FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF') +        IV_Cipher = AES.new(Key, AES.MODE_ECB) +        IV = IV_Cipher.encrypt(IV) + +        obj = AES.new(Key, AES.MODE_CFB, IV) + +        rsdf = open(infile, 'r') + +        data = rsdf.read() +        rsdf.close() + +        if re.search(r"<title>404 - Not Found</title>", data) is None: +            data = binascii.unhexlify(''.join(data.split())) +            data = data.splitlines() + +            links = [] +            for link in data: +                link = base64.b64decode(link) +                link = obj.decrypt(link) +                decryptedUrl = link.replace('CCF: ', '') +                links.append(decryptedUrl) + +            self.log.debug("%s: adding package %s with %d links" % (self.__name__,pyfile.package().name,len(links))) +            self.packages.append((pyfile.package().name, links))         diff --git a/module/plugins/crypter/XfilesharingProFolder.py b/module/plugins/crypter/XfilesharingProFolder.py new file mode 100644 index 000000000..8e58c207d --- /dev/null +++ b/module/plugins/crypter/XfilesharingProFolder.py @@ -0,0 +1,34 @@ +# -*- coding: utf-8 -*-
 +
 +from module.plugins.Crypter import Crypter, Package
 +import re
 +
 +class XfilesharingProFolder(Crypter):
 +    __name__ = "XfilesharingProFolder"
 +    __type__ = "crypter"
 +    __pattern__ = r"http://(?:www\.)?((easybytez|turboupload|uploadville|file4safe|fileband|filebeep|grupload|247upload)\.com|(muchshare|annonhost).net|bzlink.us)/users/.*"  
 +    __version__ = "0.01"
 +    __description__ = """Generic XfilesharingPro Folder Plugin"""
 +    __author_name__ = ("zoidberg")
 +    __author_mail__ = ("zoidberg@mujmail.cz")
 +
 +    LINK_PATTERN = r'<div class="link"><a href="([^"]+)" target="_blank">[^<]*</a></div>'
 +    SUBFOLDER_PATTERN = r'<TD width="1%"><img src="[^"]*/images/folder2.gif"></TD><TD><a href="([^"]+)"><b>(?!\. \.<)([^<]+)</b></a></TD>' 
 +  
 +    def decryptURL(self, url):
 +        return self.decryptFile(self.load(url, decode = True))
 +
 +    def decryptFile(self, html):
 +        new_links = []
 +
 +        new_links.extend(re.findall(self.LINK_PATTERN, html))
 +        
 +        subfolders = re.findall(self.SUBFOLDER_PATTERN, html)
 +        #self.logDebug(subfolders)        
 +        for (url, name) in subfolders:
 +            if self.package: name = "%s/%s" % (self.package.name, name)                 
 +            new_links.append(Package(name, [url]))        
 +           
 +        if not new_links: self.fail('Could not extract any links')
 +    
 +        return new_links
\ No newline at end of file | 
