# -*- 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")