diff options
Diffstat (limited to 'module')
| -rw-r--r-- | module/plugins/accounts/TusfilesNet.py | 69 | ||||
| -rw-r--r-- | module/plugins/hoster/DevhostSt.py | 49 | ||||
| -rw-r--r-- | module/plugins/hoster/DropboxCom.py | 42 | ||||
| -rw-r--r-- | module/plugins/hoster/KingfilesNet.py | 94 | 
4 files changed, 254 insertions, 0 deletions
| diff --git a/module/plugins/accounts/TusfilesNet.py b/module/plugins/accounts/TusfilesNet.py new file mode 100644 index 000000000..d7cdbaebb --- /dev/null +++ b/module/plugins/accounts/TusfilesNet.py @@ -0,0 +1,69 @@ +# -*- coding: utf-8 -*- + +import re + +from time import mktime, strptime, gmtime + +from module.plugins.Account import Account +from module.plugins.internal.SimpleHoster import parseHtmlForm +from module.utils import parseFileSize + + +class TusfilesNet(Account): +    __name__ = "TusfilesNet" +    __type__ = "account" +    __version__ = "0.01" + +    __description__ = """ Tusfile.net account plugin """ +    __author_name__ = "guidobelix" +    __author_mail__ = "guidobelix@hotmail.it" + +    VALID_UNTIL_PATTERN = r'<span class="label label-default">([^<]+)</span>' +    TRAFFIC_LEFT_PATTERN = r'<td><img src="//www.tusfiles.net/i/icon/meter.png" alt=""/></td>\n<td> (?P<S>[^<]+)</td>' + + +    def loadAccountInfo(self, user, req): +        html = req.load("http://www.tusfiles.net/?op=my_account", decode=True) + +        validuntil = None +        trafficleft = None +        premium = False + +        m = re.search(self.VALID_UNTIL_PATTERN, html) +        if m: +            expiredate = m.group(1) +            self.logDebug("Expire date: " + expiredate) + +            try: +                validuntil = mktime(strptime(expiredate, "%d %B %Y")) +            except Exception, e: +                self.logError(e) + +            if validuntil > mktime(gmtime()): +                premium = True +            else: +                premium = False +                validuntil = None + +        m = re.search(self.TRAFFIC_LEFT_PATTERN, html) +        if m: +            trafficleft = m.group(1) +            if "Unlimited" in trafficleft: +                trafficleft = -1 +            else: +                trafficleft = parseFileSize(trafficleft) * 1024 + +        return {'validuntil': validuntil, 'trafficleft': trafficleft, 'premium': premium} + + +    def login(self, user, data, req): +        html = req.load("http://www.tusfiles.net/login.html", decode=True) +        action, inputs = parseHtmlForm('name="FL"', html) +        inputs.update({'login': user, +                       'password': data['password'], +                       'redirect': "http://www.tusfiles.net/"}) + +        html = req.load("http://www.tusfiles.net/", post=inputs, decode=True) + +        if 'Incorrect Login or Password' in html or '>Error<' in html: +            self.wrongPassword() diff --git a/module/plugins/hoster/DevhostSt.py b/module/plugins/hoster/DevhostSt.py new file mode 100644 index 000000000..088ace93a --- /dev/null +++ b/module/plugins/hoster/DevhostSt.py @@ -0,0 +1,49 @@ +# -*- coding: utf-8 -*- +# +# Test links: +# http://d-h.st/mM8 + +import re + +from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo + + +class DevhostSt(SimpleHoster): +    __name__ = "Devhost" +    __type__ = "hoster" +    __version__ = "0.01" + +    __pattern__ = r'http://(?:www\.)?d-h\.st/\w+' + +    __description__ = """d-h.st hoster plugin""" +    __author_name__ = "zapp-brannigan" +    __author_mail__ = "fuerst.reinje@web.de" + + +    FILE_NAME_PATTERN = r'>Filename:</span> <div title="(?P<N>.+?)"' +    FILE_SIZE_PATTERN = r'>Size:</span> (?P<S>[\d.]+) (?P<U>\w+)' + +    OFFLINE_PATTERN = r'>File Not Found<' +    LINK_PATTERN = r'id="downloadfile" href="(.+?)"' + + +    def setup(self): +        self.multiDL = True +        self.chunkLimit = 1 + + +    def handleFree(self): +        m = re.search(self.LINK_PATTERN, self.html) +        if m is None: +            self.parseError("Download link not found") + +        dl_url = m.group(1) +        self.logDebug("Download URL = " + dl_url) +        self.download(dl_url, disposition=True) + +        check = self.checkDownload({'is_html': re.compile("html")}) +        if check == "is_html": +            self.parseError("Downloaded file is an html file") + + +getInfo = create_getInfo(DevhostSt) diff --git a/module/plugins/hoster/DropboxCom.py b/module/plugins/hoster/DropboxCom.py new file mode 100644 index 000000000..ab63fc801 --- /dev/null +++ b/module/plugins/hoster/DropboxCom.py @@ -0,0 +1,42 @@ +# -*- coding: utf-8 -*- + +import re + +from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo + + +class DropboxCom(SimpleHoster): +    __name__ = "DropboxCom" +    __type__ = "hoster" +    __version__ = "0.01" + +    __pattern__ = r'https?://(?:www\.)?dropbox\.com/.+' + +    __description__ = """Dropbox.com hoster plugin""" +    __author_name__ = "zapp-brannigan" +    __author_mail__ = "fuerst.reinje@web.de" + + +    FILE_NAME_PATTERN = r'<title>Dropbox - (?P<N>.+?)<' +    FILE_SIZE_PATTERN = r' ·  (?P<S>[\d,]+) (?P<U>\w+)' + +    OFFLINE_PATTERN = r'<title>Dropbox - (404|Shared link error)<' + +    SH_COOKIES = [(".dropbox.com", "lang", "en")] + + +    def setup(self): +        self.multiDL = True +        self.chunkLimit = 1 +        self.resumeDownload = True + + +    def handleFree(self): +        self.download(self.pyfile.url, get={'dl': "1"}) + +        check = self.checkDownload({'is_html': re.compile("html")}) +        if check == "is_html": +            self.parseError("Downloaded file is an html file") + + +getInfo = create_getInfo(DropboxCom) diff --git a/module/plugins/hoster/KingfilesNet.py b/module/plugins/hoster/KingfilesNet.py new file mode 100644 index 000000000..4d87a5933 --- /dev/null +++ b/module/plugins/hoster/KingfilesNet.py @@ -0,0 +1,94 @@ +# -*- coding: utf-8 -*- + +import re + +from module.plugins.internal.CaptchaService import SolveMedia +from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo + + +class KingfilesNet(SimpleHoster): +    __name__ = "KingfilesNet" +    __type__ = "hoster" +    __version__ = "0.01" + +    __pattern__ = r'http://(?:www\.)?kingfiles\.net/\w{12}' + +    __description__ = """Kingfiles.net hoster plugin""" +    __author_name__ = ("zapp-brannigan", "Walter Purcaro") +    __author_mail__ = ("fuerst.reinje@web.de", "vuolter@gmail.com") + + +    FILE_NAME_PATTERN = r'name="fname" value="(?P<N>.+?)">' +    FILE_SIZE_PATTERN = r'>Size: .+?">(?P<S>[\d.]+) (?P<U>\w+)' + +    OFFLINE_PATTERN = r'>(File Not Found</b><br><br>|File Not Found</h2>)' + +    FILE_ID_PATTERN = r'<input type=\"hidden\" name=\"id\" value=\"(.+)\">' +    RAND_ID_PATTERN = r'type=\"hidden\" name=\"rand\" value=\"(.+)\">' + +    LINK_PATTERN = r'var download_url = \'(.+)\';' +    SOLVEMEDIA_PATTERN = r'http://api\.solvemedia\.com/papi/challenge\.script\?k=(.+)\">' + + +    def setup(self): +        self.multiDL = True +        self.resumeDownload = True + + +    def handleFree(self): +        # Load main page and find file-id +        a = self.load(self.pyfile.url, cookies=True, decode=True) +        file_id = re.search(self.FILE_ID_PATTERN, a).group(1) +        self.logDebug("file_id", file_id) + +        # Click the free user button +        post_data = {'op': "download1", +                     'usr_login': "", +                     'id': file_id, +                     'fname': self.pyfile.name, +                     'referer': "", +                     'method_free': "+"} +        b = self.load(self.pyfile.url, post=post_data, cookies=True, decode=True) + +        # Do the captcha stuff +        m = re.search(self.SOLVEMEDIA_PATTERN, b) +        if m is None: +            self.parseError("Captcha key not found") + +        solvemedia = SolveMedia(self) +        captcha_key = m.group(1) +        self.logDebug("captcha_key", captcha_key) +        captcha_challenge, captcha_response = solvemedia.challenge(captcha_key) + +        # Make the downloadlink appear and load the file +        m = re.search(self.RAND_ID_PATTERN, b) +        if m is None: +            self.parseError("Random key not found") + +        rand = m.group(1) +        self.logDebug("rand", rand) + +        post_data = {'op': "download2", +                     'id': file_id, +                     'rand': rand, +                     'referer': self.pyfile.url, +                     'method_free': "+", +                     'method_premium': "", +                     'adcopy_response': captcha_response, +                     'adcopy_challenge': captcha_challenge, +                     'down_direct': "1"} +        c = self.load(self.pyfile.url, post=post_data, cookies=True, decode=True) + +        m = re.search(self.LINK_PATTERN, c) +        if m is None: +            self.parseError("Download url not found") + +        dl_url = m.group(1) +        self.download(dl_url, cookies=True, disposition=True) + +        check = self.checkDownload({'is_html': re.compile("<html>")}) +        if check == "is_html": +            self.parseError("Downloaded file is an html file") + + +getInfo = create_getInfo(KingfilesNet) | 
