# -*- coding: utf-8 -*- ############################################################################ # This program is free software: you can redistribute it and/or modify # # it under the terms of the GNU Affero 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 Affero General Public License for more details. # # # # You should have received a copy of the GNU Affero General Public License # # along with this program. If not, see . # ############################################################################ import re from datetime import datetime, timedelta from module.plugins.Hoster import Hoster from module.plugins.hoster.UnrestrictLi import secondsToMidnight class SimplyPremiumCom(Hoster): __name__ = "SimplyPremiumCom" __version__ = "0.03" __type__ = "hoster" __pattern__ = r'https?://.*(simply-premium)\.com' __description__ = """Simply-Premium.com hoster plugin""" __author_name__ = "EvolutionClip" __author_mail__ = "evolutionclip@live.de" def setup(self): self.chunkLimit = 16 self.resumeDownload = False def process(self, pyfile): if re.match(self.__pattern__, pyfile.url): new_url = pyfile.url elif not self.account: self.logError(_("Please enter your %s account or deactivate this plugin") % "Simply-Premium.com") self.fail("No Simply-Premium.com account provided") else: self.logDebug("Old URL: %s" % pyfile.url) for i in xrange(5): page = self.load('http://www.simply-premium.com/premium.php?info&link=' + pyfile.url) self.logDebug("JSON data: " + page) if page != '': break else: self.logInfo("Unable to get API data, waiting 1 minute and retry") self.retry(5, 60, "Unable to get API data") if '0' in page or ( "You are not allowed to download from this host" in page and self.premium): self.account.relogin(self.user) self.retry() elif "NOTFOUND" in page: self.offline() elif "downloadlimit" in page: self.logWarning("Reached maximum connctions") self.retry(5, 60, "Reached maximum connctions") elif "trafficlimit" in page: self.logWarning("Reached daily limit for this host") self.retry(1, secondsToMidnight(gmt=2), "Daily limit for this host reached") elif "hostererror" in page: self.logWarning("Hoster temporarily unavailable, waiting 1 minute and retry") self.retry(5, 60, "Hoster is temporarily unavailable") #page = json_loads(page) #new_url = page.keys()[0] #self.api_data = page[new_url] try: self.pyfile.name = re.search(r'([^<]+)', page).group(1) except AttributeError: self.pyfile.name = "" try: self.pyfile.size = re.search(r'(\d+)', page).group(1) except AttributeError: self.pyfile.size = 0 try: new_url = re.search(r'([^<]+)', page).group(1) except AttributeError: new_url = 'http://www.simply-premium.com/premium.php?link=' + pyfile.url if new_url != pyfile.url: self.logDebug("New URL: " + new_url) self.download(new_url, disposition=True)