diff options
Diffstat (limited to 'pyload/plugins')
| -rw-r--r-- | pyload/plugins/crypter/FiletramCom.py | 31 | ||||
| -rw-r--r-- | pyload/plugins/crypter/TurbobitNetFolder.py | 60 | ||||
| -rw-r--r-- | pyload/plugins/crypter/XupPl.py | 18 | ||||
| -rw-r--r-- | pyload/plugins/hoster/GooIm.py | 51 | ||||
| -rw-r--r-- | pyload/plugins/hoster/Keep2shareCC.py | 89 | ||||
| -rw-r--r-- | pyload/plugins/hoster/RgHostNet.py | 28 | 
6 files changed, 277 insertions, 0 deletions
| diff --git a/pyload/plugins/crypter/FiletramCom.py b/pyload/plugins/crypter/FiletramCom.py new file mode 100644 index 000000000..886b8be30 --- /dev/null +++ b/pyload/plugins/crypter/FiletramCom.py @@ -0,0 +1,31 @@ +# -*- coding: utf-8 -*- + +############################################################################ +# This program is free software: you can redistribute it and/or modify     # +# it under the terms of the GNU Affero 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 Affero General Public License for more details.                      # +#                                                                          # +# You should have received a copy of the GNU Affero General Public License # +# along with this program.  If not, see <http://www.gnu.org/licenses/>.    # +############################################################################ + +from module.plugins.internal.SimpleCrypter import SimpleCrypter + + +class FiletramCom(SimpleCrypter): +    __name__ = "FiletramCom" +    __type__ = "crypter" +    __pattern__ = r"http://(?:www\.)?filetram.com/[^/]+/.+" +    __version__ = "0.01" +    __description__ = """Filetram.com Plugin""" +    __author_name__ = ("igel", "stickell") +    __author_mail__ = ("igelkun@myopera.com", "l.stickell@yahoo.it") + +    LINK_PATTERN = r"\s+(http://.+)" +    TITLE_PATTERN = r"<title>(?P<title>[^<]+) - Free Download[^<]*</title>" diff --git a/pyload/plugins/crypter/TurbobitNetFolder.py b/pyload/plugins/crypter/TurbobitNetFolder.py new file mode 100644 index 000000000..e172f8037 --- /dev/null +++ b/pyload/plugins/crypter/TurbobitNetFolder.py @@ -0,0 +1,60 @@ +# -*- coding: utf-8 -*- + +############################################################################ +# This program is free software: you can redistribute it and/or modify     # +# it under the terms of the GNU Affero 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 Affero General Public License for more details.                      # +#                                                                          # +# You should have received a copy of the GNU Affero General Public License # +# along with this program.  If not, see <http://www.gnu.org/licenses/>.    # +############################################################################ + +import math +import re + +from module.plugins.internal.SimpleCrypter import SimpleCrypter +from module.common.json_layer import json_loads + + +def format_links(fid): +    return 'http://turbobit.net/%s.html' % fid + + +class TurbobitNetFolder(SimpleCrypter): +    __name__ = "TurbobitNetFolder" +    __type__ = "crypter" +    __pattern__ = r"http://(?:w{3}.)?turbobit\.net/download/folder/(?P<id>\w+)" +    __version__ = "0.01" +    __description__ = """Turbobit.net Folder Plugin""" +    __author_name__ = ("stickell") +    __author_mail__ = ("l.stickell@yahoo.it") + +    TITLE_PATTERN = r"<img src='/js/lib/grid/icon/folder.png'>(?P<title>.+)</div>" + +    def getLinks(self): +        folder_id = re.search(self.__pattern__, self.pyfile.url).group('id') +        grid = self.load('http://turbobit.net/downloadfolder/gridFile', +                         get={'id_folder': folder_id, 'rows': 200}, decode=True) +        grid = json_loads(grid) + +        links_count = grid["records"] +        pages = int(math.ceil(links_count / 200.0)) + +        ids = list() +        for i in grid['rows']: +            ids.append(i['id']) + +        for p in range(2, pages + 1): +            grid = self.load('http://turbobit.net/downloadfolder/gridFile', +                             get={'id_folder': folder_id, 'rows': 200, 'page': p}, decode=True) +            grid = json_loads(grid) +            for i in grid['rows']: +                ids.append(i['id']) + +        return map(format_links, ids) diff --git a/pyload/plugins/crypter/XupPl.py b/pyload/plugins/crypter/XupPl.py new file mode 100644 index 000000000..09832f037 --- /dev/null +++ b/pyload/plugins/crypter/XupPl.py @@ -0,0 +1,18 @@ +from module.plugins.Crypter import Crypter + + +class XupPl(Crypter): +    __name__ = "XupPl" +    __type__ = "crypter" +    __pattern__ = r"https?://.*\.xup\.pl/.*" +    __version__ = "0.1" +    __description__ = """Xup.pl Crypter Plugin""" +    __author_name__ = ("z00nx") +    __author_mail__ = ("z00nx0@gmail.com") + +    def decrypt(self, pyfile): +        header = self.load(self.pyfile.url, just_header=True) +        if 'location' in header: +            self.core.files.addLinks([header['location']], self.pyfile.package().id) +        else: +            self.fail('Unable to find link') diff --git a/pyload/plugins/hoster/GooIm.py b/pyload/plugins/hoster/GooIm.py new file mode 100644 index 000000000..5a9d98396 --- /dev/null +++ b/pyload/plugins/hoster/GooIm.py @@ -0,0 +1,51 @@ +# -*- coding: utf-8 -*- + +############################################################################ +# This program is free software: you can redistribute it and/or modify     # +# it under the terms of the GNU Affero 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 Affero General Public License for more details.                      # +#                                                                          # +# You should have received a copy of the GNU Affero General Public License # +# along with this program.  If not, see <http://www.gnu.org/licenses/>.    # +############################################################################ + +import re + +from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo + + +class GooIm(SimpleHoster): +    __name__ = "GooIm" +    __type__ = "hoster" +    __pattern__ = r"http://(?:www\.)?goo\.im/.+" +    __version__ = "0.01" +    __description__ = """Goo.im hoster plugin""" +    __author_name__ = ("stickell") +    __author_mail__ = ("l.stickell@yahoo.it") + +    FILE_NAME_PATTERN = r'<h3>Filename: (?P<N>.+)</h3>' +    FILE_OFFLINE_PATTERN = r'The file you requested was not found' + +    def handleFree(self): +        self.html = self.load(self.pyfile.url) +        m = re.search(r'MD5sum: (?P<MD5>[0-9a-z]{32})</h3>', self.html) +        if m: +            self.check_data = {"md5": m.group('MD5')} +        self.setWait(10) +        self.wait() + +        header = self.load(self.pyfile.url, just_header=True) +        if header['location']: +            self.logDebug("Direct link: " + header['location']) +            self.download(header['location']) +        else: +            self.parseError("Unable to detect direct download link") + + +getInfo = create_getInfo(GooIm) diff --git a/pyload/plugins/hoster/Keep2shareCC.py b/pyload/plugins/hoster/Keep2shareCC.py new file mode 100644 index 000000000..9bdbad6fa --- /dev/null +++ b/pyload/plugins/hoster/Keep2shareCC.py @@ -0,0 +1,89 @@ +# -*- coding: utf-8 -*- + +############################################################################ +# This program is free software: you can redistribute it and/or modify     # +# it under the terms of the GNU Affero 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 Affero General Public License for more details.                      # +#                                                                          # +# You should have received a copy of the GNU Affero General Public License # +# along with this program.  If not, see <http://www.gnu.org/licenses/>.    # +############################################################################ + +import re + +from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo +from module.plugins.ReCaptcha import ReCaptcha + + +class Keep2shareCC(SimpleHoster): +    __name__ = "Keep2shareCC" +    __type__ = "hoster" +    __pattern__ = r"http://(?:www\.)?keep2share\.cc/file/\w+" +    __version__ = "0.02" +    __description__ = """Keep2share.cc hoster plugin""" +    __author_name__ = ("stickell") +    __author_mail__ = ("l.stickell@yahoo.it") + +    FILE_NAME_PATTERN = r'File: <span>(?P<N>.+)</span>' +    FILE_SIZE_PATTERN = r'Size: (?P<S>[^<]+)</div>' +    FILE_OFFLINE_PATTERN = r'File not found or deleted|Sorry, this file is blocked or deleted' + +    DIRECT_LINK_PATTERN = r'To download this file with slow speed, use <a href="([^"]+)">this link</a>' +    WAIT_PATTERN = r'Please wait ([\d:]+) to download this file' + +    RECAPTCHA_KEY = '6LcYcN0SAAAAABtMlxKj7X0hRxOY8_2U86kI1vbb' + +    def handleFree(self): +        fid = re.search(r'<input type="hidden" name="slow_id" value="([^"]+)">', self.html).group(1) +        self.html = self.load(self.pyfile.url, post={'yt0': '', 'slow_id': fid}) + +        m = re.search(self.WAIT_PATTERN, self.html) +        if m: +            wait_string = m.group(1) +            wait_time = int(wait_string[0:2]) * 3600 + int(wait_string[3:5]) * 60 + int(wait_string[6:8]) +            self.setWait(wait_time, True) +            self.wait() +            self.process(self.pyfile) + +        recaptcha = ReCaptcha(self) +        for i in xrange(5): +            challenge, response = recaptcha.challenge(self.RECAPTCHA_KEY) +            post_data = {'recaptcha_challenge_field': challenge, +                         'recaptcha_response_field': response, +                         'CaptchaForm%5Bcode%5D': '', +                         'free': 1, +                         'freeDownloadRequest': 1, +                         'uniqueId': fid, +                         'yt0': ''} + +            self.html = self.load(self.pyfile.url, post=post_data) + +            if 'recaptcha' not in self.html: +                self.correctCaptcha() +                self.setWait(30) +                self.wait() +                break +            else: +                self.logInfo('Wrong captcha') +                self.invalidCaptcha() +        else: +            self.fail("All captcha attempts failed") + +        self.html = self.load(self.pyfile.url, post={'uniqueId': fid, 'free': 1}) + +        dl = 'http://keep2share.cc' +        m = re.search(self.DIRECT_LINK_PATTERN, self.html) +        if not m: +            self.parseError("Unable to detect direct link") +        dl += m.group(1) +        self.logDebug('Direct Link: ' + dl) +        self.download(dl, disposition=True) + + +getInfo = create_getInfo(Keep2shareCC) diff --git a/pyload/plugins/hoster/RgHostNet.py b/pyload/plugins/hoster/RgHostNet.py new file mode 100644 index 000000000..a46b51733 --- /dev/null +++ b/pyload/plugins/hoster/RgHostNet.py @@ -0,0 +1,28 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +import re +from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo + + +class RgHostNet(SimpleHoster): +    __name__ = "RgHostNet" +    __type__ = "hoster" +    __pattern__ = r"http://(?:www\.)?rghost\.net/\d+(?:r=\d+)?" +    __version__ = "0.01" +    __description__ = """RgHost.net Download Hoster""" +    __author_name__ = ("z00nx") +    __author_mail__ = ("z00nx0@gmail.com") + +    FILE_INFO_PATTERN = r'<h1>\s+(<a[^>]+>)?(?P<N>[^<]+)(</a>)?\s+<small[^>]+>\s+\((?P<S>[^)]+)\)\s+</small>\s+</h1>' +    FILE_OFFLINE_PATTERN = r'File is deleted|this page is not found' +    DOWNLOAD_LINK_PATTERN = '''<a\s+href="([^"]+)"\s+class="btn\s+large\s+download"[^>]+>Download</a>''' + +    def handleFree(self): +        found = re.search(self.DOWNLOAD_LINK_PATTERN, self.html) +        if not found: +            self.parseError("Unable to detect the direct link") +        download_link = found.group(1) +        self.download(download_link, disposition=True) + +getInfo = create_getInfo(RgHostNet) | 
