diff options
Diffstat (limited to 'Plugins/ShragleCom.py')
| -rw-r--r-- | Plugins/ShragleCom.py | 70 | 
1 files changed, 70 insertions, 0 deletions
| diff --git a/Plugins/ShragleCom.py b/Plugins/ShragleCom.py new file mode 100644 index 000000000..45f416872 --- /dev/null +++ b/Plugins/ShragleCom.py @@ -0,0 +1,70 @@ +#!/usr/bin/env python +import re +import time + +from Plugin import Plugin + +class ShragleCom(Plugin): + +    def __init__(self, parent): +        Plugin.__init__(self, parent) +        props = {} +        props['name'] = "ShragleCom" +        props['type'] = "hoster" +        props['pattern'] = r"http://(?:www.)?shragle.com/files/" +        props['version'] = "0.1" +        props['description'] = """Shragle Download PLugin""" +        props['author_name'] = ("RaNaN") +        props['author_mail'] = ("RaNaN@pyload.org") +        self.props = props +        self.parent = parent +        self.html = None +        self.multi_dl = False + +    def set_parent_status(self): +        """ sets all available Statusinfos about a File in self.parent.status +        """ +        if self.html == None: +            self.download_html() +        self.parent.status.filename = self.get_file_name() +        self.parent.status.url = self.get_file_url() +        self.parent.status.wait = self.wait_until() + +    def download_html(self): +        url = self.parent.url +        self.html = self.req.load(url) +        self.time_plus_wait = time.time() + 10 + +    def get_file_url(self): +        """ returns the absolute downloadable filepath +        """ +        if self.html == None: +            self.download_html() + +        self.fileID = re.search(r"name=\"fileID\" value=\"([^\"]+)", self.html).group(1) +        self.dlSession = re.search(r"name=\"dlSession\" value=\"([^\"]+)", self.html).group(1) +        self.userID = "" +        self.password = "" +        self.lang = "de" +        return "http://srv4.shragle.com/download.php" + +    def get_file_name(self): +        if self.html == None: +            self.download_html() + +        file_name_pattern = r"<\/div><h2>(.+)<\/h2" +        return re.search(file_name_pattern, self.html).group(1) + +    def file_exists(self): +        """ returns True or False +        """ +        if self.html == None: +            self.download_html() +             +        if re.search(r"html", self.html) == None: +            return False +        else: +            return True + +    def proceed(self, url, location): +        self.req.download(url, location, {'fileID': self.fileID, 'dlSession': self.dlSession, 'userID': self.userID, 'password': self.password, 'lang': self.lang})
\ No newline at end of file | 
