"""
Management command to grant admin role to a participant and Django admin access.

This command:
1. Sets the participant's role to 'admin' (for app-level permissions)
2. Grants Django admin interface access (is_staff=True, is_superuser=True)

Usage:
    python manage.py make_admin email@example.com
"""

from django.core.management.base import BaseCommand, CommandError
from django.db import transaction
from accounts.models import CustomUser
from participants.models import Participant


class Command(BaseCommand):
    help = 'Grant admin role and Django admin access to a user by email address'
    
    def add_arguments(self, parser):
        parser.add_argument(
            'email',
            type=str,
            help='Email address of the user to make admin'
        )
    
    def handle(self, *args, **options):
        email = options['email']
        
        try:
            with transaction.atomic():
                # Find the user
                try:
                    user = CustomUser.objects.get(email=email)
                except CustomUser.DoesNotExist:
                    raise CommandError(f'User with email "{email}" does not exist')
                
                # Get or create participant
                if hasattr(user, 'participant'):
                    participant = user.participant
                    old_role = participant.role
                else:
                    # This shouldn't happen due to signals, but handle it
                    participant = Participant.objects.create(
                        user=user,
                        name=user.get_full_name() or user.email,
                        email=user.email
                    )
                    old_role = 'None'
                
                # Update role to admin
                participant.role = Participant.ROLE_ADMIN
                participant.save()
                
                # Also grant Django admin access
                user.is_staff = True
                user.is_superuser = True
                user.save()
                
                self.stdout.write(
                    self.style.SUCCESS(
                        f'Successfully granted admin role to {participant.name} ({email})\n'
                        f'Previous role: {old_role} → New role: admin\n'
                        f'Django admin access: granted (staff: {user.is_staff}, superuser: {user.is_superuser})'
                    )
                )
                
                # Show current admin list
                admin_count = Participant.objects.filter(role=Participant.ROLE_ADMIN).count()
                self.stdout.write(f'\nTotal admin users: {admin_count}')
                
        except Exception as e:
            raise CommandError(f'Error updating user role: {str(e)}')