diff options
| author | Mjumbe Wawatu Poe | 2012-09-07 16:12:33 -0400 | 
|---|---|---|
| committer | Mjumbe Wawatu Poe | 2012-09-07 16:15:33 -0400 | 
| commit | f741cdae44bc455089a5ed7e1dbea4760ca97b85 (patch) | |
| tree | 622d3e71a0815f34c3006199ca79c9ed8ea6023a /djangorestframework | |
| parent | 10450bafc9d98f022e0f0a5246a7fb1c7e53dc39 (diff) | |
| download | django-rest-framework-f741cdae44bc455089a5ed7e1dbea4760ca97b85.tar.bz2 | |
Move TokenAuthentication class into djangorestframework.authentication
Diffstat (limited to 'djangorestframework')
| -rw-r--r-- | djangorestframework/authentication.py | 36 | ||||
| -rw-r--r-- | djangorestframework/tests/authentication.py | 6 | ||||
| -rw-r--r-- | djangorestframework/tokenauth/authentication.py | 36 | 
3 files changed, 38 insertions, 40 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 diff --git a/djangorestframework/tests/authentication.py b/djangorestframework/tests/authentication.py index dfed2fcc..fcc8f7ba 100644 --- a/djangorestframework/tests/authentication.py +++ b/djangorestframework/tests/authentication.py @@ -9,7 +9,7 @@ from djangorestframework.views import APIView  from djangorestframework import permissions  from djangorestframework.tokenauth.models import BasicToken -from djangorestframework.tokenauth.authentication import TokenAuthentication +from djangorestframework.authentication import TokenAuthentication  import base64 @@ -127,13 +127,13 @@ class TokenAuthTests(TestCase):      def test_post_form_passing_token_auth(self):          """Ensure POSTing json over token auth with correct credentials passes and does not require CSRF""" -        auth = 'Token %s' % self.key +        auth = self.key          response = self.csrf_client.post('/', {'example': 'example'}, HTTP_AUTHORIZATION=auth)          self.assertEqual(response.status_code, 200)      def test_post_json_passing_token_auth(self):          """Ensure POSTing form over token auth with correct credentials passes and does not require CSRF""" -        auth = 'Token %s' % self.key +        auth = self.key          response = self.csrf_client.post('/', json.dumps({'example': 'example'}), 'application/json', HTTP_AUTHORIZATION=auth)          self.assertEqual(response.status_code, 200) diff --git a/djangorestframework/tokenauth/authentication.py b/djangorestframework/tokenauth/authentication.py deleted file mode 100644 index 327a4a09..00000000 --- a/djangorestframework/tokenauth/authentication.py +++ /dev/null @@ -1,36 +0,0 @@ -from djangorestframework.authentication import BaseAuthentication -from .models import BasicToken - -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 BaseToken class is available as an abstract model to be derived from. - -    The token key should be passed in as a string to the "Authorization" HTTP -    header.  For example: - -        Authorization: Token 0123456789abcdef0123456789abcdef - -    """ -    model = BasicToken - -    def authenticate(self, request): -        auth = request.META.get('HTTP_AUTHORIZATION', '').strip().split() -        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)  | 
