mirror of
				https://github.com/zulip/zulip.git
				synced 2025-11-04 05:53:43 +00:00 
			
		
		
		
	Removed `is_billing_admin` user property as it is no longer used since billing permissions are now determined by `can_manage_billing_group` realm setting.
		
			
				
	
	
		
			122 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			122 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from argparse import ArgumentParser
 | 
						|
from typing import Any
 | 
						|
 | 
						|
from django.conf import settings
 | 
						|
from django.core.management.base import CommandError
 | 
						|
from typing_extensions import override
 | 
						|
 | 
						|
from zerver.actions.users import (
 | 
						|
    do_change_can_change_user_emails,
 | 
						|
    do_change_can_create_users,
 | 
						|
    do_change_can_forge_sender,
 | 
						|
    do_change_user_role,
 | 
						|
)
 | 
						|
from zerver.lib.exceptions import JsonableError
 | 
						|
from zerver.lib.management import ZulipBaseCommand
 | 
						|
from zerver.models import UserProfile
 | 
						|
 | 
						|
ROLE_CHOICES = [
 | 
						|
    "owner",
 | 
						|
    "admin",
 | 
						|
    "moderator",
 | 
						|
    "member",
 | 
						|
    "guest",
 | 
						|
    "can_forge_sender",
 | 
						|
    "can_create_users",
 | 
						|
    "can_change_user_emails",
 | 
						|
]
 | 
						|
 | 
						|
 | 
						|
class Command(ZulipBaseCommand):
 | 
						|
    help = """Change role of an existing user in their (own) Realm.
 | 
						|
 | 
						|
ONLY perform this on customer request from an authorized person.
 | 
						|
"""
 | 
						|
 | 
						|
    @override
 | 
						|
    def add_arguments(self, parser: ArgumentParser) -> None:
 | 
						|
        parser.add_argument("email", metavar="<email>", help="email of user to change role")
 | 
						|
        parser.add_argument(
 | 
						|
            "new_role",
 | 
						|
            metavar="<new_role>",
 | 
						|
            choices=ROLE_CHOICES,
 | 
						|
            help="new role of the user; choose from " + ", ".join(ROLE_CHOICES),
 | 
						|
        )
 | 
						|
        parser.add_argument(
 | 
						|
            "--revoke",
 | 
						|
            dest="grant",
 | 
						|
            action="store_false",
 | 
						|
            help="Remove can_forge_sender or can_create_users permission.",
 | 
						|
        )
 | 
						|
        self.add_realm_args(parser, required=True)
 | 
						|
 | 
						|
    @override
 | 
						|
    def handle(self, *args: Any, **options: Any) -> None:
 | 
						|
        email = options["email"]
 | 
						|
        realm = self.get_realm(options)
 | 
						|
        assert realm is not None
 | 
						|
        user = self.get_user(email, realm)
 | 
						|
 | 
						|
        user_role_map = {
 | 
						|
            "owner": UserProfile.ROLE_REALM_OWNER,
 | 
						|
            "admin": UserProfile.ROLE_REALM_ADMINISTRATOR,
 | 
						|
            "moderator": UserProfile.ROLE_MODERATOR,
 | 
						|
            "member": UserProfile.ROLE_MEMBER,
 | 
						|
            "guest": UserProfile.ROLE_GUEST,
 | 
						|
        }
 | 
						|
 | 
						|
        if options["new_role"] not in [
 | 
						|
            "can_forge_sender",
 | 
						|
            "can_create_users",
 | 
						|
            "can_change_user_emails",
 | 
						|
        ]:
 | 
						|
            new_role = user_role_map[options["new_role"]]
 | 
						|
            if not options["grant"]:
 | 
						|
                raise CommandError(
 | 
						|
                    "Revoke not supported with this permission; please specify new role."
 | 
						|
                )
 | 
						|
            if new_role == user.role:
 | 
						|
                raise CommandError("User already has this role.")
 | 
						|
            if settings.BILLING_ENABLED and user.is_guest:
 | 
						|
                from corporate.lib.registration import (
 | 
						|
                    check_spare_license_available_for_changing_guest_user_role,
 | 
						|
                )
 | 
						|
 | 
						|
                try:
 | 
						|
                    check_spare_license_available_for_changing_guest_user_role(realm)
 | 
						|
                except JsonableError:
 | 
						|
                    raise CommandError(
 | 
						|
                        "This realm does not have enough licenses to change a guest user's role."
 | 
						|
                    )
 | 
						|
            old_role_name = UserProfile.ROLE_ID_TO_NAME_MAP[user.role]
 | 
						|
            do_change_user_role(user, new_role, acting_user=None)
 | 
						|
            new_role_name = UserProfile.ROLE_ID_TO_NAME_MAP[user.role]
 | 
						|
            print(
 | 
						|
                f"Role for {user.delivery_email} changed from {old_role_name} to {new_role_name}."
 | 
						|
            )
 | 
						|
            return
 | 
						|
 | 
						|
        if options["new_role"] == "can_forge_sender":
 | 
						|
            if user.can_forge_sender and options["grant"]:
 | 
						|
                raise CommandError("User can already forge messages for this realm.")
 | 
						|
            elif not user.can_forge_sender and not options["grant"]:
 | 
						|
                raise CommandError("User can't forge messages for this realm.")
 | 
						|
            do_change_can_forge_sender(user, options["grant"])
 | 
						|
 | 
						|
            granted_text = "have" if options["grant"] else "not have"
 | 
						|
            print(
 | 
						|
                f"{user.delivery_email} changed to {granted_text} {options['new_role']} permission."
 | 
						|
            )
 | 
						|
        elif options["new_role"] == "can_create_users":
 | 
						|
            if user.can_create_users and options["grant"]:
 | 
						|
                raise CommandError("User can already create users for this realm.")
 | 
						|
            elif not user.can_create_users and not options["grant"]:
 | 
						|
                raise CommandError("User can't create users for this realm.")
 | 
						|
            do_change_can_create_users(user, options["grant"])
 | 
						|
        elif options["new_role"] == "can_change_user_emails":
 | 
						|
            if user.can_change_user_emails and options["grant"]:
 | 
						|
                raise CommandError("User can already change user emails for this realm.")
 | 
						|
            elif not user.can_change_user_emails and not options["grant"]:
 | 
						|
                raise CommandError("User can't change user emails for this realm.")
 | 
						|
            do_change_can_change_user_emails(user, options["grant"])
 |