# -*- coding: utf-8 -*- import re from pyload.plugin.Hoster import Hoster class VeehdCom(Hoster): __name__ = "VeehdCom" __type__ = "hoster" __version__ = "0.23" __pattern__ = r'http://veehd\.com/video/\d+_\S+' __config__ = [("filename_spaces", "bool", "Allow spaces in filename", False), ("replacement_char", "str", "Filename replacement character", "_")] __description__ = """Veehd.com hoster plugin""" __license__ = "GPLv3" __authors__ = [("cat", "cat@pyload")] def setup(self): self.multiDL = True self.req.canContinue = True def process(self, pyfile): self.download_html() if not self.file_exists(): self.offline() pyfile.name = self.get_file_name() self.download(self.get_file_url()) def download_html(self): url = self.pyfile.url self.logDebug("Requesting page: %s" % url) self.html = self.load(url) def file_exists(self): if not self.html: self.download_html() if 'Veehd' in self.html: return False return True def get_file_name(self): if not self.html: self.download_html() m = re.search(r']*>([^<]+) on Veehd', self.html) if m is None: self.error(_("Video title not found")) name = m.group(1) # replace unwanted characters in filename if self.getConfig('filename_spaces'): pattern = '[^\w ]+' else: pattern = '[^\w.]+' return re.sub(pattern, self.getConfig('replacement_char'), name) + '.avi' def get_file_url(self): """ returns the absolute downloadable filepath """ if not self.html: self.download_html() m = re.search(r'