# -*- coding: utf-8 -*- import re from time import sleep from module.network.RequestFactory import getURL from module.plugins.internal.CaptchaService import ReCaptcha from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo class UploadedTo(SimpleHoster): __name__ = "UploadedTo" __type__ = "hoster" __version__ = "0.81" __pattern__ = r'https?://(?:www\.)?(uploaded\.(to|net)|ul\.to)(/file/|/?\?id=|.*?&id=|/)(?P\w+)' __description__ = """Uploaded.net hoster plugin""" __license__ = "GPLv3" __authors__ = [("Walter Purcaro", "vuolter@gmail.com")] API_KEY = "lhF2IeeprweDfu9ccWlxXVVypA5nA3EL" URL_REPLACEMENTS = [(__pattern__ + ".*", r'http://uploaded.net/file/\g')] LINK_PREMIUM_PATTERN = r'
(\d+)' DL_LIMIT_ERROR = r'You have reached the max. number of possible free downloads for this hour' @classmethod def apiInfo(cls, url="", get={}, post={}): info = super(UploadedTo, cls).apiInfo(url) for _i in xrange(5): html = getURL("http://uploaded.net/api/filemultiple", get={"apikey": cls.API_KEY, 'id_0': re.match(cls.__pattern__, url).group('ID')}, decode=True) if html != "can't find request": api = html.split(",", 4) if api[0] == "offline": info['status'] = 1 else: info.update({'name': api[4], 'size': api[2], 'status': 2}) break else: sleep(3) return info def setup(self): self.multiDL = self.resumeDownload = self.premium self.chunkLimit = 1 # critical problems with more chunks self.load("http://uploaded.net/language/en", just_header=True) def checkErrors(self): if 'var free_enabled = false;' in self.html: self.logError(_("Free-download capacities exhausted")) self.retry(24, 5 * 60) elif "limit-size" in self.html: self.fail(_("File too big for free download")) elif "limit-slot" in self.html: # Temporary restriction so just wait a bit self.wait(30 * 60, True) self.retry() elif "limit-parallel" in self.html: self.fail(_("Cannot download in parallel")) elif "limit-dl" in self.html or self.DL_LIMIT_ERROR in self.html: # limit-dl self.wait(3 * 60 * 60, True) self.retry() elif '"err":"captcha"' in self.html: self.invalidCaptcha() else: m = re.search(self.WAIT_PATTERN, self.html) if m: self.wait(m.group(1)) def handleFree(self, pyfile): self.html = self.load("http://uploaded.net/js/download.js", decode=True) recaptcha = ReCaptcha(self) response, challenge = recaptcha.challenge() self.html = self.load("http://uploaded.net/io/ticket/captcha/%s" % self.info['pattern']['ID'], post={'recaptcha_challenge_field': challenge, 'recaptcha_response_field' : response}) if "type:'download'" in self.html: self.correctCaptcha() try: self.link = re.search("url:'([^']+)", self.html).group(1) except Exception: pass self.checkErrors() def checkFile(self): if self.checkDownload({'limit-dl': self.DL_LIMIT_ERROR}): self.wait(3 * 60 * 60, True) self.retry() return super(UploadedTo, self).checkFile() getInfo = create_getInfo(UploadedTo)