import { Config, Configuration, CoreApi, CurrentTenant, Middleware, ResponseContext, RootApi, Tenant } from "authentik-api"; import { getCookie } from "../utils"; import { API_DRAWER_MIDDLEWARE } from "../elements/notifications/APIDrawer"; import { MessageMiddleware } from "../elements/messages/Middleware"; export class LoggingMiddleware implements Middleware { post(context: ResponseContext): Promise { tenant().then(tenant => { console.debug(`authentik/api[${tenant.matchedDomain}]: ${context.response.status} ${context.init.method} ${context.url}`); }); return Promise.resolve(context.response); } } let globalConfigPromise: Promise; export function config(): Promise { if (!globalConfigPromise) { globalConfigPromise = new RootApi(DEFAULT_CONFIG).rootConfigRetrieve(); } return globalConfigPromise; } let globalTenantPromise: Promise; export function tenant(): Promise { if (!globalTenantPromise) { globalTenantPromise = new CoreApi(DEFAULT_CONFIG).coreTenantsCurrentRetrieve(); } return globalTenantPromise; } export const DEFAULT_CONFIG = new Configuration({ basePath: "", headers: { "X-CSRFToken": getCookie("authentik_csrf"), }, middleware: [ API_DRAWER_MIDDLEWARE, new MessageMiddleware(), new LoggingMiddleware(), ], });