2022-03-21 05:48:10 +01:00
|
|
|
import argparse
|
|
|
|
from typing import Any
|
|
|
|
|
2023-08-24 00:00:21 +02:00
|
|
|
from django.core.exceptions import ValidationError
|
2022-03-21 05:48:10 +01:00
|
|
|
from django.core.management.base import CommandError
|
|
|
|
|
2022-04-14 23:58:15 +02:00
|
|
|
from zerver.actions.create_realm import do_create_realm
|
2022-04-14 23:53:15 +02:00
|
|
|
from zerver.actions.create_user import do_create_user
|
2023-08-24 00:00:21 +02:00
|
|
|
from zerver.forms import check_subdomain_available
|
2022-03-21 05:48:10 +01:00
|
|
|
from zerver.lib.management import ZulipBaseCommand
|
|
|
|
from zerver.models import UserProfile
|
|
|
|
|
|
|
|
|
|
|
|
class Command(ZulipBaseCommand):
|
|
|
|
help = """\
|
|
|
|
Create a new Zulip organization (realm) via the command line.
|
|
|
|
|
|
|
|
We recommend `./manage.py generate_realm_creation_link` for most
|
|
|
|
users, for several reasons:
|
|
|
|
|
|
|
|
* Has a more user-friendly web flow for account creation.
|
|
|
|
* Manages passwords in a more natural way.
|
|
|
|
* Automatically logs the user in during account creation.
|
|
|
|
|
|
|
|
This management command is available as an alternative for situations
|
|
|
|
where one wants to script the realm creation process.
|
|
|
|
|
|
|
|
Since every Zulip realm must have an owner, this command creates the
|
|
|
|
initial organization owner user for the new realm, using the same
|
|
|
|
workflow as `./manage.py create_user`.
|
|
|
|
"""
|
|
|
|
|
|
|
|
def add_arguments(self, parser: argparse.ArgumentParser) -> None:
|
|
|
|
parser.add_argument("realm_name", help="Name for the new organization")
|
|
|
|
parser.add_argument(
|
|
|
|
"--string-id",
|
|
|
|
help="Subdomain for the new organization. Empty if root domain.",
|
|
|
|
default="",
|
|
|
|
)
|
2023-08-24 00:00:21 +02:00
|
|
|
parser.add_argument(
|
|
|
|
"--allow-reserved-subdomain",
|
|
|
|
action="store_true",
|
|
|
|
help="Allow use of reserved subdomains",
|
|
|
|
)
|
2022-03-21 05:48:10 +01:00
|
|
|
self.add_create_user_args(parser)
|
|
|
|
|
2023-08-24 00:00:21 +02:00
|
|
|
def handle(self, *args: Any, **options: Any) -> None:
|
2022-03-21 05:48:10 +01:00
|
|
|
realm_name = options["realm_name"]
|
|
|
|
string_id = options["string_id"]
|
2023-08-24 00:00:21 +02:00
|
|
|
allow_reserved_subdomain = options["allow_reserved_subdomain"]
|
|
|
|
|
|
|
|
try:
|
|
|
|
check_subdomain_available(string_id, allow_reserved_subdomain)
|
|
|
|
except ValidationError as error:
|
|
|
|
raise CommandError(error.message)
|
2022-03-21 05:48:10 +01:00
|
|
|
|
|
|
|
create_user_params = self.get_create_user_params(options)
|
|
|
|
|
|
|
|
try:
|
|
|
|
realm = do_create_realm(string_id=string_id, name=realm_name)
|
|
|
|
except AssertionError as e:
|
|
|
|
raise CommandError(str(e))
|
|
|
|
|
|
|
|
do_create_user(
|
|
|
|
create_user_params.email,
|
|
|
|
create_user_params.password,
|
|
|
|
realm,
|
|
|
|
create_user_params.full_name,
|
2023-05-08 09:17:57 +02:00
|
|
|
# Explicitly set tos_version=-1. This means that users
|
|
|
|
# created via this mechanism would be prompted to set
|
|
|
|
# the email_address_visibility setting on first login.
|
|
|
|
# For servers that have configured Terms of Service,
|
|
|
|
# users will also be prompted to accept the Terms of
|
|
|
|
# Service on first login.
|
2022-03-21 05:48:10 +01:00
|
|
|
role=UserProfile.ROLE_REALM_OWNER,
|
|
|
|
realm_creation=True,
|
2023-05-08 09:17:57 +02:00
|
|
|
tos_version=UserProfile.TOS_VERSION_BEFORE_FIRST_LOGIN,
|
2022-03-21 05:48:10 +01:00
|
|
|
acting_user=None,
|
|
|
|
)
|