# -*- coding: utf-8 -*-

import re

from BeautifulSoup import BeautifulSoup

from pyload.plugins.internal.Crypter import Crypter


class DuckCryptInfo(Crypter):
    __name__    = "DuckCryptInfo"
    __type__    = "crypter"
    __version__ = "0.02"

    __pattern__ = r'http://(?:www\.)?duckcrypt\.info/(folder|wait|link)/(\w+)/?(\w*)'
    __config__  = [("use_subfolder", "bool", "Save package to subfolder", True),
                   ("subfolder_per_package", "bool", "Create a subfolder for each package", True)]

    __description__ = """DuckCrypt.info decrypter plugin"""
    __license__     = "GPLv3"
    __authors__     = [("godofdream", "soilfiction@gmail.com")]


    TIMER_PATTERN = r'<span id="timer">(.*)</span>'


    def decrypt(self, pyfile):
        url = pyfile.url

        m = re.match(self.__pattern__, url)
        if m is None:
            self.fail(_("Weird error in link"))
        if str(m.group(1)) == "link":
            self.handleLink(url)
        else:
            self.handleFolder(m)


    def handleFolder(self, m):
        html = self.load("http://duckcrypt.info/ajax/auth.php?hash=" + str(m.group(2)))
        m = re.match(self.__pattern__, html)
        self.logDebug("Redirectet to " + str(m.group(0)))
        html = self.load(str(m.group(0)))
        soup = BeautifulSoup(html)
        cryptlinks = soup.findAll("div", attrs={"class": "folderbox"})
        self.logDebug("Redirectet to " + str(cryptlinks))
        if not cryptlinks:
            self.error(_("No link found"))
        for clink in cryptlinks:
            if clink.find("a"):
                self.handleLink(clink.find("a")['href'])


    def handleLink(self, url):
        html = self.load(url)
        soup = BeautifulSoup(html)
        self.urls = [soup.find("iframe")['src']]
        if not self.urls:
            self.logInfo(_("No link found"))