add management command to create a tenant
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
This commit is contained in:
parent
eb02c448aa
commit
39d13c0447
0
authentik/tenants/management/commands/__init__.py
Normal file
0
authentik/tenants/management/commands/__init__.py
Normal file
31
authentik/tenants/management/commands/add_tenant.py
Normal file
31
authentik/tenants/management/commands/add_tenant.py
Normal file
|
@ -0,0 +1,31 @@
|
|||
"""authentik add tenant command"""
|
||||
from django.core.management.base import BaseCommand
|
||||
from django.utils.text import slugify
|
||||
from structlog.stdlib import get_logger
|
||||
|
||||
from authentik.lib.config import CONFIG
|
||||
from authentik.tenants.models import Domain, Tenant
|
||||
|
||||
LOGGER = get_logger()
|
||||
|
||||
|
||||
class Command(BaseCommand):
|
||||
"""Add tenant"""
|
||||
|
||||
def add_arguments(self, parser):
|
||||
parser.add_argument("--domain", nargs="+", type=str)
|
||||
parser.add_argument(
|
||||
"name",
|
||||
type=str,
|
||||
)
|
||||
|
||||
def handle(self, *args, **options):
|
||||
"""Add tenant"""
|
||||
if not CONFIG.get_bool("tenants.enabled"):
|
||||
self.stderr.write("Tenant not enabled")
|
||||
return
|
||||
tenant = Tenant.objects.create(name=options["name"], schema_name=slugify(options["name"]))
|
||||
LOGGER.info("Created tenant", uuid=str(tenant.pk))
|
||||
for domain in options["domain"]:
|
||||
Domain.objects.create(tenant=tenant, domain=domain)
|
||||
LOGGER.info("Created domain", domain=domain)
|
Reference in a new issue