mirror of
				https://github.com/zulip/zulip.git
				synced 2025-11-04 05:53:43 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			63 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
 | 
						|
from argparse import ArgumentParser
 | 
						|
from typing import Any
 | 
						|
 | 
						|
from django.core.management.base import CommandError
 | 
						|
 | 
						|
from zerver.lib.actions import do_change_is_admin
 | 
						|
from zerver.lib.management import ZulipBaseCommand
 | 
						|
 | 
						|
class Command(ZulipBaseCommand):
 | 
						|
    help = """Give an existing user administrative permissions over their (own) Realm.
 | 
						|
 | 
						|
ONLY perform this on customer request from an authorized person.
 | 
						|
"""
 | 
						|
 | 
						|
    def add_arguments(self, parser: ArgumentParser) -> None:
 | 
						|
        parser.add_argument('-f', '--for-real',
 | 
						|
                            dest='ack',
 | 
						|
                            action="store_true",
 | 
						|
                            default=False,
 | 
						|
                            help='Acknowledgement that this is done according to policy.')
 | 
						|
        parser.add_argument('--revoke',
 | 
						|
                            dest='grant',
 | 
						|
                            action="store_false",
 | 
						|
                            default=True,
 | 
						|
                            help='Remove an administrator\'s rights.')
 | 
						|
        parser.add_argument('--permission',
 | 
						|
                            dest='permission',
 | 
						|
                            action="store",
 | 
						|
                            default='administer',
 | 
						|
                            choices=['administer', 'api_super_user', ],
 | 
						|
                            help='Permission to grant/remove.')
 | 
						|
        parser.add_argument('email', metavar='<email>', type=str,
 | 
						|
                            help="email of user to knight")
 | 
						|
        self.add_realm_args(parser, True)
 | 
						|
 | 
						|
    def handle(self, *args: Any, **options: Any) -> None:
 | 
						|
        email = options['email']
 | 
						|
        realm = self.get_realm(options)
 | 
						|
 | 
						|
        profile = self.get_user(email, realm)
 | 
						|
 | 
						|
        if options['grant']:
 | 
						|
            if profile.has_perm(options['permission'], profile.realm):
 | 
						|
                raise CommandError("User already has permission for this realm.")
 | 
						|
            else:
 | 
						|
                if options['ack']:
 | 
						|
                    do_change_is_admin(profile, True, permission=options['permission'])
 | 
						|
                    print("Done!")
 | 
						|
                else:
 | 
						|
                    print("Would have granted %s %s rights for %s" % (
 | 
						|
                          email, options['permission'], profile.realm.string_id))
 | 
						|
        else:
 | 
						|
            if profile.has_perm(options['permission'], profile.realm):
 | 
						|
                if options['ack']:
 | 
						|
                    do_change_is_admin(profile, False, permission=options['permission'])
 | 
						|
                    print("Done!")
 | 
						|
                else:
 | 
						|
                    print("Would have removed %s's %s rights on %s" % (email, options['permission'],
 | 
						|
                                                                       profile.realm.string_id))
 | 
						|
            else:
 | 
						|
                raise CommandError("User did not have permission for this realm!")
 |