Compare commits
	
		
			10 Commits
		
	
	
		
			web/parts/
			...
			web/cleanu
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 27e9e892e7 | |||
| 70bf745c0c | |||
| 8b4e0361c4 | |||
| 22cb5b7379 | |||
| 2d0117d096 | |||
| 035bda4eac | |||
| 50906214e5 | |||
| e505f274b6 | |||
| fe52f44dca | |||
| 3146e5a50f | 
@ -1,155 +1,266 @@
 | 
			
		||||
import "@goauthentik/admin/admin-overview/AdminOverviewPage";
 | 
			
		||||
import { ID_REGEX, Route, SLUG_REGEX, UUID_REGEX } from "@goauthentik/elements/router/Route";
 | 
			
		||||
import { ID_REGEX, SLUG_REGEX, UUID_REGEX } from "@goauthentik/elements/router/Route";
 | 
			
		||||
import { RawRoute, makeRoute } from "@goauthentik/elements/router/routeUtils";
 | 
			
		||||
 | 
			
		||||
import { html } from "lit";
 | 
			
		||||
 | 
			
		||||
export const ROUTES: Route[] = [
 | 
			
		||||
export const _ROUTES: RawRoute[] = [
 | 
			
		||||
    // Prevent infinite Shell loops
 | 
			
		||||
    new Route(new RegExp("^/$")).redirect("/administration/overview"),
 | 
			
		||||
    new Route(new RegExp("^#.*")).redirect("/administration/overview"),
 | 
			
		||||
    new Route(new RegExp("^/library$")).redirect("/if/user/", true),
 | 
			
		||||
    ["^/$", "/administration/overview"],
 | 
			
		||||
    ["^#.*", "/administration/overview"],
 | 
			
		||||
    ["^/library$", ["/if/user/", true]],
 | 
			
		||||
    // statically imported since this is the default route
 | 
			
		||||
    new Route(new RegExp("^/administration/overview$"), async () => {
 | 
			
		||||
    [
 | 
			
		||||
        "^/administration/overview$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            return html`<ak-admin-overview></ak-admin-overview>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/administration/dashboard/users$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/administration/dashboard/users$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/admin-overview/DashboardUserPage");
 | 
			
		||||
            return html`<ak-admin-dashboard-users></ak-admin-dashboard-users>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/administration/system-tasks$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/administration/system-tasks$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/system-tasks/SystemTaskListPage");
 | 
			
		||||
            return html`<ak-system-task-list></ak-system-task-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/core/providers$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/core/providers$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/providers/ProviderListPage");
 | 
			
		||||
            return html`<ak-provider-list></ak-provider-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp(`^/core/providers/(?<id>${ID_REGEX})$`), async (args) => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        `^/core/providers/(?<id>${ID_REGEX}])$`,
 | 
			
		||||
        async (args) => {
 | 
			
		||||
            await import("@goauthentik/admin/providers/ProviderViewPage");
 | 
			
		||||
            return html`<ak-provider-view .providerID=${parseInt(args.id, 10)}></ak-provider-view>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/core/applications$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/core/applications$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/applications/ApplicationListPage");
 | 
			
		||||
            return html`<ak-application-list></ak-application-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp(`^/core/applications/(?<slug>${SLUG_REGEX})$`), async (args) => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        `^/core/applications/(?<slug>${SLUG_REGEX})$`,
 | 
			
		||||
        async (args) => {
 | 
			
		||||
            await import("@goauthentik/admin/applications/ApplicationViewPage");
 | 
			
		||||
            return html`<ak-application-view .applicationSlug=${args.slug}></ak-application-view>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/core/sources$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/core/sources$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/sources/SourceListPage");
 | 
			
		||||
            return html`<ak-source-list></ak-source-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp(`^/core/sources/(?<slug>${SLUG_REGEX})$`), async (args) => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        `^/core/sources/(?<slug>${SLUG_REGEX})$`,
 | 
			
		||||
        async (args) => {
 | 
			
		||||
            await import("@goauthentik/admin/sources/SourceViewPage");
 | 
			
		||||
            return html`<ak-source-view .sourceSlug=${args.slug}></ak-source-view>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/core/property-mappings$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/core/property-mappings$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/property-mappings/PropertyMappingListPage");
 | 
			
		||||
            return html`<ak-property-mapping-list></ak-property-mapping-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/core/tokens$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/core/tokens$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/tokens/TokenListPage");
 | 
			
		||||
            return html`<ak-token-list></ak-token-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/core/brands"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/core/brands",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/brands/BrandListPage");
 | 
			
		||||
            return html`<ak-brand-list></ak-brand-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/policy/policies$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/policy/policies$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/policies/PolicyListPage");
 | 
			
		||||
            return html`<ak-policy-list></ak-policy-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/policy/reputation$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/policy/reputation$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/policies/reputation/ReputationListPage");
 | 
			
		||||
            return html`<ak-policy-reputation-list></ak-policy-reputation-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/identity/groups$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/identity/groups$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/groups/GroupListPage");
 | 
			
		||||
            return html`<ak-group-list></ak-group-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp(`^/identity/groups/(?<uuid>${UUID_REGEX})$`), async (args) => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        `^/identity/groups/(?<uuid>${UUID_REGEX})$`,
 | 
			
		||||
        async (args) => {
 | 
			
		||||
            await import("@goauthentik/admin/groups/GroupViewPage");
 | 
			
		||||
            return html`<ak-group-view .groupId=${args.uuid}></ak-group-view>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/identity/users$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/identity/users$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/users/UserListPage");
 | 
			
		||||
            return html`<ak-user-list></ak-user-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp(`^/identity/users/(?<id>${ID_REGEX})$`), async (args) => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        `^/identity/users/(?<id>${ID_REGEX})$`,
 | 
			
		||||
        async (args) => {
 | 
			
		||||
            await import("@goauthentik/admin/users/UserViewPage");
 | 
			
		||||
            return html`<ak-user-view .userId=${parseInt(args.id, 10)}></ak-user-view>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/identity/roles$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/identity/roles$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/roles/RoleListPage");
 | 
			
		||||
            return html`<ak-role-list></ak-role-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp(`^/identity/roles/(?<id>${UUID_REGEX})$`), async (args) => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        `^/identity/roles/(?<id>${UUID_REGEX})$`,
 | 
			
		||||
        async (args) => {
 | 
			
		||||
            await import("@goauthentik/admin/roles/RoleViewPage");
 | 
			
		||||
            return html`<ak-role-view roleId=${args.id}></ak-role-view>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/flow/stages/invitations$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/flow/stages/invitations$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/stages/invitation/InvitationListPage");
 | 
			
		||||
            return html`<ak-stage-invitation-list></ak-stage-invitation-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/flow/stages/prompts$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/flow/stages/prompts$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/stages/prompt/PromptListPage");
 | 
			
		||||
            return html`<ak-stage-prompt-list></ak-stage-prompt-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/flow/stages$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/flow/stages$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/stages/StageListPage");
 | 
			
		||||
            return html`<ak-stage-list></ak-stage-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/flow/flows$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/flow/flows$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/flows/FlowListPage");
 | 
			
		||||
            return html`<ak-flow-list></ak-flow-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp(`^/flow/flows/(?<slug>${SLUG_REGEX})$`), async (args) => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        `^/flow/flows/(?<slug>${SLUG_REGEX})$`,
 | 
			
		||||
        async (args) => {
 | 
			
		||||
            await import("@goauthentik/admin/flows/FlowViewPage");
 | 
			
		||||
            return html`<ak-flow-view .flowSlug=${args.slug}></ak-flow-view>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/events/log$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/events/log$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/events/EventListPage");
 | 
			
		||||
            return html`<ak-event-list></ak-event-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp(`^/events/log/(?<id>${UUID_REGEX})$`), async (args) => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        `^/events/log/(?<id>${UUID_REGEX})$`,
 | 
			
		||||
        async (args) => {
 | 
			
		||||
            await import("@goauthentik/admin/events/EventViewPage");
 | 
			
		||||
            return html`<ak-event-view .eventID=${args.id}></ak-event-view>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/events/transports$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/events/transports$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/events/TransportListPage");
 | 
			
		||||
            return html`<ak-event-transport-list></ak-event-transport-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/events/rules$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/events/rules$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/events/RuleListPage");
 | 
			
		||||
            return html`<ak-event-rule-list></ak-event-rule-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/outpost/outposts$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/outpost/outposts$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/outposts/OutpostListPage");
 | 
			
		||||
            return html`<ak-outpost-list></ak-outpost-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/outpost/integrations$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/outpost/integrations$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/outposts/ServiceConnectionListPage");
 | 
			
		||||
            return html`<ak-outpost-service-connection-list></ak-outpost-service-connection-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/crypto/certificates$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/crypto/certificates$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/crypto/CertificateKeyPairListPage");
 | 
			
		||||
            return html`<ak-crypto-certificate-list></ak-crypto-certificate-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/admin/settings$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/admin/settings$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/admin-settings/AdminSettingsPage");
 | 
			
		||||
            return html`<ak-admin-settings></ak-admin-settings>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/blueprints/instances$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/blueprints/instances$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/blueprints/BlueprintListPage");
 | 
			
		||||
            return html`<ak-blueprint-list></ak-blueprint-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/debug$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/debug$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/DebugPage");
 | 
			
		||||
            return html`<ak-admin-debug-page></ak-admin-debug-page>`;
 | 
			
		||||
    }),
 | 
			
		||||
    new Route(new RegExp("^/enterprise/licenses$"), async () => {
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
    [
 | 
			
		||||
        "^/enterprise/licenses$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/admin/enterprise/EnterpriseLicenseListPage");
 | 
			
		||||
            return html`<ak-enterprise-license-list></ak-enterprise-license-list>`;
 | 
			
		||||
    }),
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
];
 | 
			
		||||
 | 
			
		||||
export const ROUTES = _ROUTES.map(makeRoute);
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										41
									
								
								web/src/elements/router/routeUtils.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								web/src/elements/router/routeUtils.ts
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,41 @@
 | 
			
		||||
import { Route, RouteArgs } from "@goauthentik/elements/router/Route";
 | 
			
		||||
import { P, match } from "ts-pattern";
 | 
			
		||||
 | 
			
		||||
import { TemplateResult } from "lit";
 | 
			
		||||
 | 
			
		||||
type ListRoute = () => Promise<TemplateResult<1>>;
 | 
			
		||||
type ViewRoute = (_1: RouteArgs) => Promise<TemplateResult<1>>;
 | 
			
		||||
type InternalRedirect = string;
 | 
			
		||||
type ExternalRedirect = [string, boolean];
 | 
			
		||||
 | 
			
		||||
type RouteInvoke = ViewRoute | ListRoute;
 | 
			
		||||
 | 
			
		||||
type RedirectRoute = [string, InternalRedirect | ExternalRedirect];
 | 
			
		||||
type PageRoute = [string, RouteInvoke];
 | 
			
		||||
 | 
			
		||||
export type RawRoute = PageRoute | RedirectRoute;
 | 
			
		||||
 | 
			
		||||
// eslint-disable-next-line @typescript-eslint/no-explicit-any
 | 
			
		||||
const isLoader = (v: any): v is RouteInvoke => typeof v === "function";
 | 
			
		||||
 | 
			
		||||
// When discriminating between redirects and loaders, the loader type is irrelevant to routing
 | 
			
		||||
// correctly. The loader type *is* still well-typed to prevent an incompatible loader being added to
 | 
			
		||||
// a route, but the two different loader types-- ones that take arguments, and ones that do not-- do
 | 
			
		||||
// not matter to the route builder.
 | 
			
		||||
 | 
			
		||||
// On the other hand, the two different kinds of redirects *do* matter, but only because JavaScript
 | 
			
		||||
// makes a distinction between methods of one argument that can be `call`'ed and methods of more
 | 
			
		||||
// than one argument that must be `apply`'d. (Spread arguments are converted to call or apply as
 | 
			
		||||
// needed).
 | 
			
		||||
 | 
			
		||||
// prettier-ignore
 | 
			
		||||
export function makeRoute(route: RawRoute): Route {
 | 
			
		||||
    return match(route)
 | 
			
		||||
        .with([P.string, P.when(isLoader)],
 | 
			
		||||
              ([path, loader]) => new Route(new RegExp(path), loader))
 | 
			
		||||
        .with([P.string, P.string],
 | 
			
		||||
              ([path, redirect]) => new Route(new RegExp(path)).redirect(redirect))
 | 
			
		||||
        .with([P.string, [P.string, P.boolean]],
 | 
			
		||||
              ([path, redirect]) => new Route(new RegExp(path)).redirect(...redirect))
 | 
			
		||||
        .exhaustive();
 | 
			
		||||
}
 | 
			
		||||
@ -1,15 +1,20 @@
 | 
			
		||||
import { Route } from "@goauthentik/elements/router/Route";
 | 
			
		||||
import { RawRoute, makeRoute } from "@goauthentik/elements/router/routeUtils";
 | 
			
		||||
import "@goauthentik/user/LibraryPage/LibraryPage";
 | 
			
		||||
 | 
			
		||||
import { html } from "lit";
 | 
			
		||||
 | 
			
		||||
export const ROUTES: Route[] = [
 | 
			
		||||
export const _ROUTES: RawRoute[] = [
 | 
			
		||||
    // Prevent infinite Shell loops
 | 
			
		||||
    new Route(new RegExp("^/$")).redirect("/library"),
 | 
			
		||||
    new Route(new RegExp("^#.*")).redirect("/library"),
 | 
			
		||||
    new Route(new RegExp("^/library$"), async () => html`<ak-library></ak-library>`),
 | 
			
		||||
    new Route(new RegExp("^/settings$"), async () => {
 | 
			
		||||
    ["^/$", "/library"],
 | 
			
		||||
    ["^#.*", "/library"],
 | 
			
		||||
    ["^/library$", async () => html`<ak-library></ak-library>`],
 | 
			
		||||
    [
 | 
			
		||||
        "^/settings$",
 | 
			
		||||
        async () => {
 | 
			
		||||
            await import("@goauthentik/user/user-settings/UserSettingsPage");
 | 
			
		||||
            return html`<ak-user-settings></ak-user-settings>`;
 | 
			
		||||
    }),
 | 
			
		||||
        },
 | 
			
		||||
    ],
 | 
			
		||||
];
 | 
			
		||||
 | 
			
		||||
export const ROUTES = _ROUTES.map(makeRoute);
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user