Fix login issue

This commit is contained in:
2025-09-05 23:20:10 +09:00
parent d8e1b05d41
commit 00bc1cadc9
3 changed files with 42 additions and 2 deletions

View File

@ -0,0 +1,36 @@
from django.core.management.base import BaseCommand
from rog.models import CustomUser
from django.contrib.auth import authenticate
class Command(BaseCommand):
help = 'Check user authentication'
def add_arguments(self, parser):
parser.add_argument('email', type=str, help='User email to check')
parser.add_argument('--password', type=str, help='Password to test', default='')
def handle(self, *args, **options):
email = options['email']
password = options.get('password', '')
self.stdout.write(f'Checking user: {email}')
try:
user = CustomUser.objects.get(email=email)
self.stdout.write(f'✅ User found: {user.email}')
self.stdout.write(f' Active: {user.is_active}')
self.stdout.write(f' Has password: {bool(user.password)}')
self.stdout.write(f' Password hash start: {user.password[:30]}...')
if password:
self.stdout.write(f'\n🔐 Testing authentication with provided password...')
auth_user = authenticate(username=email, password=password)
if auth_user:
self.stdout.write('✅ Authentication successful')
else:
self.stdout.write('❌ Authentication failed')
except CustomUser.DoesNotExist:
self.stdout.write(f'❌ User does not exist: {email}')
except Exception as e:
self.stdout.write(f'❌ Error: {e}')

View File

@ -535,9 +535,10 @@ class LoginUserSerializer(serializers.Serializer):
else: else:
# Check if the user exists # Check if the user exists
try: try:
user_obj = User.objects.get(email=email) from .models import CustomUser
user_obj = CustomUser.objects.get(email=email)
raise serializers.ValidationError("Incorrect password.") raise serializers.ValidationError("Incorrect password.")
except User.DoesNotExist: except CustomUser.DoesNotExist:
raise serializers.ValidationError("User with this email does not exist.") raise serializers.ValidationError("User with this email does not exist.")
else: else:
raise serializers.ValidationError("Must include 'email' and 'password'.") raise serializers.ValidationError("Must include 'email' and 'password'.")

View File

@ -908,11 +908,14 @@ class LoginAPI(generics.GenericAPIView):
def post(self, request, *args, **kwargs): def post(self, request, *args, **kwargs):
logger.info(f"Login attempt for identifier: {request.data.get('identifier', 'identifier not provided')}") logger.info(f"Login attempt for identifier: {request.data.get('identifier', 'identifier not provided')}")
logger.debug(f"Request data: {request.data}") logger.debug(f"Request data: {request.data}")
logger.debug(f"Request headers: {dict(request.headers)}")
# フロントエンドの 'identifier' フィールドを 'email' にマッピング # フロントエンドの 'identifier' フィールドを 'email' にマッピング
data = request.data.copy() data = request.data.copy()
if 'identifier' in data and 'email' not in data: if 'identifier' in data and 'email' not in data:
data['email'] = data['identifier'] data['email'] = data['identifier']
logger.debug(f"Processed data: {data}")
serializer = self.get_serializer(data=data) serializer = self.get_serializer(data=data)
try: try: