1
0
mirror of https://github.com/django/django.git synced 2025-08-21 01:09:13 +00:00

Fixed #36540 -- Updated request.auser() in contrib.auth.alogin() and contrib.auth.alogout().

This commit is contained in:
Xinyi Rong 2025-08-06 10:17:10 -07:00 committed by Sarah Boyce
parent 117f90dea5
commit 31a43c571f
2 changed files with 31 additions and 5 deletions

View File

@ -234,8 +234,12 @@ async def alogin(request, user, backend=None):
await request.session.aset(SESSION_KEY, user._meta.pk.value_to_string(user)) await request.session.aset(SESSION_KEY, user._meta.pk.value_to_string(user))
await request.session.aset(BACKEND_SESSION_KEY, backend) await request.session.aset(BACKEND_SESSION_KEY, backend)
await request.session.aset(HASH_SESSION_KEY, session_auth_hash) await request.session.aset(HASH_SESSION_KEY, session_auth_hash)
if hasattr(request, "user"): if hasattr(request, "auser"):
request.user = user
async def auser():
return user
request.auser = auser
rotate_token(request) rotate_token(request)
await user_logged_in.asend(sender=user.__class__, request=request, user=user) await user_logged_in.asend(sender=user.__class__, request=request, user=user)
@ -269,10 +273,13 @@ async def alogout(request):
user = None user = None
await user_logged_out.asend(sender=user.__class__, request=request, user=user) await user_logged_out.asend(sender=user.__class__, request=request, user=user)
await request.session.aflush() await request.session.aflush()
if hasattr(request, "user"): if hasattr(request, "auser"):
from django.contrib.auth.models import AnonymousUser from django.contrib.auth.models import AnonymousUser
request.user = AnonymousUser() async def auser():
return AnonymousUser()
request.auser = auser
def get_user_model(): def get_user_model():

View File

@ -1,5 +1,5 @@
from django.conf import settings from django.conf import settings
from django.contrib.auth import REDIRECT_FIELD_NAME from django.contrib.auth import REDIRECT_FIELD_NAME, alogin, alogout
from django.contrib.auth.middleware import ( from django.contrib.auth.middleware import (
AuthenticationMiddleware, AuthenticationMiddleware,
LoginRequiredMiddleware, LoginRequiredMiddleware,
@ -17,6 +17,9 @@ class TestAuthenticationMiddleware(TestCase):
cls.user = User.objects.create_user( cls.user = User.objects.create_user(
"test_user", "test@example.com", "test_password" "test_user", "test@example.com", "test_password"
) )
cls.user2 = User.objects.create_user(
"test_user2", "test2@example.com", "test_password2"
)
def setUp(self): def setUp(self):
self.middleware = AuthenticationMiddleware(lambda req: HttpResponse()) self.middleware = AuthenticationMiddleware(lambda req: HttpResponse())
@ -57,6 +60,22 @@ class TestAuthenticationMiddleware(TestCase):
auser_second = await self.request.auser() auser_second = await self.request.auser()
self.assertIs(auser, auser_second) self.assertIs(auser, auser_second)
async def test_auser_after_alogin(self):
self.middleware(self.request)
auser = await self.request.auser()
self.assertEqual(auser, self.user)
await alogin(self.request, self.user2)
auser_second = await self.request.auser()
self.assertEqual(auser_second, self.user2)
async def test_auser_after_alogout(self):
self.middleware(self.request)
auser = await self.request.auser()
self.assertEqual(auser, self.user)
await alogout(self.request)
auser_second = await self.request.auser()
self.assertTrue(auser_second.is_anonymous)
@override_settings(ROOT_URLCONF="auth_tests.urls") @override_settings(ROOT_URLCONF="auth_tests.urls")
@modify_settings( @modify_settings(