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 { DualSelectPair } from "@goauthentik/elements/ak-dual-select/types.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 { html } from "lit"; import { ifDefined } from "lit/directives/if-defined.js"; import { CoreApi, CoreGroupsListRequest, Group, PropertymappingsApi, SCIMMapping, SCIMProvider, } from "@goauthentik/api"; export async function scimPropertyMappingsProvider(page = 1, search = "") { const propertyMappings = await new PropertymappingsApi( DEFAULT_CONFIG, ).propertymappingsProviderScimList({ ordering: "managed", pageSize: 20, search: search.trim(), page, }); return { pagination: propertyMappings.pagination, options: propertyMappings.results.map((m) => [m.pk, m.name, m.name, m]), }; } export function makeSCIMPropertyMappingsSelector( instanceMappings: string[] | undefined, defaultSelected: string, ) { const localMappings = instanceMappings ? new Set(instanceMappings) : undefined; return localMappings ? ([pk, _]: DualSelectPair) => localMappings.has(pk) : ([_0, _1, _2, mapping]: DualSelectPair) => mapping?.managed === defaultSelected; } export function renderForm(provider?: Partial, errors: ValidationError = {}) { return html` ${msg("Protocol settings")}

${msg("SCIM base url, usually ends in /v2.")}

${msg( "Token to authenticate with. Currently only bearer authentication is supported.", )}

${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 === provider?.filterGroup; }} blankable >

${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.")}

`; }