diff options
| -rw-r--r-- | module/FileDatabase.py | 2 | ||||
| -rw-r--r-- | module/plugins/Plugin.py | 2 | ||||
| -rw-r--r-- | module/plugins/ReCaptcha.py | 19 | ||||
| -rw-r--r-- | module/plugins/crypter/LofCc.py | 47 | ||||
| -rw-r--r-- | module/plugins/hooks/UnRar.py | 1 | 
5 files changed, 70 insertions, 1 deletions
| diff --git a/module/FileDatabase.py b/module/FileDatabase.py index 4757831e7..1c2667732 100644 --- a/module/FileDatabase.py +++ b/module/FileDatabase.py @@ -670,6 +670,8 @@ class FileDatabaseBackend(Thread):          self.c.execute('SELECT id,url,name,size,status,error,plugin,package,linkorder FROM links WHERE id=?', (str(id), ))          data = {}          r = self.c.fetchone() +        if not r: +            return None          data[str(r[0])] = {              'url': r[1],              'name': r[2], diff --git a/module/plugins/Plugin.py b/module/plugins/Plugin.py index 04a5adb91..6834962e7 100644 --- a/module/plugins/Plugin.py +++ b/module/plugins/Plugin.py @@ -194,7 +194,7 @@ class Plugin(object):          Ocr = self.core.pluginManager.getCaptchaPlugin(self.__name__) -        if Ocr or not forceUser: +        if Ocr and not forceUser:              sleep(randint(3000, 5000) / 1000.0)              if self.pyfile.abort: raise Abort diff --git a/module/plugins/ReCaptcha.py b/module/plugins/ReCaptcha.py new file mode 100644 index 000000000..23e1064ce --- /dev/null +++ b/module/plugins/ReCaptcha.py @@ -0,0 +1,19 @@ +import re + +class ReCaptcha(): +    def __init__(self, plugin): +        self.plugin = plugin +     +    def challenge(self, id): +        js = self.plugin.req.load("http://api.recaptcha.net/challenge", get={"k":id}, cookies=True) +        print js +        challenge = re.search("challenge : '(.*?)',", js).group(1) +        server = re.search("server : '(.*?)',", js).group(1) +        try: +            challenge = re.search("challenge : '(.*?)',", js).group(1) +            server = re.search("server : '(.*?)',", js).group(1) +        except: +            self.plugin.fail("recaptcha error") +        result = self.plugin.decryptCaptcha("%simage"%server, get={"c":challenge}, cookies=True) +         +        return challenge, result diff --git a/module/plugins/crypter/LofCc.py b/module/plugins/crypter/LofCc.py new file mode 100644 index 000000000..cd3a6fe4d --- /dev/null +++ b/module/plugins/crypter/LofCc.py @@ -0,0 +1,47 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +import re +from time import sleep +from os.path import join + +from module.plugins.Crypter import Crypter +from module.plugins.ReCaptcha import ReCaptcha + +class LofCc(Crypter): +    __name__ = "LofCc" +    __type__ = "container" +    __pattern__ = r"http://lof.cc/(.*)" +    __version__ = "0.1" +    __description__ = """lof.cc Plugin""" +    __author_name__ = ("mkaay") +    __author_mail__ = ("mkaay@mkaay.de") + +    def setup(self): +        self.multiDL = False +     +    def decrypt(self, pyfile): +        html = self.req.load(self.pyfile.url, cookies=True) +         +        m = re.search(r"src=\"http://api.recaptcha.net/challenge\?k=(.*?)\"></script>", html) +        if not m: +            self.offline() +         +        recaptcha = ReCaptcha(self) +        challenge, code = recaptcha.challenge(m.group(1)) +         +        resultHTML = self.req.load(self.pyfile.url, post={"recaptcha_challenge_field":challenge, "recaptcha_response_field":code}, cookies=True) +         +        if re.search("class=\"error\"", resultHTML): +            self.retry() +         +        dlc = self.req.load(self.pyfile.url+"/dlc", cookies=True) +         +        name = re.search(self.__pattern__, self.pyfile.url).group(1)+".dlc" +         +        dlcFile = join(self.config["general"]["download_folder"], name) +        f = open(dlcFile, "wb") +        f.write(dlc) +        f.close() +         +        self.packages.append((self.pyfile.package().name, [dlcFile], self.pyfile.package().folder)) diff --git a/module/plugins/hooks/UnRar.py b/module/plugins/hooks/UnRar.py index 82c99a575..7cc73f265 100644 --- a/module/plugins/hooks/UnRar.py +++ b/module/plugins/hooks/UnRar.py @@ -121,4 +121,5 @@ class UnRar(Hook):                  self.removeFiles(pack, fname)              finally:                  pyfile.alternativePercent = None +                pyfile.setStatus("finished") | 
