#!/usr/bin/env python # -*- coding: utf-8 -*- import os import re import tempfile from time import time from module.plugins.Hoster import Hoster class MegauploadCom(Hoster): __name__ = "MegauploadCom" __type__ = "hoster" __pattern__ = r"http://[\w\.]*?(megaupload)\.com/.*?(\?|&)d=[0-9A-Za-z]+" __version__ = "0.1" __description__ = """Megaupload.com Download Hoster""" __author_name__ = ("spoob") __author_mail__ = ("spoob@pyload.org") def setup(self): self.html = [None, None] self.multiDL = False def process(self, pyfile): self.pyfile = pyfile self.download_html() if not self.file_exists(): self.offline() self.setWait(45) self.wait() pyfile.name = self.get_file_name() self.download(self.get_file_url()) def download_html(self): captcha_image = tempfile.NamedTemporaryFile(suffix=".gif").name for i in range(5): self.html[0] = self.load(self.pyfile.url) try: url_captcha_html = re.search('(http://www.{,3}\.megaupload\.com/gencap.php\?.*\.gif)', self.html[0]).group(1) except: continue self.pyfile.status.waituntil = time() + 10 captcha = self.decryptCaptcha(url_captcha_html) captchacode = re.search('name="captchacode" value="(.*)"', self.html[0]).group(1) megavar = re.search('name="megavar" value="(.*)">', self.html[0]).group(1) self.html[1] = self.load(self.pyfile.url, post={"captcha": captcha, "captchacode": captchacode, "megavar": megavar}) if re.search(r"Waiting time before each download begins", self.html[1]) != None: break def get_file_url(self): file_url_pattern = 'id="downloadlink">