diff options
| author | Tom Christie | 2012-09-12 20:39:22 +0100 |
|---|---|---|
| committer | Tom Christie | 2012-09-12 20:39:22 +0100 |
| commit | 003a65f0e094e59b5462fcd0607bf290d80cc5aa (patch) | |
| tree | c514790099c155e18897012cc4599a60f191832e /djangorestframework/authentication.py | |
| parent | dac4cb9e8bf107f407ed8754bbef0ce97e79beb2 (diff) | |
| download | django-rest-framework-003a65f0e094e59b5462fcd0607bf290d80cc5aa.tar.bz2 | |
Tweaks to Token auth
Diffstat (limited to 'djangorestframework/authentication.py')
| -rw-r--r-- | djangorestframework/authentication.py | 50 |
1 files changed, 21 insertions, 29 deletions
diff --git a/djangorestframework/authentication.py b/djangorestframework/authentication.py index 2446fbbd..a6634392 100644 --- a/djangorestframework/authentication.py +++ b/djangorestframework/authentication.py @@ -6,14 +6,9 @@ Authentication behavior is provided by mixing the :class:`mixins.RequestMixin` c from django.contrib.auth import authenticate from djangorestframework.compat import CsrfViewMiddleware +from djangorestframework.authtoken.models import Token import base64 -__all__ = ( - 'BaseAuthentication', - 'BasicAuthentication', - 'SessionAuthentication' -) - class BaseAuthentication(object): """ @@ -105,36 +100,33 @@ class SessionAuthentication(BaseAuthentication): class TokenAuthentication(BaseAuthentication): """ - Use a token model for authentication. + Simple token based authentication. - A custom token model may be used here, but must have the following minimum - properties: + Clients should authenticate by passing the token key in the "Authorization" + HTTP header, prepended with the string "Token ". For example: - * key -- The string identifying the token - * user -- The user to which the token belongs - * revoked -- The status of the token - - The token key should be passed in as a string to the "Authorization" HTTP - header. For example: + Authorization: Token 401f7ac837da42b97f613d789819ff93537bee6a + """ - Authorization: 0123456789abcdef0123456789abcdef + model = Token + """ + A custom token model may be used, but must have the following properties. + * key -- The string identifying the token + * user -- The user to which the token belongs """ - model = None def authenticate(self, request): - key = request.META.get('HTTP_AUTHORIZATION', '').strip() - - if self.model is None: - from djangorestframework.tokenauth.models import BasicToken - self.model = BasicToken + auth = request.META.get('HTTP_AUTHORIZATION', '').split() - try: - token = self.model.objects.get(key=key) - except self.model.DoesNotExist: - return None + if len(auth) == 2 and auth[0].lower() == "token": + key = auth[1] + try: + token = self.model.objects.get(key=key) + except self.model.DoesNotExist: + return None - if token.user.is_active and not token.revoked: - return (token.user, token) + if token.user.is_active and not getattr(token, 'revoked', False): + return (token.user, token) -# TODO: DigestAuthentication, OAuthAuthentication +# TODO: OAuthAuthentication |
