2012-09-20 16:06:27 +04:00
|
|
|
import uuid
|
|
|
|
import hmac
|
|
|
|
from hashlib import sha1
|
|
|
|
from django.db import models
|
2012-11-17 20:46:16 +04:00
|
|
|
from django import VERSION
|
2012-09-20 16:06:27 +04:00
|
|
|
|
2012-11-17 20:46:16 +04:00
|
|
|
|
|
|
|
if VERSION[:2] in ((1, 5,),):
|
|
|
|
from django.conf import settings
|
2012-11-17 21:04:37 +04:00
|
|
|
if hasattr(settings, 'AUTH_USER_MODEL'):
|
2012-11-17 20:46:16 +04:00
|
|
|
user_model = settings.AUTH_USER_MODEL
|
2012-11-17 21:01:46 +04:00
|
|
|
else:
|
|
|
|
from django.contrib.auth.models import User as user_model
|
|
|
|
else:
|
|
|
|
try:
|
|
|
|
from django.db.models.auth import User as user_model
|
|
|
|
except ImportError:
|
|
|
|
raise ImportError('User model is not to be found.')
|
2012-11-17 20:46:16 +04:00
|
|
|
|
2012-09-20 16:06:27 +04:00
|
|
|
|
|
|
|
class Token(models.Model):
|
|
|
|
"""
|
|
|
|
The default authorization token model.
|
|
|
|
"""
|
|
|
|
key = models.CharField(max_length=40, primary_key=True)
|
2012-11-17 20:46:16 +04:00
|
|
|
user = models.OneToOneField(user_model, related_name='auth_token')
|
2012-09-20 16:06:27 +04:00
|
|
|
created = models.DateTimeField(auto_now_add=True)
|
|
|
|
|
|
|
|
def save(self, *args, **kwargs):
|
|
|
|
if not self.key:
|
|
|
|
self.key = self.generate_key()
|
|
|
|
return super(Token, self).save(*args, **kwargs)
|
|
|
|
|
|
|
|
def generate_key(self):
|
|
|
|
unique = str(uuid.uuid4())
|
|
|
|
return hmac.new(unique, digestmod=sha1).hexdigest()
|
2012-10-09 12:57:31 +04:00
|
|
|
|
|
|
|
def __unicode__(self):
|
|
|
|
return self.key
|