import re from module.plugins.Hoster import Hoster from module.common.json_layer import json_loads class RPNetBiz(Hoster): __name__ = "RPNetBiz" __version__ = "0.1" __type__ = "hoster" __description__ = """RPNet.biz hoster plugin""" __pattern__ = r"https?://.*rpnet\.biz" __author_name__ = "Dman" __author_mail__ = "dmanugm@gmail.com" def setup(self): self.chunkLimit = -1 self.resumeDownload = True def process(self, pyfile): if re.match(self.__pattern__, pyfile.url): link_status = {'generated': pyfile.url} elif not self.account: # Check account self.logError(_("Please enter your %s account or deactivate this plugin") % "rpnet") self.fail("No rpnet account provided") else: (user, data) = self.account.selectAccount() self.logDebug("Original URL: %s" % pyfile.url) # Get the download link response = self.load("https://premium.rpnet.biz/client_api.php", get={"username": user, "password": data['password'], "action": "generate", "links": self.pyfile.url}) self.logDebug("JSON data: %s" % response) link_status = json_loads(response)['links'][0] # get the first link... since we only queried one # Check if we only have an id as a HDD link if 'id' in link_status: self.logDebug("Need to wait at least 30 seconds before requery") self.setWait(30) # wait for 30 seconds self.wait() # Lets query the server again asking for the status on the link, # we need to keep doing this until we reach 100 max_tries = 30 my_try = 0 while (my_try <= max_tries): self.logDebug("Try: %d ; Max Tries: %d" % (my_try, max_tries)) response = self.load("https://premium.rpnet.biz/client_api.php", get={"username": user, "password": data['password'], "action": "downloadInformation", "id": link_status['id']}) self.logDebug("JSON data hdd query: %s" % response) download_status = json_loads(response)['download'] if download_status['status'] == '100': link_status['generated'] = download_status['rpnet_link'] self.logDebug("Successfully downloaded to rpnet HDD: %s" % link_status['generated']) break else: self.logDebug("At %s%% for the file download" % download_status['status']) self.setWait(30) self.wait() my_try += 1 if my_try > max_tries: # We went over the limit! self.fail("Waited for about 15 minutes for download to finish but failed") if 'generated' in link_status: self.download(link_status['generated'], disposition=True) elif 'error' in link_status: self.fail(link_status['error']) else: self.fail("Something went wrong, not supposed to enter here")