# -*- 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.Hoster import Hoster
from module.network.RequestFactory import getURL
def getInfo(urls):
    result = []
    for url in urls:
        try:
            html = getURL(url, decode=True)
            if re.search(QuickshareCz.FILE_OFFLINE_PATTERN, html):
                # File offline
                result.append((url, 0, 1, url))
            else:
                # Get file info
                found = re.search(QuickshareCz.VAR_PATTERN, html)
                if found is not None:
                    name = found.group('ID3')
                    found = re.search(QuickshareCz.FILE_SIZE_PATTERN, html)
                    if found is not None:
                        size = float(found.group(1))
                        units = found.group(2)
                        pow = {'kB': 1, 'MB': 2, 'GB': 3}[units]
                        size = int(size * 1024 ** pow)
                        result.append((name, size, 2, url))
        except:
            result.append((url, 0, 1, url))
    yield result
class QuickshareCz(Hoster):
    __name__ = "QuickshareCz"
    __type__ = "hoster"
    __pattern__ = r"http://.*quickshare.cz/stahnout-soubor/.*"
    __version__ = "0.5"
    __description__ = """Quickshare.cz"""
    __author_name__ = ("zoidberg")
    VAR_PATTERN = r"var ID1 = '(?P[^']+)';var ID2 = '(?P[^']+)';var ID3 = '(?P[^']+)';var ID4 = '(?P[^']+)';var ID5 = '[^']*';var UU_prihlasen = '[^']*';var UU_kredit = [^;]*;var velikost = [^;]*;var kredit_odecet = [^;]*;var CaptchaText = '(?P[^']+)';var server = '(?P[^']+)';"
    FILE_OFFLINE_PATTERN = r''
    FILE_SIZE_PATTERN = r'
Velikost: ([0-9.]+)\s*(KB|MB|GB)
'
    def setup(self):
        self.multiDL = False
    def process(self, pyfile):
        self.html = self.load(pyfile.url, decode=True)
        # marks the file as "offline" when the pattern was found on the html-page
        if re.search(self.FILE_OFFLINE_PATTERN, self.html) is not None:
            self.offline()
        # parse the name from the site and set attribute in pyfile
        parsed_vars = re.search(self.VAR_PATTERN, self.html)
        if parsed_vars is None:
            self.fail("Parser error")
        
        pyfile.name = parsed_vars.group('ID3')
        # download the file, destination is determined by pyLoad
        download_url = parsed_vars.group('Server') + "/download.php"
        self.log.debug("File:" + pyfile.name)
        self.log.debug("URL:" + download_url)
        self.download(download_url, post={
            "ID1": parsed_vars.group('ID1'),
            "ID2": parsed_vars.group('ID2'),
            "ID3": parsed_vars.group('ID3'),
            "ID4": parsed_vars.group('ID4')
        })
        # check download
        check = self.checkDownload({
            "no_slots": "obsazen na 100 %"
        })
        if check == "no_slots":
            self.retry(5, 600, "No free slots")