#!/usr/bin/env python # -*- coding: utf-8 -*- # Plugin for www.filesmonster.com # this plugin isn't fully implemented yet,but it does download # todo: # detect, if reconnect is necessary # download-error handling # postpone download, if speed is below a set limit # implement premium-access # optional replace blanks in filename with underscores import re import urllib import time from module.plugins.Plugin import Plugin class FilesmonsterCom(Plugin): def __init__(self, parent): Plugin.__init__(self, parent) props = {} props['name'] = "FilesmonsterCom" props['type'] = "hoster" props['pattern'] = r"http://(www.)??filesmonster.com/download.php" props['version'] = "0.1" props['description'] = """Filesmonster.com Download Plugin""" props['author_name'] = ("sitacuisses","spoob") props['author_mail'] = ("sitacuisses@yahoo.de","spoob@pyload.org") self.props = props self.parent = parent self.html = None self.want_reconnect = False self.multi_dl = False self.htmlwithlink = None self.url = None self.filerequest = None def download_html(self): self.url = self.parent.url self.html = self.load(self.url) # get the start page 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() # the complex work is done here file_url = self.htmlwithlink 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(r"File\sname:\s(.*?)", self.html).group(1) return file_name else: return self.parent.url def file_exists(self): 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_download_page(self): herewego = re.findall(r"\s*\n\s*", self.html) the_download_page = self.load("http://filesmonster.com/get/free/", None, herewego) temporary_filtered = re.search(r"\s*\n(\s*\s*\n)*?\s*", the_download_page).group(0) all_the_tuples = re.findall(r"