mirror of
				https://github.com/zulip/zulip.git
				synced 2025-11-03 21:43:21 +00:00 
			
		
		
		
	Automatically generated by the following script, based on the output
of lint with flake8-comma:
import re
import sys
last_filename = None
last_row = None
lines = []
for msg in sys.stdin:
    m = re.match(
        r"\x1b\[35mflake8    \|\x1b\[0m \x1b\[1;31m(.+):(\d+):(\d+): (\w+)", msg
    )
    if m:
        filename, row_str, col_str, err = m.groups()
        row, col = int(row_str), int(col_str)
        if filename == last_filename:
            assert last_row != row
        else:
            if last_filename is not None:
                with open(last_filename, "w") as f:
                    f.writelines(lines)
            with open(filename) as f:
                lines = f.readlines()
            last_filename = filename
        last_row = row
        line = lines[row - 1]
        if err in ["C812", "C815"]:
            lines[row - 1] = line[: col - 1] + "," + line[col - 1 :]
        elif err in ["C819"]:
            assert line[col - 2] == ","
            lines[row - 1] = line[: col - 2] + line[col - 1 :].lstrip(" ")
if last_filename is not None:
    with open(last_filename, "w") as f:
        f.writelines(lines)
Signed-off-by: Anders Kaseorg <anders@zulipchat.com>
		
	
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from argparse import ArgumentParser
 | 
						|
from typing import Any
 | 
						|
 | 
						|
from zerver.lib.actions import do_deactivate_user
 | 
						|
from zerver.lib.management import CommandError, ZulipBaseCommand
 | 
						|
from zerver.lib.sessions import user_sessions
 | 
						|
from zerver.models import UserProfile
 | 
						|
 | 
						|
 | 
						|
class Command(ZulipBaseCommand):
 | 
						|
    help = "Deactivate a user, including forcibly logging them out."
 | 
						|
 | 
						|
    def add_arguments(self, parser: ArgumentParser) -> None:
 | 
						|
        parser.add_argument('-f', '--for-real',
 | 
						|
                            dest='for_real',
 | 
						|
                            action='store_true',
 | 
						|
                            default=False,
 | 
						|
                            help="Actually deactivate the user. Default is a dry run.")
 | 
						|
        parser.add_argument('email', metavar='<email>', type=str,
 | 
						|
                            help='email of user to deactivate')
 | 
						|
        self.add_realm_args(parser)
 | 
						|
 | 
						|
    def handle(self, *args: Any, **options: Any) -> None:
 | 
						|
        realm = self.get_realm(options)
 | 
						|
        user_profile = self.get_user(options['email'], realm)
 | 
						|
 | 
						|
        print(f"Deactivating {user_profile.full_name} ({user_profile.delivery_email}) - {user_profile.realm.string_id}")
 | 
						|
        print(f"{user_profile.delivery_email} has the following active sessions:")
 | 
						|
        for session in user_sessions(user_profile):
 | 
						|
            print(session.expire_date, session.get_decoded())
 | 
						|
        print("")
 | 
						|
        print("{} has {} active bots that will also be deactivated.".format(
 | 
						|
            user_profile.delivery_email,
 | 
						|
            UserProfile.objects.filter(
 | 
						|
                is_bot=True, is_active=True, bot_owner=user_profile,
 | 
						|
            ).count(),
 | 
						|
        ))
 | 
						|
 | 
						|
        if not options["for_real"]:
 | 
						|
            raise CommandError("This was a dry run. Pass -f to actually deactivate.")
 | 
						|
 | 
						|
        do_deactivate_user(user_profile)
 | 
						|
        print("Sessions deleted, user deactivated.")
 |