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

import re
import time

from pyload.plugin.Account import Account


class FilerNet(Account):
    __name    = "FilerNet"
    __type    = "account"
    __version = "0.04"

    __description = """Filer.net account plugin"""
    __license     = "GPLv3"
    __authors     = [("stickell", "l.stickell@yahoo.it")]


    TOKEN_PATTERN = r'_csrf_token" value="(.+?)" />'
    WALID_UNTIL_PATTERN = r'Der Premium-Zugang ist gültig bis (.+)\.\s*</td>'
    TRAFFIC_PATTERN = r'Traffic</th>\s*<td>([^<]+)</td>'
    FREE_PATTERN = r'Account Status</th>\s*<td>\s*Free'


    def loadAccountInfo(self, user, req):
        html = req.load("https://filer.net/profile")

        # Free user
        if re.search(self.FREE_PATTERN, html):
            return {"premium": False, "validuntil": None, "trafficleft": None}

        until   = re.search(self.WALID_UNTIL_PATTERN, html)
        traffic = re.search(self.TRAFFIC_PATTERN, html)

        if until and traffic:
            validuntil  = time.mktime(time.strptime(until.group(1), "%d.%m.%Y %H:%M:%S"))
            trafficleft = self.parseTraffic(traffic.group(1))
            return {"premium": True, "validuntil": validuntil, "trafficleft": trafficleft}

        else:
            self.logError(_("Unable to retrieve account information"))
            return {"premium": False, "validuntil": None, "trafficleft": None}


    def login(self, user, data, req):
        html = req.load("https://filer.net/login")

        token = re.search(self.TOKEN_PATTERN, html).group(1)

        html = req.load("https://filer.net/login_check",
                        post={"_username": user,
                              "_password": data['password'],
                              "_remember_me": "on",
                              "_csrf_token": token,
                              "_target_path": "https://filer.net/"},
                        decode=True)

        if 'Logout' not in html:
            self.wrongPassword()