diff options
| -rw-r--r-- | module/plugins/HotfileCom.py | 115 | 
1 files changed, 115 insertions, 0 deletions
| diff --git a/module/plugins/HotfileCom.py b/module/plugins/HotfileCom.py new file mode 100644 index 000000000..e994b1e87 --- /dev/null +++ b/module/plugins/HotfileCom.py @@ -0,0 +1,115 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +import re +import urllib +from time import time +from Plugin import Plugin + +class HotfileCom(Plugin): + +    def __init__(self, parent): +        Plugin.__init__(self, parent) +        props = {} +        props['name'] = "HotfileCom" +        props['type'] = "hoster" +        props['pattern'] = r"http://hotfile.com/dl/" +        props['version'] = "0.1" +        props['description'] = """Hotfile.com Download Plugin""" +        props['author_name'] = ("sitacuisses","spoob","mkaay") +        props['author_mail'] = ("sitacuisses@yhoo.de","spoob@pyload.org","mkaay@mkaay.de") +        self.props = props +        self.parent = parent +        self.html = None +        self.want_reconnect = False +        self.multi_dl = False +        self.htmlwithlink = None +        self.url = None + +    def prepare(self, thread): +        pyfile = self.parent + +        self.want_reconnect = False + +        pyfile.status.exists = self.file_exists() + +        if not pyfile.status.exists: +            raise Exception, "The file was not found on the server." +            return False + +        pyfile.status.filename = self.get_file_name() +             +        self.get_wait_time() +        pyfile.status.waituntil = self.time_plus_wait +        pyfile.status.want_reconnect = self.want_reconnect + +        thread.wait(self.parent) +         +        pyfile.status.url = self.get_file_url() + +        return True + +    def download_html(self): +        self.url = self.parent.url +        self.html = self.req.load(self.url) +        with open("hotfile_dump_1.html", "w") as f: +            f.write(self.html) + +    def get_file_url(self): +        """ returns the absolute downloadable filepath +        """ +        if self.html == None: +            self.download_html() +        if not self.want_reconnect: +            self.get_download_page() +            file_url = re.search("a href=\"(http://hotfile\.com/get/\S*?)\"", self.htmlwithlink).group(1) +            return file_url +        else: +            return False + +    def get_file_name(self): +        if self.html == None: +            self.download_html() +        if not self.want_reconnect: +            file_name = re.search('Downloading\s<b>(.*?)</b>', self.html).group(1) +            return file_name +        else: +            return self.parent.url + +    def file_exists(self): +        """ returns True or False +        """ +        if self.html == None: +            self.download_html() +        if re.search(r"Such file does not exist or it has been removed for infringement of copyrights.", self.html) != None: +            return False +        else: +            return True +     +    def get_wait_time(self): +        free_limit_pattern = re.compile(r"timerend=d\.getTime\(\)\+(\d+);") +        matches = free_limit_pattern.findall(self.html) +        if matches: +            for match in matches: +                if int(match) == 60000: +                    continue +                if int(match) == 0: +                    continue +                else: +                    self.time_plus_wait = time() + int(match)/1000 + 65 +                    self.want_reconnect = True +                    return True +            self.time_plus_wait = time() + 65 + +    def get_download_page(self): +        herewego = re.search(r"<form style=.*(\n<.*>\s*)*?\n<tr>", self.html).group(0) +        all_the_tuples = re.findall(r"<input\stype=hidden\sname=(\S*)\svalue=(\S*)>", herewego) +         +        self.htmlwithlink = self.req.load(self.url, None, all_the_tuples) +        with open("hotfile_dump_2.html", "w") as f: +            f.write(self.htmlwithlink) + +    def proceed(self, url, location): + +        self.req.download(url, location) + | 
