aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRob Romano2012-11-12 15:16:53 -0800
committerRob Romano2012-11-14 12:46:14 -0800
commitce3ccb91dc2a7aaf8ff41ac24045c558d641839e (patch)
treed6631e56c5466462f25896b0ce29a82056c10a6e
parentbd92db3c672137fa68185dbc0f453f7cea7caff3 (diff)
downloaddjango-rest-framework-ce3ccb91dc2a7aaf8ff41ac24045c558d641839e.tar.bz2
Updates to login view for TokenAuthentication from feedback from Tom
-rw-r--r--rest_framework/authtoken/serializers.py15
-rw-r--r--rest_framework/authtoken/urls.py5
-rw-r--r--rest_framework/authtoken/views.py27
-rw-r--r--rest_framework/tests/authentication.py25
4 files changed, 24 insertions, 48 deletions
diff --git a/rest_framework/authtoken/serializers.py b/rest_framework/authtoken/serializers.py
index 8e0128c1..a5ed6e6d 100644
--- a/rest_framework/authtoken/serializers.py
+++ b/rest_framework/authtoken/serializers.py
@@ -1,12 +1,8 @@
from django.contrib.auth import authenticate
-
from rest_framework import serializers
-from rest_framework.authtoken.models import Token
-
class AuthTokenSerializer(serializers.Serializer):
- token = serializers.Field(source="key")
- username = serializers.CharField(max_length=30)
+ username = serializers.CharField()
password = serializers.CharField()
def validate(self, attrs):
@@ -26,12 +22,3 @@ class AuthTokenSerializer(serializers.Serializer):
else:
raise serializers.ValidationError('Must include "username" and "password"')
- def convert_object(self, obj):
- ret = self._dict_class()
- ret['token'] = obj.key
- ret['user'] = obj.user.id
- return ret
-
- def restore_object(self, attrs, instance=None):
- token, created = Token.objects.get_or_create(user=attrs['user'])
- return token
diff --git a/rest_framework/authtoken/urls.py b/rest_framework/authtoken/urls.py
index 8bea46c0..87872136 100644
--- a/rest_framework/authtoken/urls.py
+++ b/rest_framework/authtoken/urls.py
@@ -13,9 +13,8 @@ your authentication settings include `TokenAuthentication`.
)
"""
from django.conf.urls.defaults import patterns, url
-from rest_framework.authtoken.views import AuthTokenLoginView, AuthTokenLogoutView
+from rest_framework.authtoken.views import AuthTokenView
urlpatterns = patterns('rest_framework.authtoken.views',
- url(r'^login/$', AuthTokenLoginView.as_view(), name='token_login'),
- url(r'^logout/$', AuthTokenLogoutView.as_view(), name='token_logout'),
+ url(r'^login/$', AuthTokenView.as_view(), name='token_login'),
)
diff --git a/rest_framework/authtoken/views.py b/rest_framework/authtoken/views.py
index a52f0a77..e027dff1 100644
--- a/rest_framework/authtoken/views.py
+++ b/rest_framework/authtoken/views.py
@@ -1,19 +1,22 @@
from rest_framework.views import APIView
-from rest_framework.generics import CreateAPIView
+from rest_framework import status
+from rest_framework import parsers
+from rest_framework import renderers
+from rest_framework.response import Response
from rest_framework.authtoken.models import Token
from rest_framework.authtoken.serializers import AuthTokenSerializer
-from django.http import HttpResponse
-class AuthTokenLoginView(CreateAPIView):
+class AuthTokenView(APIView):
+ throttle_classes = ()
+ permission_classes = ()
+ parser_classes = (parsers.FormParser, parsers.MultiPartParser, parsers.JSONParser,)
+ renderer_classes = (renderers.JSONRenderer,)
model = Token
- serializer_class = AuthTokenSerializer
-
-class AuthTokenLogoutView(APIView):
def post(self, request):
- if request.user.is_authenticated() and request.auth:
- request.auth.delete()
- return HttpResponse("logged out")
- else:
- return HttpResponse("not logged in")
-
+ serializer = AuthTokenSerializer(data=request.DATA)
+ if serializer.is_valid():
+ token, created = Token.objects.get_or_create(user=serializer.object['user'])
+ return Response({'token': token.key})
+ return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)
+
diff --git a/rest_framework/tests/authentication.py b/rest_framework/tests/authentication.py
index d1bc23d9..cb16ef1e 100644
--- a/rest_framework/tests/authentication.py
+++ b/rest_framework/tests/authentication.py
@@ -158,41 +158,28 @@ class TokenAuthTests(TestCase):
"""Ensure token login view using JSON POST works."""
client = Client(enforce_csrf_checks=True)
response = client.post('/auth-token/login/',
- json.dumps({'username': self.username, 'password': self.password}), 'application/json')
- self.assertEqual(response.status_code, 201)
+ json.dumps({'username': self.username, 'password': self.password}), 'application/json')
+ self.assertEqual(response.status_code, 200)
self.assertEqual(json.loads(response.content)['token'], self.key)
def test_token_login_json_bad_creds(self):
"""Ensure token login view using JSON POST fails if bad credentials are used."""
client = Client(enforce_csrf_checks=True)
response = client.post('/auth-token/login/',
- json.dumps({'username': self.username, 'password': "badpass"}), 'application/json')
+ json.dumps({'username': self.username, 'password': "badpass"}), 'application/json')
self.assertEqual(response.status_code, 400)
def test_token_login_json_missing_fields(self):
"""Ensure token login view using JSON POST fails if missing fields."""
client = Client(enforce_csrf_checks=True)
response = client.post('/auth-token/login/',
- json.dumps({'username': self.username}), 'application/json')
+ json.dumps({'username': self.username}), 'application/json')
self.assertEqual(response.status_code, 400)
def test_token_login_form(self):
"""Ensure token login view using form POST works."""
client = Client(enforce_csrf_checks=True)
response = client.post('/auth-token/login/',
- {'username': self.username, 'password': self.password})
- self.assertEqual(response.status_code, 201)
- self.assertEqual(json.loads(response.content)['token'], self.key)
-
- def test_token_logout(self):
- """Ensure token logout view using JSON POST works."""
- # Use different User and Token as to isolate this test's effects on other unittests in class
- username = "ringo"
- user = User.objects.create_user(username, "starr@thebeatles.com", "pass")
- token = Token.objects.create(user=user)
- auth = "Token " + token.key
- client = Client(enforce_csrf_checks=True)
- response = client.post('/auth-token/logout/', HTTP_AUTHORIZATION=auth)
+ {'username': self.username, 'password': self.password})
self.assertEqual(response.status_code, 200)
- # Ensure token no longer exists
- self.assertRaises(Token.DoesNotExist, lambda token: Token.objects.get(key=token.key), token)
+ self.assertEqual(json.loads(response.content)['token'], self.key)