diff options
Diffstat (limited to 'module/plugins')
| -rw-r--r-- | module/plugins/accounts/SimplydebridCom.py | 30 | ||||
| -rw-r--r-- | module/plugins/hooks/SimplydebridCom.py | 20 | ||||
| -rw-r--r-- | module/plugins/hoster/SimplydebridCom.py | 61 | 
3 files changed, 111 insertions, 0 deletions
| diff --git a/module/plugins/accounts/SimplydebridCom.py b/module/plugins/accounts/SimplydebridCom.py new file mode 100644 index 000000000..82b499bbd --- /dev/null +++ b/module/plugins/accounts/SimplydebridCom.py @@ -0,0 +1,30 @@ +# -*- coding: utf-8 -*- +from time import mktime, strptime + +from module.plugins.Account import Account + + +class SimplydebridCom(Account): +    __name__ = "SimplydebridCom" +    __version__ = "0.1" +    __type__ = "account" +    __description__ = """Simply-Debrid.com account plugin""" +    __author_name__ = ("Kagenoshin") +    __author_mail__ = ("kagenoshin@gmx.ch") + +    def loadAccountInfo(self, user, req): +        get_data = {'login': 2, 'u': self.loginname, 'p': self.password} +        response = req.load("http://simply-debrid.com/api.php", get=get_data, decode=True) +        data = [x.strip() for x in response.split(";")] +        if str(data[0]) != "1": +            return {"premium": False} +        else: +            return {"trafficleft": -1, "validuntil": mktime(strptime(str(data[2]), "%d/%m/%Y"))} + +    def login(self, user, data, req): +        self.loginname = user +        self.password = data["password"] +        get_data = {'login': 1, 'u': self.loginname, 'p': self.password} +        response = req.load("http://simply-debrid.com/api.php", get=get_data, decode=True) +        if response != "02: loggin success": +            self.wrongPassword() diff --git a/module/plugins/hooks/SimplydebridCom.py b/module/plugins/hooks/SimplydebridCom.py new file mode 100644 index 000000000..3272df567 --- /dev/null +++ b/module/plugins/hooks/SimplydebridCom.py @@ -0,0 +1,20 @@ +# -*- coding: utf-8 -*- + +from module.network.RequestFactory import getURL +from module.plugins.internal.MultiHoster import MultiHoster + + +class SimplydebridCom(MultiHoster): +    __name__ = "SimplydebridCom" +    __version__ = "0.01" +    __type__ = "hook" +    __config__ = [("activated", "bool", "Activated", "False"), +                  ("hosterListMode", "all;listed;unlisted", "Use for hosters (if supported)", "all"), +                  ("hosterList", "str", "Hoster list (comma separated)", "")] +    __description__ = """Simply-Debrid.com hook plugin""" +    __author_name__ = ("Kagenoshin") +    __author_mail__ = ("kagenoshin@gmx.ch") + +    def getHoster(self): +        page = getURL("http://simply-debrid.com/api.php?list=1") +        return [x.strip() for x in page.rstrip(';').replace("\"", "").split(";")] diff --git a/module/plugins/hoster/SimplydebridCom.py b/module/plugins/hoster/SimplydebridCom.py new file mode 100644 index 000000000..67cc39255 --- /dev/null +++ b/module/plugins/hoster/SimplydebridCom.py @@ -0,0 +1,61 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +from urllib import quote, unquote +import re + +from module.plugins.Hoster import Hoster + + +class SimplydebridCom(Hoster): +    __name__ = "SimplydebridCom" +    __version__ = "0.1" +    __type__ = "hoster" +    __pattern__ = r"http://\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}/sd.php/*" +    __description__ = """simply-debrid.com hoster plugin""" +    __author_name__ = ("Kagenoshin") +    __author_mail__ = ("kagenoshin@gmx.ch") + +    def setup(self): +        self.resumeDownload = self.multiDL = True +        self.chunkLimit = 1 + +    def process(self, pyfile): +        if not self.account: +            self.logError(_("Please enter your %s account or deactivate this plugin") % "simply-debrid.com") +            self.fail("No simply-debrid.com account provided") + +        self.logDebug("Old URL: %s" % pyfile.url) + +        #fix the links for simply-debrid.com! +        new_url = pyfile.url +        new_url = new_url.replace("clz.to", "cloudzer.net/file") +        new_url = new_url.replace("http://share-online", "http://www.share-online") +        new_url = new_url.replace("ul.to", "uploaded.net/file") +        new_url = new_url.replace("uploaded.com", "uploaded.net") +        new_url = new_url.replace("filerio.com", "filerio.in") +        new_url = new_url.replace("lumfile.com", "lumfile.se") +        if('fileparadox' in new_url): +            new_url = new_url.replace("http://", "https://") + +        if re.match(self.__pattern__, new_url): +            new_url = new_url + +        self.logDebug("New URL: %s" % new_url) + +        if not re.match(self.__pattern__, new_url): +            page = self.load('http://simply-debrid.com/api.php', get={'dl': new_url}) #+'&u='+self.user+'&p='+self.account.getAccountData(self.user)['password']) +            if 'tiger Link' in page or 'Invalid Link' in page or ('API' in page and 'ERROR' in page): +                self.fail('Unable to unrestrict link') +            new_url = page + +        self.setWait(5) +        self.wait() +        self.logDebug("Unrestricted URL: " + new_url) + +        self.download(new_url, disposition=True) + +        check = self.checkDownload({"bad1": "No address associated with hostname", "bad2": "<html"}) + +        if check == "bad1" or check == "bad2": +            self.retry(24, 150, 'Bad file downloaded') | 
