# -*- coding: utf-8 -*-
import re
import pycurl
from module.network.HTTPRequest import BadHeader
from module.plugins.captcha.AdsCaptcha import AdsCaptcha
from module.plugins.captcha.ReCaptcha import ReCaptcha
from module.plugins.captcha.SolveMedia import SolveMedia
from module.plugins.internal.SimpleHoster import SimpleHoster
from module.plugins.internal.misc import json, seconds_to_midnight
class RapidgatorNet(SimpleHoster):
    __name__    = "RapidgatorNet"
    __type__    = "hoster"
    __version__ = "0.44"
    __status__  = "testing"
    __pattern__ = r'http://(?:www\.)?(?:rapidgator\.net|rg\.to)/file/\w+'
    __config__  = [("activated"   , "bool", "Activated"                                        , True),
                   ("use_premium" , "bool", "Use premium account if available"                 , True),
                   ("fallback"    , "bool", "Fallback to free download if premium fails"       , True),
                   ("chk_filesize", "bool", "Check file size"                                  , True),
                   ("max_wait"    , "int" , "Reconnect if waiting time is greater than minutes", 10  )]
    __description__ = """Rapidgator.net hoster plugin"""
    __license__     = "GPLv3"
    __authors__     = [("zoidberg",       "zoidberg@mujmail.cz"       ),
                       ("chrox",          None                        ),
                       ("stickell",       "l.stickell@yahoo.it"       ),
                       ("Walter Purcaro", "vuolter@gmail.com"         ),
                       ("GammaCode",      "nitzo2001[AT]yahoo[DOT]com")]
    API_URL = "http://rapidgator.net/api/file"
    COOKIES = [("rapidgator.net", "lang", "en")]
    NAME_PATTERN    = r'
Download file (?P.*)'
    SIZE_PATTERN    = r'File size:\s*(?P[\d.,]+) (?P[\w^_]+)'
    OFFLINE_PATTERN = r'>(File not found|Error 404)'
    JSVARS_PATTERN = r'\s+var\s*(startTimerUrl|getDownloadUrl|captchaUrl|fid|secs)\s*=\s*\'?(.*?)\'?;'
    PREMIUM_ONLY_PATTERN         = r'You can download files up to|This file can be downloaded by premium only<'
    DOWNLOAD_LIMIT_ERROR_PATTERN = r'You have reached your (daily|hourly) downloads limit'
    WAIT_PATTERN                 = r'(?:Delay between downloads must be not less than|Try again in).+'
    LINK_FREE_PATTERN = r'return \'(http://\w+.rapidgator.net/.*)\';'
    RECAPTCHA_PATTERN  = r'"http://api\.recaptcha\.net/challenge\?k=(.*?)"'
    ADSCAPTCHA_PATTERN = r'(http://api\.adscaptcha\.com/Get\.aspx[^"\']+)'
    SOLVEMEDIA_PATTERN = r'http://api\.solvemedia\.com/papi/challenge\.script\?k=(.*?)"'
    URL_REPLACEMENTS = [(r'//(?:www\.)?rg\.to/', "//rapidgator.net/")]
    def setup(self):
        if self.account:
            self.sid = self.account.get_data('sid')
        else:
            self.sid = None
        if self.sid:
            self.premium = True
        self.resume_download = self.multiDL = self.premium
        self.chunk_limit     = 1
    def api_response(self, cmd):
        try:
            html = self.load('%s/%s' % (self.API_URL, cmd),
                             get={'sid': self.sid,
                                  'url': self.pyfile.url})
            self.log_debug("API:%s" % cmd, html, "SID: %s" % self.sid)
            json_data = json.loads(html)
            status = json_data['response_status']
            msg = json_data['response_details']
        except BadHeader, e:
            self.log_error("API: %s" % cmd, e, "SID: %s" % self.sid)
            status = e.code
            msg = e
        if status == 200:
            return json_data['response']
        elif status == 423:
            self.restart(msg=json_data['response_details'], premium=False)
        else:
            self.account.relogin()
            self.retry(wait=60)
    def handle_premium(self, pyfile):
        self.api_data = self.api_response('info')
        self.api_data['md5'] = self.api_data['hash']
        pyfile.name = self.api_data['filename']
        pyfile.size = self.api_data['size']
        self.link = self.api_response('download')['url']
    def check_errors(self):
        super(RapidgatorNet, self).check_errors()
        m = re.search(self.DOWNLOAD_LIMIT_ERROR_PATTERN, self.data)
        if m:
            self.log_warning(m.group(0))
            if m.group(1) == "daily":
                wait_time = seconds_to_midnight()
            else:
                wait_time = 1 * 60 * 60
            self.retry(wait=wait_time, msg=m.group(0))
    def handle_free(self, pyfile):
        jsvars = dict(re.findall(self.JSVARS_PATTERN, self.data))
        self.log_debug(jsvars)
        self.req.http.lastURL = pyfile.url
        self.req.http.c.setopt(pycurl.HTTPHEADER, ["X-Requested-With: XMLHttpRequest"])
        url = "http://rapidgator.net%s?fid=%s" % (
            jsvars.get('startTimerUrl', '/download/AjaxStartTimer'), jsvars['fid'])
        jsvars.update(self.get_json_response(url))
        self.wait(jsvars.get('secs', 45), False)
        url = "http://rapidgator.net%s?sid=%s" % (
            jsvars.get('getDownloadUrl', '/download/AjaxGetDownload'), jsvars['sid'])
        jsvars.update(self.get_json_response(url))
        self.req.http.lastURL = pyfile.url
        self.req.http.c.setopt(pycurl.HTTPHEADER, ["X-Requested-With:"])
        url = "http://rapidgator.net%s" % jsvars.get('captchaUrl', '/download/captcha')
        self.data = self.load(url)
        m = re.search(self.LINK_FREE_PATTERN, self.data)
        if m is not None:
            self.link = m.group(1)
        else:
            captcha = self.handle_captcha()
            if not captcha:
                self.error(_("Captcha pattern not found"))
            response, challenge  = captcha.challenge()
            self.data = self.load(url, post={'DownloadCaptchaForm[captcha]': "",
                                             'adcopy_challenge'            : challenge,
                                             'adcopy_response'             : response})
            if "The verification code is incorrect" in self.data:
                self.retry_captcha()
            else:
                m = re.search(self.LINK_FREE_PATTERN, self.data)
                if m is not None:
                    self.link = m.group(1)
    def handle_captcha(self):
        for klass in (AdsCaptcha, ReCaptcha, SolveMedia):
            captcha = klass(self.pyfile)
            if captcha.detect_key():
                self.captcha = captcha
                return captcha
    def get_json_response(self, url):
        res = self.load(url)
        if not res.startswith('{'):
            self.retry()
        self.log_debug(url, res)
        return json.loads(res)