# -*- coding: utf-8 -*-
import re
from urlparse import urljoin
from pyload.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo
class FileSharkPl(SimpleHoster):
    __name__    = "FileSharkPl"
    __type__    = "hoster"
    __version__ = "0.01"
    __pattern__ = r'http://(?:www\.)?fileshark\.pl/pobierz/\d{6}/\w{5}'
    __description__ = """FileShark.pl hoster plugin"""
    __license__     = "GPLv3"
    __authors__     = [("prOq", None),
                       ("Walter Purcaro", "vuolter@gmail.com")]
    NAME_PATTERN = r'
(?P.+)
'
    SIZE_PATTERN = r'(.*?)(?P\d+\.?\d*)\s(?P\w+)
'
    OFFLINE_PATTERN = '(P|p)lik zosta. (usuni.ty|przeniesiony)'
    DOWNLOAD_ALERT = r'(.*?)
'
    IP_BLOCKED_PATTERN = 'Strona jest dost.pna wy..cznie dla u.ytkownik.w znajduj.cych si. na terenie Polski'
    DOWNLOAD_SLOTS_ERROR_PATTERN = r'Osi.gni.to maksymaln. liczb. .ci.ganych jednocze.nie plik.w\.'
    DOWNLOAD_URL_FREE = r''
    DOWNLOAD_URL_PREMIUM = r''
    SECONDS_PATTERN = r'var timeToDownload = (\d+);'
    CAPTCHA_IMG_PATTERN = ') '
    def setup(self):
        self.resumeDownload = True
        if self.premium:
            self.multiDL = True
            self.limitDL = 20
        else:
            self.multiDL = False
    def prepare(self):
        super(FileSharkPl, self).prepare()
        m = re.search(self.DOWNLOAD_ALERT, self.html):
        if m:
            return
        alert = m.group(1)
        if re.match(self.IP_BLOCKED_PATTERN, alert):
            self.fail(_("Only connections from Polish IP are allowed"))
        elif re.match(self.DOWNLOAD_SLOTS_ERROR_PATTERN, alert):
            self.logInfo(_("No free download slots available"))
            self.retry(10, 30 * 60, _("Still no free download slots available"))
        else:
            self.logInfo(alert)
            self.retry(10, 10 * 60, _("Try again later"))
    #@NOTE: handlePremium method was never been tested
    def handlePremium(self):
        self.logDebug("Premium accounts support in experimental modus!")
        m = re.search(self.DOWNLOAD_URL_PREMIUM, self.html)
        file_url = urljoin("http://fileshark.pl", m.group(1))
        self.download(file_url, disposition=True)
        self.checkDownload()
    def handleFree(self):
        m = re.search(self.DOWNLOAD_URL_FREE, self.html)
        if m is None:
            self.error(_("Download url not found"))
        file_url = urljoin("http://fileshark.pl", m.group(1))
        m = re.search(self.SECONDS_PATTERN, self.html)
        if m:
            seconds = int(m.group(1))
            self.logDebug("Wait %s seconds" % seconds)
            self.wait(seconds + 2)
        action, inputs = self.parseHtmlForm('action=""')
        m = re.search(self.CAPTCHA_TOKEN_PATTERN, self.html)
        if m is None:
            self.retry(reason=_("Captcha form not found"))
        inputs['form[_token]'] = m.group(1)
        m = re.search(self.CAPTCHA_IMG_PATTERN, self.html)
        if m is None:
            self.retry(reason=_("Captcha image not found"))
        tmp_load = self.load
        self.load = self.decode64  #: injects decode64 inside decryptCaptcha
        inputs['form[captcha]'] = self.decryptCaptcha(m.group(1), imgtype='jpeg')
        inputs['form[start]'] = ""
        self.load = tmp_load
        self.download(file_url, post=inputs, cookies=True, disposition=True)
        self.checkDownload()
    def checkDownload(self):
        check = super(FileSharkPl, self).checkDownload({
            'wrong_captcha': re.compile(r''),
            'wait_pattern': re.compile(self.SECONDS_PATTERN),
            'DL-found': re.compile('')
        })
        if check == "DL-found":
            self.correctCaptcha()
        elif check == "wrong_captcha":
            self.invalidCaptcha()
            self.retry(10, 1, _("Wrong captcha solution"))
        elif check == "wait_pattern":
            self.retry()
    def decode64(self, data, *args, **kwargs):
        return data.decode("base64")
getInfo = create_getInfo(FileSharkPl)
'
    def setup(self):
        self.resumeDownload = True
        if self.premium:
            self.multiDL = True
            self.limitDL = 20
        else:
            self.multiDL = False
    def prepare(self):
        super(FileSharkPl, self).prepare()
        m = re.search(self.DOWNLOAD_ALERT, self.html):
        if m:
            return
        alert = m.group(1)
        if re.match(self.IP_BLOCKED_PATTERN, alert):
            self.fail(_("Only connections from Polish IP are allowed"))
        elif re.match(self.DOWNLOAD_SLOTS_ERROR_PATTERN, alert):
            self.logInfo(_("No free download slots available"))
            self.retry(10, 30 * 60, _("Still no free download slots available"))
        else:
            self.logInfo(alert)
            self.retry(10, 10 * 60, _("Try again later"))
    #@NOTE: handlePremium method was never been tested
    def handlePremium(self):
        self.logDebug("Premium accounts support in experimental modus!")
        m = re.search(self.DOWNLOAD_URL_PREMIUM, self.html)
        file_url = urljoin("http://fileshark.pl", m.group(1))
        self.download(file_url, disposition=True)
        self.checkDownload()
    def handleFree(self):
        m = re.search(self.DOWNLOAD_URL_FREE, self.html)
        if m is None:
            self.error(_("Download url not found"))
        file_url = urljoin("http://fileshark.pl", m.group(1))
        m = re.search(self.SECONDS_PATTERN, self.html)
        if m:
            seconds = int(m.group(1))
            self.logDebug("Wait %s seconds" % seconds)
            self.wait(seconds + 2)
        action, inputs = self.parseHtmlForm('action=""')
        m = re.search(self.CAPTCHA_TOKEN_PATTERN, self.html)
        if m is None:
            self.retry(reason=_("Captcha form not found"))
        inputs['form[_token]'] = m.group(1)
        m = re.search(self.CAPTCHA_IMG_PATTERN, self.html)
        if m is None:
            self.retry(reason=_("Captcha image not found"))
        tmp_load = self.load
        self.load = self.decode64  #: injects decode64 inside decryptCaptcha
        inputs['form[captcha]'] = self.decryptCaptcha(m.group(1), imgtype='jpeg')
        inputs['form[start]'] = ""
        self.load = tmp_load
        self.download(file_url, post=inputs, cookies=True, disposition=True)
        self.checkDownload()
    def checkDownload(self):
        check = super(FileSharkPl, self).checkDownload({
            'wrong_captcha': re.compile(r''),
            'wait_pattern': re.compile(self.SECONDS_PATTERN),
            'DL-found': re.compile('')
        })
        if check == "DL-found":
            self.correctCaptcha()
        elif check == "wrong_captcha":
            self.invalidCaptcha()
            self.retry(10, 1, _("Wrong captcha solution"))
        elif check == "wait_pattern":
            self.retry()
    def decode64(self, data, *args, **kwargs):
        return data.decode("base64")
getInfo = create_getInfo(FileSharkPl)