mirror of
https://github.com/haiwen/seahub.git
synced 2025-08-31 14:42:10 +00:00
Added captcha to thirdpart
This commit is contained in:
69
thirdpart/captcha/models.py
Normal file
69
thirdpart/captcha/models.py
Normal file
@@ -0,0 +1,69 @@
|
||||
from captcha.conf import settings as captcha_settings
|
||||
from django.db import models
|
||||
from django.conf import settings
|
||||
import datetime
|
||||
import random
|
||||
import time
|
||||
import unicodedata
|
||||
import six
|
||||
|
||||
# Heavily based on session key generation in Django
|
||||
# Use the system (hardware-based) random number generator if it exists.
|
||||
if hasattr(random, 'SystemRandom'):
|
||||
randrange = random.SystemRandom().randrange
|
||||
else:
|
||||
randrange = random.randrange
|
||||
MAX_RANDOM_KEY = 18446744073709551616 # 2 << 63
|
||||
|
||||
|
||||
try:
|
||||
import hashlib # sha for Python 2.5+
|
||||
except ImportError:
|
||||
import sha # sha for Python 2.4 (deprecated in Python 2.6)
|
||||
hashlib = False
|
||||
|
||||
|
||||
def get_safe_now():
|
||||
try:
|
||||
from django.utils.timezone import utc
|
||||
if settings.USE_TZ:
|
||||
return datetime.datetime.utcnow().replace(tzinfo=utc)
|
||||
except:
|
||||
pass
|
||||
return datetime.datetime.now()
|
||||
|
||||
|
||||
class CaptchaStore(models.Model):
|
||||
challenge = models.CharField(blank=False, max_length=32)
|
||||
response = models.CharField(blank=False, max_length=32)
|
||||
hashkey = models.CharField(blank=False, max_length=40, unique=True)
|
||||
expiration = models.DateTimeField(blank=False)
|
||||
|
||||
def save(self, *args, **kwargs):
|
||||
#import ipdb; ipdb.set_trace()
|
||||
self.response = six.text_type(self.response).lower()
|
||||
if not self.expiration:
|
||||
#self.expiration = datetime.datetime.now() + datetime.timedelta(minutes=int(captcha_settings.CAPTCHA_TIMEOUT))
|
||||
self.expiration = get_safe_now() + datetime.timedelta(minutes=int(captcha_settings.CAPTCHA_TIMEOUT))
|
||||
if not self.hashkey:
|
||||
key_ = unicodedata.normalize('NFKD', str(randrange(0, MAX_RANDOM_KEY)) + str(time.time()) + six.text_type(self.challenge)).encode('ascii', 'ignore') + unicodedata.normalize('NFKD', six.text_type(self.response)).encode('ascii', 'ignore')
|
||||
if hashlib:
|
||||
self.hashkey = hashlib.sha1(key_).hexdigest()
|
||||
else:
|
||||
self.hashkey = sha.new(key_).hexdigest()
|
||||
del(key_)
|
||||
super(CaptchaStore, self).save(*args, **kwargs)
|
||||
|
||||
def __unicode__(self):
|
||||
return self.challenge
|
||||
|
||||
def remove_expired(cls):
|
||||
cls.objects.filter(expiration__lte=get_safe_now()).delete()
|
||||
remove_expired = classmethod(remove_expired)
|
||||
|
||||
@classmethod
|
||||
def generate_key(cls):
|
||||
challenge, response = captcha_settings.get_challenge()()
|
||||
store = cls.objects.create(challenge=challenge, response=response)
|
||||
|
||||
return store.hashkey
|
Reference in New Issue
Block a user