diff options
| author | Tom Christie | 2012-09-07 13:48:39 -0700 |
|---|---|---|
| committer | Tom Christie | 2012-09-07 13:48:39 -0700 |
| commit | 9faca0aef087c9a54c277c38ae75f72f51d0945d (patch) | |
| tree | 3a467bdd50bea4772c38887deb4694e444f244d7 /djangorestframework/authentication.py | |
| parent | 72bdd0fcec7faa32d7f24e0698736f9433b56f3f (diff) | |
| parent | 8df71f4d1d9a8a3df8e053d99340fbe5bf78b8ad (diff) | |
| download | django-rest-framework-9faca0aef087c9a54c277c38ae75f72f51d0945d.tar.bz2 | |
Merge pull request #249 from mjumbewu/restframework2
Implement simple token authentication
Diffstat (limited to 'djangorestframework/authentication.py')
| -rw-r--r-- | djangorestframework/authentication.py | 36 |
1 files changed, 35 insertions, 1 deletions
diff --git a/djangorestframework/authentication.py b/djangorestframework/authentication.py index 4d5a7e86..2446fbbd 100644 --- a/djangorestframework/authentication.py +++ b/djangorestframework/authentication.py @@ -103,4 +103,38 @@ class SessionAuthentication(BaseAuthentication): return (user, None) -# TODO: TokenAuthentication, DigestAuthentication, OAuthAuthentication +class TokenAuthentication(BaseAuthentication): + """ + Use a token model for authentication. + + A custom token model may be used here, but must have the following minimum + properties: + + * 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: 0123456789abcdef0123456789abcdef + + """ + 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 + + 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) + +# TODO: DigestAuthentication, OAuthAuthentication |
