summaryrefslogtreecommitdiffstats
path: root/module/plugins
diff options
context:
space:
mode:
authorGravatar prOq <anonim> 2014-10-24 15:29:52 +0200
committerGravatar Walter Purcaro <vuolter@gmail.com> 2014-12-05 20:53:22 +0100
commitada1607d8a7190386e7a13dde2d8e312c2f6edf0 (patch)
treec426fa82a70a015f4d495d4f333fa815c5071d17 /module/plugins
parent[DodanePl] Mark dead XD (diff)
downloadpyload-ada1607d8a7190386e7a13dde2d8e312c2f6edf0.tar.xz
[RapiduNet] new hoster and account plugin
Diffstat (limited to 'module/plugins')
-rw-r--r--module/plugins/accounts/RapiduNet.py45
-rw-r--r--module/plugins/hoster/RapiduNet.py97
2 files changed, 142 insertions, 0 deletions
diff --git a/module/plugins/accounts/RapiduNet.py b/module/plugins/accounts/RapiduNet.py
new file mode 100644
index 000000000..2fabb6120
--- /dev/null
+++ b/module/plugins/accounts/RapiduNet.py
@@ -0,0 +1,45 @@
+# -*- coding: utf-8 -*-
+
+import re
+from module.plugins.Account import Account
+from module.common.json_layer import json_loads
+
+
+class RapiduNet(Account):
+ __name__ = "RapiduNet"
+ __type__ = "account"
+ __version__ = "0.01"
+
+ __description__ = """Rapidu.net account plugin"""
+ __license__ = "GPLv3"
+ __authors__ = [("prOq", None)]
+
+
+ ACCOUNT_INFO_PATTERN = '<a href="premium/" style="padding-left: 0px;">Account: <b>(.*?)</b></a>'
+
+
+ def loadAccountInfo(self, user, req):
+ premium = False
+
+ req.load('https://rapidu.net/ajax.php?a=getChangeLang', post={"_go": "", "lang": "en"})
+ self.html = req.load('https://rapidu.net/', decode=True)
+
+ m = re.search(self.ACCOUNT_INFO_PATTERN, self.html)
+ if m:
+ if m.group(1) == "Premium":
+ premium = True
+
+ return {"validuntil": None, "trafficleft": None, "premium": premium}
+
+
+ def login(self, user, data, req):
+ try:
+ json = req.load('https://rapidu.net/ajax.php?a=getUserLogin', post={"_go": "", "login": user, "pass": data['password'], "member": "1"})
+ json = json_loads(json)
+ self.logDebug(json)
+
+ if not json['message'] == "success":
+ self.wrongPassword()
+ except Exception, e:
+ self.logError(e)
+
diff --git a/module/plugins/hoster/RapiduNet.py b/module/plugins/hoster/RapiduNet.py
new file mode 100644
index 000000000..624c5844b
--- /dev/null
+++ b/module/plugins/hoster/RapiduNet.py
@@ -0,0 +1,97 @@
+# -*- coding: utf-8 -*-
+
+import re
+
+from pycurl import HTTPHEADER
+from module.common.json_layer import json_loads
+from time import time, altzone
+
+from module.plugins.internal.CaptchaService import ReCaptcha
+from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo
+
+
+class RapiduNet(SimpleHoster):
+ __name__ = "RapiduNet"
+ __type__ = "hoster"
+ __version__ = "0.01"
+ __pattern__ = r'https?://(?:www\.)?rapidu\.net/(?P<fileID>\d{10})(/|/.*)?'
+ __description__ = """Rapidu.net hoster plugin"""
+ __authors__ = [("prOq", None)]
+
+
+ FILE_INFO_PATTERN = r'<h1 title="(?P<N>.*)">.*</h1>\s*<small>(?P<S>\d+(\.\d+)?)\s(?P<U>\w+)</small>'
+
+ OFFLINE_PATTERN = '404 - (File not found|Nie znaleziono pliku)'
+ ERROR_PATTERN = '<div class="error">'
+
+ RECAPTCHA_KEY = r'6Ld12ewSAAAAAHoE6WVP_pSfCdJcBQScVweQh8Io'
+
+ fileID = ""
+
+
+ def setup(self):
+ self.resumeDownload = True
+ self.multiDL = True
+
+ if self.premium:
+ self.limitDL = -1
+ else:
+ self.limitDL = 2
+
+
+ def process(self, pyfile):
+ m = re.match(self.__pattern__, self.pyfile.url)
+ if m:
+ self.fileID = m.group('fileID')
+ else:
+ self.fail("URL mismatch")
+
+ self.handleFree()
+
+
+ def handleFree(self):
+ self.html = self.load(self.pyfile.url, decode=True)
+
+ if re.search(self.ERROR_PATTERN, self.html):
+ self.fail("An error occured on hoster")
+
+ self.req.http.lastURL = self.pyfile.url
+ self.req.http.c.setopt(HTTPHEADER, ["X-Requested-With: XMLHttpRequest"])
+
+ jsvars = self.getJsonResponse("https://rapidu.net/ajax.php?a=getLoadTimeToDownload", {"_go": None})
+
+ if str(jsvars['timeToDownload']) is "stop":
+ t = (24 *60 * 60) - (int(time()) % (24 *60 * 60)) + altzone
+ t = 10 if t < 1 else None # in case of not synchronised clock
+ self.logInfo("You've reach your daily download transfer")
+ self.retry(10, t, "Try tomorrow again")
+ else:
+ self.wait((int(jsvars['timeToDownload'])-int(time())))
+
+ recaptcha = ReCaptcha(self)
+
+ for _ in xrange(10):
+ challenge, code = recaptcha.challenge(self.RECAPTCHA_KEY)
+
+ self.req.http.c.setopt(HTTPHEADER, ["X-Requested-With: XMLHttpRequest"])
+ jsvars = self.getJsonResponse("https://rapidu.net/ajax.php?a=getCheckCaptcha", {
+ "_go": None,
+ "captcha1": challenge,
+ "captcha2": code,
+ "fileId": self.fileID
+ })
+
+ if jsvars['message'] == 'success':
+ self.download(jsvars['url'])
+ break
+
+
+ def getJsonResponse(self, url, post_data):
+ response = self.load(url, post=post_data, decode=True)
+ if not response.startswith('{'):
+ self.retry()
+ self.logDebug(url, response)
+ return json_loads(response)
+
+
+getInfo = create_getInfo(RapiduNet)