diff options
Diffstat (limited to 'module')
| -rw-r--r-- | module/plugins/accounts/FilefactoryCom.py | 28 | ||||
| -rw-r--r-- | module/plugins/accounts/UploadheroCom.py | 35 | ||||
| -rw-r--r-- | module/plugins/hoster/GigapetaCom.py | 73 | ||||
| -rw-r--r-- | module/plugins/hoster/UploadheroCom.py | 79 | ||||
| -rw-r--r-- | module/plugins/hoster/WrzucTo.py | 58 | 
5 files changed, 259 insertions, 14 deletions
| diff --git a/module/plugins/accounts/FilefactoryCom.py b/module/plugins/accounts/FilefactoryCom.py index 8c04cf49b..73431b546 100644 --- a/module/plugins/accounts/FilefactoryCom.py +++ b/module/plugins/accounts/FilefactoryCom.py @@ -23,32 +23,32 @@ from time import mktime, strptime  class FilefactoryCom(Account):      __name__ = "FilefactoryCom" -    __version__ = "0.1" +    __version__ = "0.11"      __type__ = "account"      __description__ = """filefactory.com account plugin"""      __author_name__ = ("zoidberg")      __author_mail__ = ("zoidberg@mujmail.cz") -    ACCOUNT_INFO_PATTERN = r'Your account is valid until the <strong>(.*?)</strong>'  - -    def loadAccountInfo(self, user, req): -        premium = False -        validuntil = -1 -         -        html = req.load("http://filefactory.com/member/") -        if "You are a FileFactory Premium Member" in html: +    ACCOUNT_INFO_PATTERN = r'"greenText">Premium member until<.*?datetime="(.*?)"' + +    def loadAccountInfo(self, user, req):       +        html = req.load("http://www.filefactory.com/member/") +             +        found = re.search(self.ACCOUNT_INFO_PATTERN, html) +        if found:              premium = True -            found = re.search(self.ACCOUNT_INFO_PATTERN, html) -            if found: -                validuntil = mktime(strptime(re.sub(r"(\d)[a-z]{2} ", r"\1 ", found.group(1)),"%d %B, %Y"))  +            validuntil = mktime(strptime(re.sub(r"(\d)[a-z]{2} ", r"\1 ", found.group(1)),"%d %B, %Y")) +        else: +            premium = False +            validuntil = -1             return {"premium": premium, "trafficleft": -1, "validuntil": validuntil}      def login(self, user, data, req): -        html = req.load("http://filefactory.com/member/login.php", post={ +        html = req.load("http://www.filefactory.com/member/login.php", post={              "email": user,               "password": data["password"],              "redirect": "/"}) -        if not re.search(r'location:.*?\?login=1', req.http.header, re.I): +        if '/member/login.php?err=1' in req.http.header:              self.wrongPassword()
\ No newline at end of file diff --git a/module/plugins/accounts/UploadheroCom.py b/module/plugins/accounts/UploadheroCom.py new file mode 100644 index 000000000..f1e0649e6 --- /dev/null +++ b/module/plugins/accounts/UploadheroCom.py @@ -0,0 +1,35 @@ +#!/usr/bin/env python
 +# -*- coding: utf-8 -*-
 +
 +from module.plugins.Account import Account
 +import re,datetime,time
 +
 +class UploadheroCom(Account):
 +    __name__ = "UploadheroCom"
 +    __version__ = "0.1"
 +    __type__ = "account"
 +    __description__ = """Uploadhero.com account plugin"""
 +    __author_name__ = ("mcmyst")
 +    __author_mail__ = ("mcmyst@hotmail.fr")
 +
 +
 +    def loadAccountInfo(self, user, req):
 +        premium_pattern = re.compile('Il vous reste <span class="bleu">([0-9]+)</span> jours premium.')
 +
 +        data = self.getAccountData(user)
 +        page = req.load("http://uploadhero.com/my-account")
 +
 +        if premium_pattern.search(page):
 +                end_date = datetime.date.today() + datetime.timedelta(days=int(premium_pattern.search(page).group(1)))
 +                end_date = time.mktime(future.timetuple())
 +                account_info = {"validuntil": end_date, "trafficleft": -1, "premium": True}
 +        else:
 +                account_info = {"validuntil": -1, "trafficleft": -1, "premium": False}
 +
 +        return account_info
 +
 +    def login(self, user, data, req):
 +        page = req.load("http://uploadhero.com/lib/connexion.php", post={"pseudo_login": user, "password_login": data["password"]})
 +
 +        if "mot de passe invalide" in page:
 +            self.wrongPassword()
\ No newline at end of file diff --git a/module/plugins/hoster/GigapetaCom.py b/module/plugins/hoster/GigapetaCom.py new file mode 100644 index 000000000..28ba35abe --- /dev/null +++ b/module/plugins/hoster/GigapetaCom.py @@ -0,0 +1,73 @@ +# -*- 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 <http://www.gnu.org/licenses/>. + +    @author: zoidberg +""" + +import re +from random import randint +from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo +from pycurl import FOLLOWLOCATION + +class GigapetaCom(SimpleHoster): +    __name__ = "GigapetaCom" +    __type__ = "hoster" +    __pattern__ = r"http://(?:www\.)?gigapeta\.com/dl/\w+" +    __version__ = "0.01" +    __description__ = """GigaPeta.com plugin - free only""" +    __author_name__ = ("zoidberg") +    __author_mail__ = ("zoidberg@mujmail.cz") + +    SH_COOKIES = [("http://gigapeta.com", "lang", "us")] +    FILE_NAME_PATTERN = r'<img src=".*" alt="file" />-->\s*(?P<N>.*?)\s*</td>' +    FILE_SIZE_PATTERN = r'<th>\s*Size\s*</th>\s*<td>\s*(?P<S>.*?)\s*</td>' +    FILE_OFFLINE_PATTERN = r'<div id="page_error">' +     +    def handleFree(self):        +        captcha_key = str(randint(1,100000000)) +        captcha_url = "http://gigapeta.com/img/captcha.gif?x=%s" % captcha_key +                +        self.req.http.c.setopt(FOLLOWLOCATION, 0) +         +        for i in range(5): +            self.checkErrors() +             +            captcha = self.decryptCaptcha(captcha_url)     +            self.html = self.load(self.pyfile.url, post = { +                "captcha_key": captcha_key,  +                "captcha": captcha, +                "download": "Download"}) +             +            found = re.search(r"Location\s*:\s*(.*)", self.req.http.header, re.I) +            if found: +                download_url = found.group(1)                 +                break           +            elif "Entered figures don`t coincide with the picture" in self.html: +                self.invalidCaptcha()             +        else: +            self.fail("No valid captcha code entered")                   +         +        self.req.http.c.setopt(FOLLOWLOCATION, 1) +        self.logDebug("Download URL: %s" % download_url) +        self.download(download_url) +              +    def checkErrors(self): +        if "All threads for IP" in self.html: +            self.logDebug("Your IP is already downloading a file - wait and retry") +            self.setWait(300, True) +            self.wait() +            self.retry() +         +getInfo = create_getInfo(GigapetaCom)
\ No newline at end of file diff --git a/module/plugins/hoster/UploadheroCom.py b/module/plugins/hoster/UploadheroCom.py new file mode 100644 index 000000000..dd43d76b9 --- /dev/null +++ b/module/plugins/hoster/UploadheroCom.py @@ -0,0 +1,79 @@ +# -*- 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 <http://www.gnu.org/licenses/>. + +    @author: zoidberg +""" + +import re +from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo + +class UploadheroCom(SimpleHoster): +    __name__ = "UploadheroCom" +    __type__ = "hoster" +    __pattern__ = r"http://(?:www\.)?uploadhero\.com/dl/\w+" +    __version__ = "0.11" +    __description__ = """UploadHero.com plugin""" +    __author_name__ = ("mcmyst", "zoidberg") +    __author_mail__ = ("mcmyst@hotmail.fr", "zoidberg@mujmail.cz") + +    SH_COOKIES = [("http://uploadhero.com", "lang", "en")] +    FILE_NAME_PATTERN = r'<div class="nom_de_fichier">(?P<N>.*?)</div>' +    FILE_SIZE_PATTERN = r'Taille du fichier : </span><strong>(?P<S>.*?)</strong>' +    FILE_OFFLINE_PATTERN = r'<p class="titre_dl_2">|<div class="raison"><strong>Le lien du fichier ci-dessus n\'existe plus.' +     +    DOWNLOAD_URL_PATTERN = r'<a href="([^"]+)" id="downloadnow"' +     +    IP_WAIT_PATTERN = r'/lightbox_block_download\.php\?min=(\d+)\&sec=(\d+)"' +    CAPTCHA_PATTERN = r'"(/captchadl\.php\?[a-z0-9]+)"' +    DL_URL_PATTERN = r'var magicomfg = \'<a href="(http://[^<>"]*?)"|"(http://storage\d+\.uploadhero\.com/\?d=[A-Za-z0-9]+/[^<>"/]+)"' +     +    def handleFree(self): +        self.checkErrors()  +         +        found = re.search(self.CAPTCHA_PATTERN, self.html) +        if not found: self.parseError("Captcha URL") +        captcha_url = "http://uploadhero.com" + found.group(1) +                       +        for i in range(5): +            captcha = self.decryptCaptcha(captcha_url)     +            self.html = self.load(self.pyfile.url, get = {"code": captcha}) +            found = re.search(self.DL_URL_PATTERN, self.html)  +            if found: +                self.correctCaptcha() +                download_url = found.group(1) or found.group(2) +                break +            else: +                self.invalidCaptcha() +        else: +            self.fail("No valid captcha code entered")                   +         +        self.download(download_url) +     +    def handlePremium(self): +        self.log.debug("%s: Use Premium Account" % self.__name__) +        self.html = self.load(self.pyfile.url) +        link = re.search(self.DOWNLOAD_URL_PATTERN, self.html).group(1) +        self.log.debug("Downloading link : '%s'" % link) +        self.download(link)  +              +    def checkErrors(self): +        found = re.search(self.IP_WAIT_PATTERN, self.html) +        if found: +            wait_time = 30 * 60 - int(found.group(1)) * 60 - int(found.group(2)) +            self.setWait(wait_time, True) +            self.wait() +            self.retry() +         +getInfo = create_getInfo(UploadheroCom)
\ No newline at end of file diff --git a/module/plugins/hoster/WrzucTo.py b/module/plugins/hoster/WrzucTo.py new file mode 100644 index 000000000..4a5e89f22 --- /dev/null +++ b/module/plugins/hoster/WrzucTo.py @@ -0,0 +1,58 @@ +# -*- 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 <http://www.gnu.org/licenses/>. + +    @author: zoidberg +""" + +import re +from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo +from pycurl import HTTPHEADER + +class WrzucTo(SimpleHoster): +    __name__ = "WrzucTo" +    __type__ = "hoster" +    __pattern__ = r"http://(?:\w+\.)*?wrzuc\.to/([a-zA-Z0-9]+(\.wt|\.html)|(\w+/?linki/[a-zA-Z0-9]+))" +    __version__ = "0.01" +    __description__ = """Wrzuc.to plugin - free only""" +    __author_name__ = ("zoidberg") +    __author_mail__ = ("zoidberg@mujmail.cz") + +    SH_COOKIES = [("http://www.wrzuc.to", "language", "en")]    +    FILE_SIZE_PATTERN = r'class="info">\s*<tr>\s*<td>(?P<S>.*?)</td>' +    FILE_NAME_PATTERN = r'id="file_info">\s*<strong>(?P<N>.*?)</strong>' +     +    def setup(self): +        self.multiDL = True  +     +    def handleFree(self): +        data = dict(re.findall(r'(md5|file): "(.*?)"', self.html)) +        if len(data) != 2: self.parseError('File ID') +         +        self.req.http.c.setopt(HTTPHEADER, ["X-Requested-With: XMLHttpRequest"]) +        self.req.http.lastURL = self.pyfile.url +        self.load("http://www.wrzuc.to/ajax/server/prepair", post = {"md5": data['md5']}) +         +        self.req.http.lastURL = self.pyfile.url +        self.html = self.load("http://www.wrzuc.to/ajax/server/download_link", post = {"file": data['file']}) +         +        data.update(re.findall(r'"(download_link|server_id)":"(.*?)"', self.html)) +        if len(data) != 4: self.parseError('Download URL') +         +        download_url = "http://%s.wrzuc.to/pobierz/%s" % (data['server_id'], data['download_link'])        +        self.logDebug("Download URL: %s" % download_url)         +        self.download(download_url) +         +getInfo = create_getInfo(WrzucTo) + | 
