mirror of
https://github.com/zulip/zulip.git
synced 2025-11-20 14:38:46 +00:00
@@ -25,7 +25,8 @@ class ZulipBaseCommand(BaseCommand):
|
|||||||
dest='realm_id',
|
dest='realm_id',
|
||||||
required=required,
|
required=required,
|
||||||
type=str,
|
type=str,
|
||||||
help='The numeric or string ID (subdomain) of the Zulip organization to modify.')
|
help='The numeric or string ID (subdomain) of the Zulip organization to modify. '
|
||||||
|
'You can use the command list_realms to find ID of the realms in this server.')
|
||||||
|
|
||||||
def get_realm(self, options):
|
def get_realm(self, options):
|
||||||
# type: (Dict[str, Any]) -> Optional[Realm]
|
# type: (Dict[str, Any]) -> Optional[Realm]
|
||||||
|
|||||||
77
zerver/management/commands/list_realms.py
Normal file
77
zerver/management/commands/list_realms.py
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
from __future__ import absolute_import
|
||||||
|
from __future__ import print_function
|
||||||
|
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from typing import Any
|
||||||
|
from argparse import ArgumentParser
|
||||||
|
|
||||||
|
from zerver.models import Realm
|
||||||
|
from zerver.lib.management import ZulipBaseCommand
|
||||||
|
|
||||||
|
class Command(ZulipBaseCommand):
|
||||||
|
help = """List realms in the server and it's configuration settings(optional).
|
||||||
|
|
||||||
|
Usage examples:
|
||||||
|
|
||||||
|
./manage.py list_realms
|
||||||
|
./manage.py list_realms --all"""
|
||||||
|
|
||||||
|
def add_arguments(self, parser):
|
||||||
|
# type: (ArgumentParser) -> None
|
||||||
|
parser.add_argument("--all",
|
||||||
|
dest="all",
|
||||||
|
action="store_true",
|
||||||
|
default=False,
|
||||||
|
help="Print all the configuration settings of the realms.")
|
||||||
|
|
||||||
|
def handle(self, *args, **options):
|
||||||
|
# type: (*Any, **Any) -> None
|
||||||
|
realms = Realm.objects.all()
|
||||||
|
|
||||||
|
outer_format = "%-5s %-40s %-40s"
|
||||||
|
inner_format = "%-40s %s"
|
||||||
|
deactivated = False
|
||||||
|
|
||||||
|
if not options["all"]:
|
||||||
|
print(outer_format % ("id", "string_id", "name"))
|
||||||
|
print(outer_format % ("--", "---------", "----"))
|
||||||
|
|
||||||
|
for realm in realms:
|
||||||
|
if realm.deactivated:
|
||||||
|
print(self.style.ERROR(outer_format % (realm.id, realm.string_id, realm.name)))
|
||||||
|
deactivated = True
|
||||||
|
else:
|
||||||
|
print(outer_format % (realm.id, realm.string_id, realm.name))
|
||||||
|
if deactivated:
|
||||||
|
print(self.style.WARNING("\nRed rows represent deactivated realms."))
|
||||||
|
sys.exit(0)
|
||||||
|
|
||||||
|
# The remaining code path is the --all case.
|
||||||
|
identifier_attributes = ["id", "name", "string_id"]
|
||||||
|
for realm in realms:
|
||||||
|
# Start with just all the fields on the object, which is
|
||||||
|
# hacky but doesn't require any work to maintain.
|
||||||
|
realm_dict = realm.__dict__
|
||||||
|
# Remove a field that is confusingly useless
|
||||||
|
del realm_dict['_state']
|
||||||
|
# Fix the one bitfield to display useful data
|
||||||
|
realm_dict['authentication_methods'] = str(realm.authentication_methods_dict())
|
||||||
|
|
||||||
|
for key in identifier_attributes:
|
||||||
|
if realm.deactivated:
|
||||||
|
print(self.style.ERROR(inner_format % (key, realm_dict[key])))
|
||||||
|
deactivated = True
|
||||||
|
else:
|
||||||
|
print(inner_format % (key, realm_dict[key]))
|
||||||
|
|
||||||
|
for key, value in sorted(realm_dict.iteritems()):
|
||||||
|
if key not in identifier_attributes:
|
||||||
|
if realm.deactivated:
|
||||||
|
print(self.style.ERROR(inner_format % (key, value)))
|
||||||
|
else:
|
||||||
|
print(inner_format % (key, value))
|
||||||
|
print("-" * 80)
|
||||||
|
|
||||||
|
if deactivated:
|
||||||
|
print(self.style.WARNING("\nRed is used to highlight deactivated realms."))
|
||||||
Reference in New Issue
Block a user