summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar igel-kun <mathiaswe@gmx.de> 2014-04-10 13:52:22 +0200
committerGravatar Stefano <l.stickell@yahoo.it> 2014-04-21 17:12:25 +0200
commit4983c9f3c8238c948a87b93d461cccf059e23130 (patch)
treef75507a4982536bc9745773f666fa0f199c40e58
parentXFS: Improved CAPTCHA_DIV_PATTERN (diff)
downloadpyload-4983c9f3c8238c948a87b93d461cccf059e23130.tar.xz
New hoster: UpstoreNet
Merges #581 (cherry picked from commit 7d38c98efe5e0d48062a0e67767f17da0982a88d)
-rw-r--r--module/plugins/hoster/UpstoreNet.py74
1 files changed, 74 insertions, 0 deletions
diff --git a/module/plugins/hoster/UpstoreNet.py b/module/plugins/hoster/UpstoreNet.py
new file mode 100644
index 000000000..d2b3e0529
--- /dev/null
+++ b/module/plugins/hoster/UpstoreNet.py
@@ -0,0 +1,74 @@
+# -*- coding: utf-8 -*-
+import re
+
+from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo
+from module.plugins.internal.CaptchaService import ReCaptcha
+
+
+class UpstoreNet(SimpleHoster):
+ __name__ = "UpstoreNet"
+ __type__ = "hoster"
+ __pattern__ = r"https?://(?:www\.)?upstore\.net/"
+ __version__ = "0.01"
+ __description__ = """Upstore.Net File Download Hoster"""
+ __author_name__ = ("igel")
+
+ FILE_INFO_PATTERN = r'<div class="comment">.*?</div>\s*\n<h2 style="margin:0">(?P<N>.*?)</h2>\s*\n<div class="comment">\s*\n\s*(?P<S>[\d.]+) (?P<U>\w+)'
+ FILE_OFFLINE_PATTERN = r'<span class="error">File not found</span>'
+
+ WAIT_PATTERN = r"var sec = (\d+)"
+ RECAPTCHA_PATTERN = r"Recaptcha.create.*?'(.*?)'"
+ CHASH_PATTERN = r'<input type="hidden" name="hash" value="([^"]*)">'
+ DIRECT_LINK_PATTERN = r'<a href="(https?://.*?)" target="_blank"><b>'
+
+ def handleFree(self):
+ # STAGE 1: get link to continue
+ m = re.search(self.CHASH_PATTERN, self.html)
+ if not m:
+ self.parseError("could not detect hash")
+ chash = m.group(1)
+ self.logDebug("read hash " + chash)
+ # continue to stage2
+ post_data = {'hash': chash, 'free': 'Slow download'}
+ self.html = self.load(self.pyfile.url, post=post_data, decode=True)
+
+ # try the captcha 5 times
+ for i in xrange(5):
+ # STAGE 2: solv captcha and wait
+ # first get the infos we need: recaptcha key and wait time
+ m = re.search(self.RECAPTCHA_PATTERN, self.html)
+ if not m:
+ self.parseError("could not find recaptcha pattern")
+ recaptcha_key = m.group(1)
+ self.logDebug("using captcha key " + recaptcha_key)
+ recaptcha = ReCaptcha(self)
+
+ m = re.search(self.WAIT_PATTERN, self.html)
+ if not m:
+ self.parseError("could not find wait pattern")
+ wait_time = m.group(1)
+
+ # then, handle the captcha
+ challenge, code = recaptcha.challenge(recaptcha_key)
+ post_data['recaptcha_challenge_field'] = challenge
+ post_data['recaptcha_response_field'] = code
+
+ # then, do the waiting
+ self.wait(wait_time)
+
+ self.html = self.load(self.pyfile.url, post=post_data, decode=True)
+
+ # STAGE 3: get direct link
+ m = re.search(self.DIRECT_LINK_PATTERN, self.html, re.DOTALL)
+ if m:
+ break
+
+ if not m:
+ self.parseError("could not detect direct link")
+
+ direct = m.group(1)
+ self.logDebug('found direct link: ' + direct)
+ self.download(direct, disposition=True)
+
+
+getInfo = create_getInfo(UpstoreNet)