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

import re
import time

from module.plugins.internal.Account import Account


class FilerNet(Account):
    __name__    = "FilerNet"
    __type__    = "account"
    __version__ = "0.09"
    __status__  = "testing"

    __description__ = """Filer.net account plugin"""
    __license__     = "GPLv3"
    __authors__     = [("stickell", "l.stickell@yahoo.it")]


    TOKEN_PATTERN = r'name="_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 grab_info(self, user, password, data):
        html = self.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.parse_traffic(traffic.group(1))
            return {'premium': True, 'validuntil': validuntil, 'trafficleft': trafficleft}

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


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

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

        html = self.load("https://filer.net/login_check",
                         post={'_username'   : user,
                               '_password'   : password,
                               '_remember_me': "on",
                               '_csrf_token' : token,
                               '_target_path': "https://filer.net/"})

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