#!/usr/bin/env python # -*- coding: utf-8 -*- import re from time import time from urllib import quote, unquote from random import randrange from module.utils import parseFileSize, remove_chars from module.common.json_layer import json_loads from module.plugins.Hoster import Hoster class RealdebridCom(Hoster): __name__ = "RealdebridCom" __version__ = "0.49" __type__ = "hoster" __pattern__ = r"https?://.*real-debrid\..*" __description__ = """Real-Debrid.com hoster plugin""" __author_name__ = ("Devirex, Hazzard") __author_mail__ = ("naibaf_11@yahoo.de") def getFilename(self, url): try: name = unquote(url.rsplit("/", 1)[1]) except IndexError: name = "Unknown_Filename..." if not name or name.endswith(".."): #incomplete filename, append random stuff name += "%s.tmp" % randrange(100,999) return name def init(self): self.tries = 0 self.chunkLimit = 3 self.resumeDownload = True def process(self, pyfile): if not self.account: self.logError(_("Please enter your Real-debrid account or deactivate this plugin")) self.fail("No Real-debrid account provided") self.log.debug("Real-Debrid: Old URL: %s" % pyfile.url) if re.match(self.__pattern__, pyfile.url): new_url = pyfile.url else: password = self.getPassword().splitlines() if not password: password = "" else: password = password[0] url = "http://real-debrid.com/ajax/unrestrict.php?lang=en&link=%s&password=%s&time=%s" % (quote(pyfile.url, ""), password, int(time()*1000)) page = self.load(url) data = json_loads(page) self.logDebug("Returned Data: %s" % data) if data["error"] != 0: if data["message"] == "Your file is unavailable on the hoster.": self.offline() else: self.logWarning(data["message"]) self.tempOffline() else: if self.pyfile.name is not None and self.pyfile.name.endswith('.tmp') and data["file_name"]: self.pyfile.name = data["file_name"] self.pyfile.size = parseFileSize(data["file_size"]) new_url = data['generated_links'][0][-1] if self.getConfig("https"): new_url = new_url.replace("http://", "https://") else: new_url = new_url.replace("https://", "http://") self.log.debug("Real-Debrid: New URL: %s" % new_url) if pyfile.name.startswith("http") or pyfile.name.startswith("Unknown") or pyfile.name.endswith('..'): #only use when name wasnt already set pyfile.name = self.getFilename(new_url) self.download(new_url, disposition=True) check = self.checkDownload( {"error": "An error occured while processing your request"}) if check == "error": #usual this download can safely be retried self.retry(reason="An error occured while generating link.", wait_time=60)