summaryrefslogtreecommitdiffstats
path: root/module/plugins/hoster/SimplydebridCom.py
diff options
context:
space:
mode:
Diffstat (limited to 'module/plugins/hoster/SimplydebridCom.py')
-rw-r--r--module/plugins/hoster/SimplydebridCom.py60
1 files changed, 23 insertions, 37 deletions
diff --git a/module/plugins/hoster/SimplydebridCom.py b/module/plugins/hoster/SimplydebridCom.py
index b4be77031..aae71d983 100644
--- a/module/plugins/hoster/SimplydebridCom.py
+++ b/module/plugins/hoster/SimplydebridCom.py
@@ -2,62 +2,48 @@
import re
-from module.plugins.internal.MultiHoster import MultiHoster, create_getInfo
+from module.plugins.internal.MultiHoster import MultiHoster, create_getInfo, replace_patterns
class SimplydebridCom(MultiHoster):
__name__ = "SimplydebridCom"
__type__ = "hoster"
- __version__ = "0.14"
+ __version__ = "0.17"
- __pattern__ = r'http://(?:www\.)?\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}/sd\.php/*'
+ __pattern__ = r'http://\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}/sd\.php'
+ __config__ = [("use_premium", "bool", "Use premium account if available", True)]
- __description__ = """Simply-debrid.com hoster plugin"""
+ __description__ = """Simply-debrid.com multi-hoster plugin"""
__license__ = "GPLv3"
__authors__ = [("Kagenoshin", "kagenoshin@gmx.ch")]
- def setup(self):
- self.resumeDownload = True
- self.multiDL = True
- self.chunkLimit = 1
-
-
- def handlePremium(self):
+ def handlePremium(self, pyfile):
#fix the links for simply-debrid.com!
- self.link = self.pyfile.url
- self.link = self.link.replace("clz.to", "cloudzer.net/file")
- self.link = self.link.replace("http://share-online", "http://www.share-online")
- self.link = self.link.replace("ul.to", "uploaded.net/file")
- self.link = self.link.replace("uploaded.com", "uploaded.net")
- self.link = self.link.replace("filerio.com", "filerio.in")
- self.link = self.link.replace("lumfile.com", "lumfile.se")
-
- if('fileparadox' in self.link):
+ self.link = replace_patterns(pyfile.url, [("clz.to", "cloudzer.net/file")
+ ("http://share-online", "http://www.share-online")
+ ("ul.to", "uploaded.net/file")
+ ("uploaded.com", "uploaded.net")
+ ("filerio.com", "filerio.in")
+ ("lumfile.com", "lumfile.se")])
+
+ if 'fileparadox' in self.link:
self.link = self.link.replace("http://", "https://")
- if re.match(self.__pattern__, self.link):
- self.link = self.link
-
- self.logDebug("New URL: %s" % self.link)
-
- if not re.match(self.__pattern__, self.link):
- page = self.load("http://simply-debrid.com/api.php", get={'dl': self.link}) # +'&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"))
- self.link = page
+ self.html = self.load("http://simply-debrid.com/api.php", get={'dl': self.link})
+ if 'tiger Link' in self.html or 'Invalid Link' in self.html or ('API' in self.html and 'ERROR' in self.html):
+ self.error(_("Unable to unrestrict link"))
- self.setWait(5)
- self.wait()
+ self.link = self.html
+ self.wait(5)
- def checkFile(self):
- super(SimplydebridCom, self).checkFile()
- check = self.checkDownload({"bad1": "No address associated with hostname", "bad2": "<html"})
+ def checkFile(self, rules={}):
+ if self.checkDownload({"error": "No address associated with hostname"}):
+ self.retry(24, 3 * 60, _("Bad file downloaded"))
- if check == "bad1" or check == "bad2":
- self.retry(24, 3 * 60, "Bad file downloaded")
+ return super(SimplydebridCom, self).checkFile(rules)
getInfo = create_getInfo(SimplydebridCom)