# -*- coding: utf-8 -*-
import re
from pycurl import error
from module.plugins.Hoster import Hoster
from module.network.RequestFactory import getURL
from module.plugins.Plugin import chunks
from module.plugins.ReCaptcha import ReCaptcha
from module.utils import parseFileSize
def parseInfos(html):
        match = re.search(r'id="filename">([^<]+)
([^<]+)', html)
        return {"name" : match.group(1),
                "size": parseFileSize(match.group(2))}
def getInfo(urls):
    pattern = re.compile(UploadedTo.__pattern__)
    for chunk in chunks(urls, 10):
        result = []
        for url in chunk:
            match = pattern.search(url)
            if match:
                src = getURL(url, get={"id": match.group(1).split("/")[0]}).decode("utf8", "ignore")
                if 'Error: 404' in src:
                    result.append((url, 0, 1, url))
                    continue
                    
                data = parseInfos(src)
                result.append((data["name"], data["size"], 2, url))
        yield result
class UploadedTo(Hoster):
    __name__ = "UploadedTo"
    __type__ = "hoster"
    __pattern__ = r"http://(?:www\.)?u(?:p)?l(?:oaded)?\.to/(?:file/|\?id=)?(.+)"
    __version__ = "0.42"
    __description__ = """Uploaded.to Download Hoster"""
    __author_name__ = ("spoob", "mkaay")
    __author_mail__ = ("spoob@pyload.org", "mkaay@mkaay.de")
    
    def setup(self):
        self.html = None
        self.data = {}
        self.multiDL = False
        self.resumeDownload = False
        self.url = False
        if self.account:
            self.premium = self.account.getAccountInfo(self.user)
            if self.premium:
                self.multiDL = True
                self.chunkLimit = -1
                self.resumeDownload = True
        self.pyfile.url = self.cleanUrl(self.pyfile.url)
        self.fileID = re.search(self.__pattern__, self.pyfile.url).group(1)
    def process(self, pyfile):
        self.req.cj.setCookie("uploaded.to", "lang", "en")
        self.html = self.load(self.pyfile.url, cookies=False, utf8=True)
        if re.search(r'File doesn\'t exist|Error: 404', self.html) is not None:
            self.offline()
        self.data = parseInfos(self.html)
        pyfile.name = self.data["name"]
        # self.pyfile.name = self.get_file_name()
        if self.account and self.premium:
            self.handlePremium()
        else:
            self.handleFree()
    def handlePremium(self):
        info = self.account.getAccountInfo(self.user, True)
        self.log.debug("%(name)s: Use Premium Account (%(left)sGB left)" % {"name" :self.__name__, "left" : info["trafficleft"]/1024/1024})
        if self.data["size"]/1024 > info["trafficleft"]:
            self.log.info(_("%s: Not enough traffic left" % self.__name__))
            self.account.empty()
            self.resetAccount()
            self.fail(_("Traffic exceeded"))
        try:
            html = self.load(self.pyfile.url, utf8=True)
        except error, e:
            if e.args and e.args[0] == 23:
                self.log.warning(_("Deactivate direct downloads in your Uploaded.to Account settings."))
                self.download(self.pyfile.url)
        else:
            url = re.search(r'action="(http://.*\.uploaded.to/dl(\?id=|/)[^"]+)', html)
            url = url.group(1)
            self.download(url)
    def handleFree(self):
        wait = re.search(r"Current waiting period: (\d+) seconds", self.html).group(1)
        self.setWait(wait)
        js = self.load("http://uploaded.to/js/download.js")
        challengeId = re.search(r'Recaptcha\.create\("([^"]+)', js)
        url = "http://uploaded.to/io/ticket/captcha/%s" % self.fileID
        downloadURL = ""
        for i in range(5):
            self.req.lastURL = str(self.url)
            re_captcha = ReCaptcha(self)
            challenge, result = re_captcha.challenge(challengeId.group(1))
            options = {"recaptcha_challenge_field" : challenge, "recaptcha_response_field": result}
            self.wait()
            result = self.load(url, post=options)
            self.log.debug("UploadedTo result: %s" % result)
            if "limit-dl" in result:
                self.setWait(30 * 60, True)
                self.wait()
                self.retry()
            elif 'err:"captcha"' in result:
                self.invalidCaptcha()
            elif "type:'download'" in result:
                downloadURL = re.search("url:'([^']+)", result).group(1)
                break
                
        if not downloadURL:
            self.fail("No Download url retrieved")
        self.download(downloadURL)
    def cleanUrl(self, url):
        url = url.replace("ul.to/", "uploaded.to/file/")
        url = url.replace("/?id=", "/file/")
        url = url.replace("?id=", "file/")
        url = re.sub("/\?(.*?)&id=", "/file/", url, 1)
        return url