From 1d9f24f60d1348c53e9a88cb605c7890b6c40146 Mon Sep 17 00:00:00 2001 From: Tom Christie Date: Tue, 24 Jan 2012 19:26:37 +0000 Subject: [PATCH] Fix UserLoggedInAuthentication for POST requests. Fixes #78. --- djangorestframework/authentication.py | 17 ++--------------- 1 file changed, 2 insertions(+), 15 deletions(-) diff --git a/djangorestframework/authentication.py b/djangorestframework/authentication.py index b61af32a2..f46a9c460 100644 --- a/djangorestframework/authentication.py +++ b/djangorestframework/authentication.py @@ -87,25 +87,12 @@ class UserLoggedInAuthentication(BaseAuthentication): Returns a :obj:`User` if the request session currently has a logged in user. Otherwise returns :const:`None`. """ - # TODO: Might be cleaner to switch this back to using request.POST, - # and let FormParser/MultiPartParser deal with the consequences. + self.view.DATA # Make sure our generic parsing runs first + if getattr(request, 'user', None) and request.user.is_active: # Enforce CSRF validation for session based authentication. - - # Temporarily replace request.POST with .DATA, to use our generic parsing. - # If DATA is not dict-like, use an empty dict. - if request.method.upper() == 'POST': - if hasattr(self.view.DATA, 'get'): - request._post = self.view.DATA - else: - request._post = {} - resp = CsrfViewMiddleware().process_view(request, None, (), {}) - # Replace request.POST - if request.method.upper() == 'POST': - del(request._post) - if resp is None: # csrf passed return request.user return None