summaryrefslogtreecommitdiffstats
path: root/module/plugins/hoster
diff options
context:
space:
mode:
authorGravatar Walter Purcaro <vuolter@gmail.com> 2014-12-27 14:37:29 +0100
committerGravatar Walter Purcaro <vuolter@gmail.com> 2014-12-27 14:37:29 +0100
commitfd8d1bd2b86db4be1c9b7200a50982f80c0c5e58 (patch)
treedf95fad760db41a2618db3aafe32b72e39983c85 /module/plugins/hoster
parent[ShareonlineBiz] Fix account wrong password recognition (diff)
parentNew __authors__ key, added __license__ (diff)
downloadpyload-fd8d1bd2b86db4be1c9b7200a50982f80c0c5e58.tar.xz
Merge pull request #682 from synweap15/rapideo
MultihosterRapideo.pl
Diffstat (limited to 'module/plugins/hoster')
-rw-r--r--module/plugins/hoster/RapideoPl.py102
1 files changed, 102 insertions, 0 deletions
diff --git a/module/plugins/hoster/RapideoPl.py b/module/plugins/hoster/RapideoPl.py
new file mode 100644
index 000000000..9fd20e69e
--- /dev/null
+++ b/module/plugins/hoster/RapideoPl.py
@@ -0,0 +1,102 @@
+# -*- coding: utf-8 -*-
+
+from module.common.json_layer import json_loads as loads
+from module.plugins.internal.SimpleHoster import SimpleHoster
+
+
+class RapideoPl(SimpleHoster):
+ __name__ = "RapideoPl"
+ __version__ = "0.01"
+ __type__ = "hoster"
+ __description__ = "Rapideo.pl hoster plugin"
+ __license__ = "GPLv3"
+ __authors__ = [("goddie", "dev@rapideo.pl")]
+
+ _api_url = "http://enc.rapideo.pl"
+
+ _api_query = {"site": "newrd",
+ "output": "json",
+ "username": "",
+ "password": "",
+ "url": ""}
+
+ _error_codes = {
+ 0: "[%s] Incorrect login credentials",
+ 1: "[%s] Not enough transfer to download - top-up your account",
+ 2: "[%s] Incorrect / dead link",
+ 3: "[%s] Error connecting to hosting, try again later",
+ 9: "[%s] Premium account has expired",
+ 15: "[%s] Hosting no longer supported",
+ 80: "[%s] Too many incorrect login attempts, account blocked for 24h"
+ }
+
+ _usr = False
+ _pwd = False
+
+ def setup(self):
+ self.resumeDownload = True
+ self.multiDL = True
+
+ def get_username_password(self):
+ if not self.account:
+ self.fail(_("Please enter your %s account or deactivate this plugin") % "Rapideo.pl")
+ else:
+ self._usr = self.account.getAccountData(self.user).get('usr')
+ self._pwd = self.account.getAccountData(self.user).get('pwd')
+
+ def runFileQuery(self, url, mode=None):
+ query = self._api_query.copy()
+ query["username"] = self._usr
+ query["password"] = self._pwd
+ query["url"] = url
+
+ if mode == "fileinfo":
+ query['check'] = 2
+ query['loc'] = 1
+
+ self.logDebug(query)
+ return self.load(self._api_url, post=query)
+
+ def process(self, pyfile):
+ self.get_username_password()
+ try:
+ data = self.runFileQuery(pyfile.url, 'fileinfo')
+ except Exception:
+ self.logDebug("RunFileQuery error")
+ self.tempOffline()
+
+ try:
+ parsed = loads(data)
+ except Exception:
+ self.logDebug("Loads error")
+ self.tempOffline()
+
+ self.logDebug(parsed)
+
+ if "errno" in parsed.keys():
+ if parsed["errno"] in self._error_codes:
+ # error code in known
+ self.fail(self._error_codes[parsed["errno"]] % self.__name__)
+ else:
+ # error code isn't yet added to plugin
+ self.fail(
+ parsed["errstring"]
+ or "Unknown error (code: %s)" % parsed["errno"]
+ )
+
+ if "sdownload" in parsed:
+ if parsed["sdownload"] == "1":
+ self.fail(
+ "Download from %s is possible only using Rapideo.pl webiste \
+ directly. Update this plugin." % parsed["hosting"])
+
+ pyfile.name = parsed["filename"]
+ pyfile.size = parsed["filesize"]
+
+ try:
+ result_dl = self.runFileQuery(pyfile.url, 'filedownload')
+ except Exception:
+ self.logDebug("runFileQuery error #2")
+ self.tempOffline()
+
+ self.download(result_dl, disposition=True)