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.py44
1 files changed, 19 insertions, 25 deletions
diff --git a/module/plugins/hoster/SimplydebridCom.py b/module/plugins/hoster/SimplydebridCom.py
index a26bc5751..aae71d983 100644
--- a/module/plugins/hoster/SimplydebridCom.py
+++ b/module/plugins/hoster/SimplydebridCom.py
@@ -2,15 +2,16 @@
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.15"
+ __version__ = "0.17"
__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 multi-hoster plugin"""
__license__ = "GPLv3"
@@ -19,37 +20,30 @@ class SimplydebridCom(MultiHoster):
def handlePremium(self, pyfile):
#fix the links for simply-debrid.com!
- self.link = 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.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.logDebug("New URL: %s" % self.link)
+ self.link = self.html
- if not re.match(self.__pattern__, self.link):
- page = self.load("http://simply-debrid.com/api.php", get={'dl': self.link})
- 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.wait(5)
- self.setWait(5)
- self.wait()
-
- def checkFile(self):
+ def checkFile(self, rules={}):
if self.checkDownload({"error": "No address associated with hostname"}):
- self.retry(24, 3 * 60, "Bad file downloaded")
+ self.retry(24, 3 * 60, _("Bad file downloaded"))
- return super(SimplydebridCom, self).checkFile()
+ return super(SimplydebridCom, self).checkFile(rules)
getInfo = create_getInfo(SimplydebridCom)