import { BaseProviderForm } from "@goauthentik/admin/providers/BaseProviderForm"; import { propertyMappingsProvider, propertyMappingsSelector, } from "@goauthentik/admin/providers/microsoft_entra/MicrosoftEntraProviderFormHelpers.js"; import { DEFAULT_CONFIG } from "@goauthentik/common/api/config"; import { first } from "@goauthentik/common/utils"; import "@goauthentik/elements/ak-dual-select/ak-dual-select-dynamic-selected-provider.js"; import "@goauthentik/elements/ak-dual-select/ak-dual-select-provider.js"; import "@goauthentik/elements/forms/FormGroup"; import "@goauthentik/elements/forms/HorizontalFormElement"; import "@goauthentik/elements/forms/Radio"; import "@goauthentik/elements/forms/SearchSelect"; import { msg } from "@lit/localize"; import { TemplateResult, html } from "lit"; import { customElement } from "lit/decorators.js"; import { ifDefined } from "lit/directives/if-defined.js"; import { CoreApi, CoreGroupsListRequest, Group, MicrosoftEntraProvider, OutgoingSyncDeleteAction, ProvidersApi, } from "@goauthentik/api"; @customElement("ak-provider-microsoft-entra-form") export class MicrosoftEntraProviderFormPage extends BaseProviderForm { loadInstance(pk: number): Promise { return new ProvidersApi(DEFAULT_CONFIG).providersMicrosoftEntraRetrieve({ id: pk, }); } async send(data: MicrosoftEntraProvider): Promise { if (this.instance) { return new ProvidersApi(DEFAULT_CONFIG).providersMicrosoftEntraUpdate({ id: this.instance.pk, microsoftEntraProviderRequest: data, }); } else { return new ProvidersApi(DEFAULT_CONFIG).providersMicrosoftEntraCreate({ microsoftEntraProviderRequest: data, }); } } renderForm(): TemplateResult { return html` ${msg("Protocol settings")}

${msg("Client ID for the app registration.")}

${msg("Client secret for the app registration.")}

${msg("ID of the tenant accounts will be synced into.")}

${msg( "When enabled, mutating requests will be dropped and logged instead.", )}

${msg("User filtering")}
=> { const args: CoreGroupsListRequest = { ordering: "name", includeUsers: false, }; if (query !== undefined) { args.search = query; } const groups = await new CoreApi(DEFAULT_CONFIG).coreGroupsList( args, ); return groups.results; }} .renderElement=${(group: Group): string => { return group.name; }} .value=${(group: Group | undefined): string | undefined => { return group ? group.pk : undefined; }} .selected=${(group: Group): boolean => { return group.pk === this.instance?.filterGroup; }} ?blankable=${true} >

${msg("Only sync users within the selected group.")}

${msg("Attribute mapping")}

${msg("Property mappings used to user mapping.")}

${msg("Property mappings used to group creation.")}

`; } } declare global { interface HTMLElementTagNameMap { "ak-provider-microsoft-entra-form": MicrosoftEntraProviderFormPage; } }