[tor-commits] [bridgedb/master] Add challenge Attribute to ICaptcha interface and implementation.
isis at torproject.org
isis at torproject.org
Sun Mar 16 19:04:58 UTC 2014
commit acc5f2ab0656db5f0bff1e3f0a8061f54aa8b5bd
Author: Isis Lovecruft <isis at torproject.org>
Date: Tue Mar 4 19:04:18 2014 +0000
Add challenge Attribute to ICaptcha interface and implementation.
---
lib/bridgedb/captcha.py | 24 +++++++++++++-----------
1 file changed, 13 insertions(+), 11 deletions(-)
diff --git a/lib/bridgedb/captcha.py b/lib/bridgedb/captcha.py
index 672d75c..5d36432 100644
--- a/lib/bridgedb/captcha.py
+++ b/lib/bridgedb/captcha.py
@@ -53,20 +53,26 @@ class ReCaptchaKeyError(Exception):
class GimpCaptchaError(Exception):
"""General exception raised when a Gimp CAPTCHA cannot be retrieved."""
+
class ICaptcha(Interface):
"""Interface specification for CAPTCHAs."""
- image = Attribute("A CAPTCHA image.")
- def get(self):
- """Retrieve a new CAPTCHA."""
- return None
+ image = Attribute(
+ "A string containing the contents of a CAPTCHA image file.")
+ challenge = Attribute(
+ "A unique string associated with the dispursal of this CAPTCHA.")
+
+ def get():
+ """Retrieve a new CAPTCHA image."""
+
class Captcha(object):
- """A generic CAPTCHA object."""
+ """A generic CAPTCHA base class."""
implements(ICaptcha)
def __init__(self):
self.image = None
+ self.challenge = None
def get(self):
return self.image
@@ -76,10 +82,9 @@ class ReCaptcha(Captcha):
"""A reCaptcha CAPTCHA."""
def __init__(self, pubkey=None, privkey=None):
+ super(ReCaptcha, self).__init__()
self.pubkey = pubkey
self.privkey = privkey
- self.image = None
- super(ReCaptcha, self).__init__()
def get(self):
"""Retrieve a CAPTCHA from the reCaptcha API server.
@@ -111,15 +116,12 @@ class GimpCaptcha(Captcha):
:raises GimpCaptchaError: if **cacheDir** is not a directory.
"""
+ super(GimpCaptcha, self).__init__()
if not os.path.isdir(cacheDir):
raise GimpCaptchaError("Gimp captcha cache isn't a directory: %r"
% cacheDir)
-
- self.image = None
- self.challenge = None
self.cacheDir = cacheDir
self.clientIP = clientIP
- super(GimpCaptcha, self).__init__()
@classmethod
def check(cls, challenge, answer, clientIP=None):
More information about the tor-commits
mailing list