# -*- coding: utf-8 -*-
"""
    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 3 of the License,
    or (at your option) any later version.
    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
    See the GNU General Public License for more details.
    You should have received a copy of the GNU General Public License
    along with this program; if not, see .
    @author: zoidberg
"""
import re
from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo
from module.utils import fixup
class NowDownloadEu(SimpleHoster):
    __name__ = "NowDownloadEu"
    __type__ = "hoster"
    __pattern__ = r"http://(www\.)?nowdownload\.(eu|co)/dl/(?P[a-z0-9]+)"
    __version__ = "0.02"
    __description__ = """NowDownloadEu"""
    __author_name__ = ("godofdream")
    FILE_INFO_PATTERN = r'Downloading 
 (?P.*) (?P[0-9,.]+) (?P[kKMG])i?B '
    FILE_OFFLINE_PATTERN = r'(This file does not exist!)'
    FILE_TOKEN_PATTERN = r'"(/api/token\.php\?token=[a-z0-9]+)"'
    FILE_CONTINUE_PATTERN = r'"(/dl2/[a-z0-9]+/[a-z0-9]+)"'
    FILE_WAIT_PATTERN = r'\.countdown\(\{until: \+(\d+),'
    FILE_DOWNLOAD_LINK = r'"(http://f\d+\.nowdownload\.eu/dl/[a-z0-9]+/[a-z0-9]+/[^<>"]*?)"'
    FILE_NAME_REPLACEMENTS = [("?\w+;", fixup), (r'<[^>]*>', '')]
    def setup(self):
        self.wantReconnect = False
        self.multiDL = True
        self.chunkLimit = -1
        self.resumeDownload = True
    def handleFree(self):
        tokenlink = re.search(self.FILE_TOKEN_PATTERN, self.html)
        continuelink = re.search(self.FILE_CONTINUE_PATTERN, self.html)
        if (not tokenlink) or (not continuelink):
            self.fail('Plugin out of Date')
        wait = 60
        found = re.search(self.FILE_WAIT_PATTERN, self.html)
        if found:
            wait = int(found.group(1))
        self.html = self.load("http://www.nowdownload.eu" + str(tokenlink.group(1)))
        self.setWait(wait)
        self.wait()
        self.html = self.load("http://www.nowdownload.eu" + str(continuelink.group(1)))
        url = re.search(self.FILE_DOWNLOAD_LINK, self.html)
        if not url:
            self.fail('Download Link not Found (Plugin out of Date?)')
        self.logDebug('Download link: ' + str(url.group(1)))
        self.download(str(url.group(1)))
getInfo = create_getInfo(NowDownloadEu)