diff options
Diffstat (limited to 'module')
-rw-r--r-- | module/plugins/accounts/FilefactoryCom.py | 6 | ||||
-rw-r--r-- | module/plugins/accounts/FshareVn.py | 10 | ||||
-rw-r--r-- | module/plugins/crypter/C1neonCom.py | 9 | ||||
-rw-r--r-- | module/plugins/hooks/BypassCaptcha.py | 167 | ||||
-rw-r--r-- | module/plugins/hoster/FreakshareCom.py | 10 | ||||
-rw-r--r-- | module/plugins/hoster/IcyFilesCom.py | 4 | ||||
-rw-r--r-- | module/plugins/hoster/ZippyshareCom.py | 29 |
7 files changed, 215 insertions, 20 deletions
diff --git a/module/plugins/accounts/FilefactoryCom.py b/module/plugins/accounts/FilefactoryCom.py index 73431b546..356c5d22a 100644 --- a/module/plugins/accounts/FilefactoryCom.py +++ b/module/plugins/accounts/FilefactoryCom.py @@ -23,13 +23,13 @@ from time import mktime, strptime class FilefactoryCom(Account): __name__ = "FilefactoryCom" - __version__ = "0.11" + __version__ = "0.12" __type__ = "account" __description__ = """filefactory.com account plugin""" __author_name__ = ("zoidberg") __author_mail__ = ("zoidberg@mujmail.cz") - ACCOUNT_INFO_PATTERN = r'"greenText">Premium member until<.*?datetime="(.*?)"' + ACCOUNT_INFO_PATTERN = r'<a href="/premium/">.*?datetime="(.*?)"' def loadAccountInfo(self, user, req): html = req.load("http://www.filefactory.com/member/") @@ -51,4 +51,4 @@ class FilefactoryCom(Account): "redirect": "/"}) if '/member/login.php?err=1' in req.http.header: - self.wrongPassword()
\ No newline at end of file + self.wrongPassword() diff --git a/module/plugins/accounts/FshareVn.py b/module/plugins/accounts/FshareVn.py index 46d2d5166..e51009f50 100644 --- a/module/plugins/accounts/FshareVn.py +++ b/module/plugins/accounts/FshareVn.py @@ -24,7 +24,7 @@ import re class FshareVn(Account): __name__ = "FshareVn" - __version__ = "0.01" + __version__ = "0.02" __type__ = "account" __description__ = """fshare.vn account plugin""" __author_name__ = ("zoidberg") @@ -47,13 +47,13 @@ class FshareVn(Account): return {"validuntil": validuntil, "trafficleft": trafficleft} def login(self, user, data, req): - req.http.c.setopt(REFERER, "http://www.fshare.vn/login.php") + req.http.c.setopt(REFERER, "https://www.fshare.vn/login.php") - html = req.load('http://www.fshare.vn/login.php', post = { + html = req.load('https://www.fshare.vn/login.php', post = { "login_password" : data['password'], "login_useremail" : user, - "url_refe" : "http://www.fshare.vn/login.php" + "url_refe" : "https://www.fshare.vn/login.php" }, referer = True, decode = True) if not '<img alt="VIP"' in html: - self.wrongPassword()
\ No newline at end of file + self.wrongPassword() diff --git a/module/plugins/crypter/C1neonCom.py b/module/plugins/crypter/C1neonCom.py index e9861ab54..1a0c3c90f 100644 --- a/module/plugins/crypter/C1neonCom.py +++ b/module/plugins/crypter/C1neonCom.py @@ -24,7 +24,7 @@ class C1neonCom(Crypter): __name__ = "C1neonCom" __type__ = "container" __pattern__ = r"http://(www\.)?c1neon.com/.*?" - __version__ = "0.02" + __version__ = "0.03" __config__ = [ ("changeNameS", "Packagename;Show;Season;Episode", "Rename Show by", "Show"), ("changeName", "Packagename;Movie", "Rename Movie by", "Movie"), @@ -99,8 +99,11 @@ class C1neonCom(Crypter): #selects the preferred hoster, after that selects any hoster (ignoring the one to ignore) #selects only one Hoster def getpreferred(self, hosterslist): - hosterlist = hosterslist['d'] - if self.getConfig("useStreams"): + if hosterslist['u'] is not None: + hosterlist = hosterslist['u'] + if hosterslist['d'] is not None: + hosterlist.append(hosterslist['d']) + if self.getConfig("useStreams") and hosterslist['s'] is not None: hosterlist.append(hosterslist['s']) result = [] diff --git a/module/plugins/hooks/BypassCaptcha.py b/module/plugins/hooks/BypassCaptcha.py new file mode 100644 index 000000000..892c5cca6 --- /dev/null +++ b/module/plugins/hooks/BypassCaptcha.py @@ -0,0 +1,167 @@ +# -*- coding: utf-8 -*- +""" + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 3 of the License, + or (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + See the GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, see <http://www.gnu.org/licenses/>. + + @author: RaNaN +""" + +import base64 + +try: + from json import loads +except ImportError: + from simplejson import loads + +from thread import start_new_thread +from pycurl import FORM_FILE, LOW_SPEED_TIME + +from module.network.RequestFactory import getURL, getRequest +from module.network.HTTPRequest import BadHeader + +from module.plugins.Addon import Addon + +class BypassCaptchaException(Exception): + def __init__(self, err): + self.err = err + + def getCode(self): + return self.err + + def __str__(self): + return "<BypassCaptchaException %s>" % self.err + + def __repr__(self): + return "<BypassCaptchaException %s>" % self.err + +class BypassCaptcha(Addon): + __name__ = "BypassCaptcha" + __version__ = "0.01" + __description__ = """send captchas to bypasscaptcha.com""" + __config__ = [("activated", "bool", "Activated", True), + ("key", "str", "Key", ""), + ("force", "bool", "Force CT even if client is connected", False), + __author_name__ = ("RaNaN") + __author_mail__ = ("RaNaN@pyload.org") + + SUBMIT_URL = "http://bypasscaptcha.com/upload.php" + RESPOND_URL = "http://bypasscaptcha.com/check_value.php" + GETCREDITS_URL = "http://bypasscaptcha.com/ex_left.php" + + def setup(self): + self.info = {} + + def getCredits(self): + json = getURL(BypassCaptcha.GETCREDITS_URL % {"key": self.getConfig("key")}) + response = loads(json) + if response[0] < 0: + raise BypassCaptchaException(response[1]) + else: + self.logInfo(_("%s credits left") % response['Left']) + self.info["credits"] = response['Left'] + return response['Left'] + + def submit(self, captcha, captchaType="file", match=None): + #if type(captcha) == str and captchaType == "file": + # raise BypassCaptchaException("Invalid Type") + assert captchaType in ("file", "url-jpg", "url-jpeg", "url-png", "url-bmp") + + self.logInfo(_("submitting %s, type %s") % (captcha, captchaType)) + + req = getRequest() + + #raise timeout threshold + req.c.setopt(LOW_SPEED_TIME, 80) + + try: + img = Image.open(captcha) + self.logDebug("CAPTCHA IMAGE", img, img.format) + output = StringIO.StringIO() + img.save(output, "JPEG") + data = base64.b64encode(output.getvalue()) + output.close() + except Exception, e: + raise BypassCaptchaException("Reading or converting captcha image failed: %s" % e) + + try: + json = req.load(BypassCaptcha.SUBMIT_URL, post={"key": self.getConfig("key"), + "password": self.getConfig("passkey"), + "file": data, + "submit": "Submit", + "gen_task_id": 1, + "base64_code": 1}) + finally: + req.close() + + response = loads(json) + if response[0] < 0: + raise BypassCaptchaException(response[1]) + + ticket = response['TaskId'] + result = response['Value'] + self.logDebug("result %s : %s" % (ticket,result)) + + return ticket, result + + def respond(self, ticket, success): + try: + json = getURL(BypassCaptcha.RESPOND_URL, post={ "key": self.getConfig("key"), + "task_id": ticket, + "cv": 1 if success else 0, + "submit": "Submit" }) + + response = loads(json) + if response[0] < 0: + raise BypassCaptchaException(response[1]) + + except BadHeader, e: + self.logError(_("Could not send response."), str(e)) + + def newCaptchaTask(self, task): + if not task.isTextual(): + return False + + if not self.getConfig("key"): + return False + + if self.core.isClientConnected() and not self.getConfig("force"): + return False + + if self.getCredits() > 0: + task.handler.append(self) + task.setWaiting(100) + start_new_thread(self.processCaptcha, (task,)) + + else: + self.logInfo(_("Your BypassCaptcha Account has not enough credits")) + + def captchaCorrect(self, task): + if "TaskId" in task.data: + ticket = task.data["TaskId"] + self.respond(ticket, True) + + def captchaInvalid(self, task): + if "TaskId" in task.data: + ticket = task.data["TaskId"] + self.respond(ticket, False) + + def processCaptcha(self, task): + c = task.captchaFile + try: + ticket, result = self.submit(c) + except BypassCaptchaException, e: + task.error = e.getCode() + return + + task.data["ticket"] = ticket + task.setResult(result)
\ No newline at end of file diff --git a/module/plugins/hoster/FreakshareCom.py b/module/plugins/hoster/FreakshareCom.py index 29a0bda8f..56e02cbdc 100644 --- a/module/plugins/hoster/FreakshareCom.py +++ b/module/plugins/hoster/FreakshareCom.py @@ -9,7 +9,7 @@ class FreakshareCom(Hoster): __name__ = "FreakshareCom"
__type__ = "hoster"
__pattern__ = r"http://(?:www\.)?freakshare\.(net|com)/files/\S*?/"
- __version__ = "0.36"
+ __version__ = "0.37"
__description__ = """Freakshare.com Download Hoster"""
__author_name__ = ("sitacuisses","spoob","mkaay", "Toilal")
__author_mail__ = ("sitacuisses@yahoo.de","spoob@pyload.org","mkaay@mkaay.de", "toilal.dev@gmail.com")
@@ -39,7 +39,8 @@ class FreakshareCom(Hoster): check = self.checkDownload({"bad": "bad try",
"paralell": "> Sorry, you cant download more then 1 files at time. <",
- "empty": "Warning: Unknown: Filename cannot be empty"})
+ "empty": "Warning: Unknown: Filename cannot be empty",
+ "wrong_captcha": "Wrong Captcha!"})
if check == "bad":
self.fail("Bad Try.")
@@ -48,7 +49,10 @@ class FreakshareCom(Hoster): self.wait()
self.retry()
if check == "empty":
- self.fail("File not downloadable")
+ self.fail("File not downloadable")
+ if check == "wrong_captcha":
+ self.invalidCaptcha()
+ self.retry()
def prepare(self):
pyfile = self.pyfile
diff --git a/module/plugins/hoster/IcyFilesCom.py b/module/plugins/hoster/IcyFilesCom.py index 73dd5f7c9..09458732e 100644 --- a/module/plugins/hoster/IcyFilesCom.py +++ b/module/plugins/hoster/IcyFilesCom.py @@ -33,7 +33,7 @@ def getInfo(urls): size = re.search(IcyFilesCom.SIZE_PATTERN, html) if name is not None: name = name.group(1) - size = (size.group(1) * 1000000) + size = (int(size.group(1)) * 1000000) result.append((name, size, 2, url)) yield result @@ -42,7 +42,7 @@ class IcyFilesCom(Hoster): __name__ = "IcyFilesCom" __type__ = "hoster" __pattern__ = r"http://(?:www\.)?icyfiles\.com/.*" - __version__ = "0.02" + __version__ = "0.03" __description__ = """IcyFiles.com plugin - free only""" __author_name__ = ("godofdream") __author_mail__ = ("soilfiction@gmail.com") diff --git a/module/plugins/hoster/ZippyshareCom.py b/module/plugins/hoster/ZippyshareCom.py index 0dde85e2c..001e2b296 100644 --- a/module/plugins/hoster/ZippyshareCom.py +++ b/module/plugins/hoster/ZippyshareCom.py @@ -10,7 +10,7 @@ class ZippyshareCom(SimpleHoster): __name__ = "ZippyshareCom" __type__ = "hoster" __pattern__ = r"(?P<HOST>http://www\d{0,2}\.zippyshare.com)/v(?:/|iew.jsp.*key=)(?P<KEY>\d+)" - __version__ = "0.33" + __version__ = "0.35" __description__ = """Zippyshare.com Download Hoster""" __author_name__ = ("spoob", "zoidberg") __author_mail__ = ("spoob@pyload.org", "zoidberg@mujmail.cz") @@ -100,8 +100,29 @@ class ZippyshareCom(SimpleHoster): try: swf_data = self.load(swf_url) os.write(fd, swf_data) - - p = subprocess.Popen(['swfdump', '-a', fpath], stdout=subprocess.PIPE, stderr=subprocess.PIPE) + + # used for detecting if swfdump is instelled + def is_exe(ppath): + return os.path.isfile(ppath) and os.access(ppath, os.X_OK) + + program = 'swfdump' + swfdump = None + ppath, pname = os.path.split(program) + if ppath: + if is_exe(program): + swfdump = program + else: + for ppath in os.environ["PATH"].split(os.pathsep): + exe_file = os.path.join(ppath, program) + if is_exe(exe_file): + swfdump = exe_file + if swfdump is None: + self.fail("swfdump missing - install swftools") + # ok swfdump is installed move on... + + + + p = subprocess.Popen([swfdump, '-a', fpath], stdout=subprocess.PIPE, stderr=subprocess.PIPE) out, err = p.communicate() if err: @@ -151,4 +172,4 @@ class ZippyshareCom(SimpleHoster): return url -getInfo = create_getInfo(ZippyshareCom)
\ No newline at end of file +getInfo = create_getInfo(ZippyshareCom) |