summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Nils Hesse <nphesse@gmail.com> 2012-11-08 13:06:06 +0100
committerGravatar Nils Hesse <nphesse@gmail.com> 2012-11-08 13:06:06 +0100
commit5cbfd1ebff6845f2824f0086969b733346858d5a (patch)
treeea648d9a1648123c4f7fe5fa87794e07a201817c
parentupdate plugins - easybytez,filefactory,rusfolder,euroshare (diff)
downloadpyload-5cbfd1ebff6845f2824f0086969b733346858d5a.tar.xz
Added the reload.cc plugin
-rw-r--r--module/plugins/accounts/ReloadCc.py47
-rw-r--r--module/plugins/hooks/ReloadCc.py59
-rw-r--r--module/plugins/hoster/ReloadCc.py58
3 files changed, 164 insertions, 0 deletions
diff --git a/module/plugins/accounts/ReloadCc.py b/module/plugins/accounts/ReloadCc.py
new file mode 100644
index 000000000..1db5ba6af
--- /dev/null
+++ b/module/plugins/accounts/ReloadCc.py
@@ -0,0 +1,47 @@
+from module.plugins.Account import Account
+
+from module.common.json_layer import json_loads
+
+class ReloadCc(Account):
+ __name__ = "ReloadCc"
+ __version__ = "0.1"
+ __type__ = "account"
+ __description__ = """Reload.Cc account plugin"""
+
+ __author_name__ = ("Reload Team")
+ __author_mail__ = ("hello@reload.cc")
+
+ def loadAccountInfo(self, user, req):
+
+ # Get user data from premiumize.me
+ status = self.getAccountStatus(user, req)
+
+ # Parse account info
+ account_info = {"validuntil": float(status['msg']['expires']),
+ "pwdhash": status['msg']['hash'],
+ "trafficleft": -1}
+
+ return account_info
+
+ def login(self, user, data, req):
+
+ # Get user data from premiumize.me
+ status = self.getAccountStatus(user, req)
+
+ # Check if user and password are valid
+ if status['status'] != "ok":
+ self.wrongPassword()
+
+
+ def getAccountStatus(self, user, req):
+ pwd = "pwd=%s" % self.accounts[user]['password']
+
+ try:
+ pwd = "hash=%s" % self.accounts[user]['pwdhash']
+ except Exception:
+ pass
+
+ # Use reload.cc API v1 to retrieve account info and return the parsed json answer
+ answer = req.load("https://api.reload.cc/login?via=pyload&v=1&get_traffic=true&user=%s&%s" % (user, pwd))
+ return json_loads(answer)
+ \ No newline at end of file
diff --git a/module/plugins/hooks/ReloadCc.py b/module/plugins/hooks/ReloadCc.py
new file mode 100644
index 000000000..1d4adfbe3
--- /dev/null
+++ b/module/plugins/hooks/ReloadCc.py
@@ -0,0 +1,59 @@
+from module.plugins.internal.MultiHoster import MultiHoster
+
+from module.common.json_layer import json_loads
+from module.network.RequestFactory import getURL
+
+class ReloadCc(MultiHoster):
+ __name__ = "ReloadCc"
+ __version__ = "0.1"
+ __type__ = "hook"
+ __description__ = """Reload.cc hook plugin"""
+
+ __config__ = [("activated", "bool", "Activated", "False"),
+ ("hosterListMode", "all;listed;unlisted", "Use for hosters (if supported):", "all"),
+ ("hosterList", "str", "Hoster list (comma separated)", "")]
+
+ __author_name__ = ("Reload Team")
+ __author_mail__ = ("hello@reload.cc")
+
+ interval = 0 # Disable periodic calls, we dont use them anyway
+
+ def getHoster(self):
+ # If no accounts are available there will be no hosters available
+ if not self.account or not self.account.canUse():
+ print "ReloadCc: No accounts available"
+ return []
+
+ # Get account data
+ (user, data) = self.account.selectAccount()
+
+ pwd = "pwd=%s" % data['password']
+
+ try:
+ pwd = "hash=%s" % data['pwdhash']
+ except Exception:
+ pass
+
+ # Get supported hosters list from reload.cc using the json API v1
+ answer = getURL("https://api.reload.cc/login?via=pyload&v=1&get_supported=true&get_traffic=true&user=%s&%s" % (user, pwd))
+ data = json_loads(answer)
+
+
+ # If account is not valid thera are no hosters available
+ if data['status'] != "ok":
+ print "ReloadCc: Status is not ok: %s" % data['status']
+ return []
+
+ # Extract hosters from json file
+ return data['msg']['supportedHosters']
+
+ def coreReady(self):
+ # Get account plugin and check if there is a valid account available
+ self.account = self.core.accountManager.getAccountPlugin("ReloadCc")
+ if not self.account.canUse():
+ self.account = None
+ self.logError(_("Please add a valid reload.cc account first and restart pyLoad."))
+ return
+
+ # Run the overwriten core ready which actually enables the multihoster hook
+ return MultiHoster.coreReady(self) \ No newline at end of file
diff --git a/module/plugins/hoster/ReloadCc.py b/module/plugins/hoster/ReloadCc.py
new file mode 100644
index 000000000..4195afb89
--- /dev/null
+++ b/module/plugins/hoster/ReloadCc.py
@@ -0,0 +1,58 @@
+from module.plugins.Hoster import Hoster
+
+from module.common.json_layer import json_loads
+
+class ReloadCc(Hoster):
+ __name__ = "ReloadCc"
+ __version__ = "0.1"
+ __type__ = "hoster"
+ __description__ = """Reload.Cc hoster plugin"""
+
+ # Since we want to allow the user to specify the list of hoster to use we let MultiHoster.coreReady create the regex patterns for us using getHosters in our ReloadCc hook.
+ __pattern__ = None
+
+ __author_name__ = ("Reload Team")
+ __author_mail__ = ("hello@reload.cc")
+
+ def process(self, pyfile):
+ # Check account
+ if not self.account or not self.account.canUse():
+ self.logError(_("Please enter a valid reload.cc account or deactivate this plugin"))
+ self.fail("No valid reload.cc account provided")
+
+ # In some cases hostsers do not supply us with a filename at download, so we are going to set a fall back filename (e.g. for freakshare or xfileshare)
+ self.pyfile.name = self.pyfile.name.split('/').pop() # Remove everthing before last slash
+
+ # Correction for automatic assigned filename: Removing html at end if needed
+ suffix_to_remove = ["html", "htm", "php", "php3", "asp", "shtm", "shtml", "cfml", "cfm"]
+ temp = self.pyfile.name.split('.')
+ if temp.pop() in suffix_to_remove:
+ self.pyfile.name = ".".join(temp)
+
+ # Get account data
+ (user, data) = self.account.selectAccount()
+
+ pwd = "pwd=%s" % data['password']
+
+ try:
+ pwd = "hash=%s" % data['pwdhash']
+ except Exception:
+ pass
+
+ # Get rewritten link using the reload.cc api v1
+ answer = self.load("https://api.reload.cc/dl?via=pyload&v=1&user=%s&%s&uri=%s" % (user, pwd, self.pyfile.url))
+ data = json_loads(answer)
+
+ # Check status and decide what to do
+ status = data['status']
+ if status == "ok":
+ self.download(data['link'], disposition=True)
+ # TODO: real error codes/messages
+ elif status == 400:
+ self.fail("Invalid link")
+ elif status == 404:
+ self.offline()
+ elif status >= 500:
+ self.tempOffline()
+ else:
+ self.fail(data['msg'])