2016-06-04 16:52:18 +02:00
|
|
|
from argparse import ArgumentParser
|
2017-11-16 00:43:27 +01:00
|
|
|
from typing import Any
|
2013-03-05 19:09:05 +01:00
|
|
|
|
2017-03-08 11:46:12 +01:00
|
|
|
from zerver.lib.actions import do_deactivate_user
|
2020-01-14 21:59:46 +01:00
|
|
|
from zerver.lib.management import CommandError, ZulipBaseCommand
|
2017-11-16 00:43:27 +01:00
|
|
|
from zerver.lib.sessions import user_sessions
|
2017-07-08 00:31:56 +02:00
|
|
|
from zerver.models import UserProfile
|
2013-03-05 19:09:05 +01:00
|
|
|
|
2020-01-14 21:59:46 +01:00
|
|
|
|
2017-07-08 00:31:56 +02:00
|
|
|
class Command(ZulipBaseCommand):
|
2013-03-05 19:09:05 +01:00
|
|
|
help = "Deactivate a user, including forcibly logging them out."
|
|
|
|
|
2017-10-26 11:35:57 +02:00
|
|
|
def add_arguments(self, parser: ArgumentParser) -> None:
|
2015-08-21 02:10:41 +02:00
|
|
|
parser.add_argument('-f', '--for-real',
|
|
|
|
action='store_true',
|
|
|
|
help="Actually deactivate the user. Default is a dry run.")
|
2020-09-02 21:24:05 +02:00
|
|
|
parser.add_argument('email', metavar='<email>',
|
2015-08-21 02:10:41 +02:00
|
|
|
help='email of user to deactivate')
|
2017-07-08 00:31:56 +02:00
|
|
|
self.add_realm_args(parser)
|
2013-03-05 19:09:05 +01:00
|
|
|
|
2017-10-26 11:35:57 +02:00
|
|
|
def handle(self, *args: Any, **options: Any) -> None:
|
2017-07-08 00:31:56 +02:00
|
|
|
realm = self.get_realm(options)
|
|
|
|
user_profile = self.get_user(options['email'], realm)
|
2013-03-28 20:20:31 +01:00
|
|
|
|
2020-06-10 06:41:04 +02:00
|
|
|
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:")
|
2013-03-29 17:39:53 +01:00
|
|
|
for session in user_sessions(user_profile):
|
2015-11-01 17:11:06 +01:00
|
|
|
print(session.expire_date, session.get_decoded())
|
|
|
|
print("")
|
2020-06-10 06:41:04 +02:00
|
|
|
print("{} has {} active bots that will also be deactivated.".format(
|
2019-11-16 01:42:36 +01:00
|
|
|
user_profile.delivery_email,
|
2017-01-24 07:06:13 +01:00
|
|
|
UserProfile.objects.filter(
|
python: Use trailing commas consistently.
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>
2020-04-10 05:23:40 +02:00
|
|
|
is_bot=True, is_active=True, bot_owner=user_profile,
|
|
|
|
).count(),
|
2017-01-24 06:02:39 +01:00
|
|
|
))
|
2013-03-05 19:09:05 +01:00
|
|
|
|
|
|
|
if not options["for_real"]:
|
2019-05-03 23:20:39 +02:00
|
|
|
raise CommandError("This was a dry run. Pass -f to actually deactivate.")
|
2013-03-05 19:09:05 +01:00
|
|
|
|
2013-11-16 17:11:15 +01:00
|
|
|
do_deactivate_user(user_profile)
|
2015-11-01 17:11:06 +01:00
|
|
|
print("Sessions deleted, user deactivated.")
|