fe7f23238c
* core: initial migration to /if Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * core: move jsi18n to api Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * tests: fix static URLs in tests Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * web: add new html files to rollup Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * web: fix rollup config and nginx config Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * core: add Impersonation support to user API Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * web: add banner for impersonation Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * tests: fix test_user function for new User API Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * flows: add background to API Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * web: set background from flow API Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * core: make root view login_required for redirect Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * flows: redirect to root-redirect instead of if-admin direct Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * api: add header to prevent Authorization Basic prompt in browser Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * web: redirect to root when user/me request fails Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
70 lines
2.2 KiB
Python
70 lines
2.2 KiB
Python
"""authentik URL Configuration"""
|
|
from django.conf import settings
|
|
from django.conf.urls.static import static
|
|
from django.contrib import admin
|
|
from django.urls import include, path
|
|
from django.views.generic import RedirectView
|
|
from structlog.stdlib import get_logger
|
|
|
|
from authentik.core.views import error
|
|
from authentik.lib.utils.reflection import get_apps
|
|
from authentik.root.monitoring import LiveView, MetricsView, ReadyView
|
|
|
|
LOGGER = get_logger()
|
|
admin.autodiscover()
|
|
admin.site.login = RedirectView.as_view(
|
|
pattern_name="authentik_flows:default-authentication"
|
|
)
|
|
admin.site.logout = RedirectView.as_view(
|
|
pattern_name="authentik_flows:default-invalidation"
|
|
)
|
|
|
|
handler400 = error.BadRequestView.as_view()
|
|
handler403 = error.ForbiddenView.as_view()
|
|
handler404 = error.NotFoundView.as_view()
|
|
handler500 = error.ServerErrorView.as_view()
|
|
|
|
urlpatterns = []
|
|
|
|
for _authentik_app in get_apps():
|
|
mountpoints = None
|
|
base_url_module = _authentik_app.name + ".urls"
|
|
if hasattr(_authentik_app, "mountpoint"):
|
|
mountpoint = getattr(_authentik_app, "mountpoint")
|
|
mountpoints = {base_url_module: mountpoint}
|
|
if hasattr(_authentik_app, "mountpoints"):
|
|
mountpoints = getattr(_authentik_app, "mountpoints")
|
|
if not mountpoints:
|
|
continue
|
|
for module, mountpoint in mountpoints.items():
|
|
namespace = _authentik_app.label + module.replace(base_url_module, "")
|
|
_path = path(
|
|
mountpoint,
|
|
include(
|
|
(module, _authentik_app.label),
|
|
namespace=namespace,
|
|
),
|
|
)
|
|
urlpatterns.append(_path)
|
|
LOGGER.debug(
|
|
"Mounted URLs",
|
|
app_name=_authentik_app.name,
|
|
app_mountpoint=mountpoint,
|
|
namespace=namespace,
|
|
)
|
|
|
|
urlpatterns += [
|
|
path("administration/django/", admin.site.urls),
|
|
path("metrics/", MetricsView.as_view(), name="metrics"),
|
|
path("-/health/live/", LiveView.as_view(), name="health-live"),
|
|
path("-/health/ready/", ReadyView.as_view(), name="health-ready"),
|
|
]
|
|
|
|
if settings.DEBUG:
|
|
|
|
urlpatterns = (
|
|
static(settings.STATIC_URL, document_root=settings.STATIC_ROOT)
|
|
+ static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
|
|
+ urlpatterns
|
|
)
|