import "@goauthentik/admin/groups/MemberSelectModal"; import { DEFAULT_CONFIG } from "@goauthentik/common/api/config"; import { first } from "@goauthentik/common/utils"; import "@goauthentik/elements/CodeMirror"; import { CodeMirrorMode } from "@goauthentik/elements/CodeMirror"; import "@goauthentik/elements/ak-dual-select/ak-dual-select-provider"; import { DataProvision, DualSelectPair } from "@goauthentik/elements/ak-dual-select/types"; import "@goauthentik/elements/chips/Chip"; import "@goauthentik/elements/chips/ChipGroup"; import "@goauthentik/elements/forms/HorizontalFormElement"; import { ModelForm } from "@goauthentik/elements/forms/ModelForm"; import "@goauthentik/elements/forms/SearchSelect"; import YAML from "yaml"; import { msg } from "@lit/localize"; import { CSSResult, TemplateResult, css, html } from "lit"; import { customElement } from "lit/decorators.js"; import { ifDefined } from "lit/directives/if-defined.js"; import { CoreApi, CoreGroupsListRequest, Group, RbacApi, Role } from "@goauthentik/api"; export function rbacRolePair(item: Role): DualSelectPair { return [item.pk, html`
${item.name}
`, item.name]; } @customElement("ak-group-form") export class GroupForm extends ModelForm { static get styles(): CSSResult[] { return super.styles.concat(css` .pf-c-button.pf-m-control { height: 100%; } .pf-c-form-control { height: auto !important; } `); } loadInstance(pk: string): Promise { return new CoreApi(DEFAULT_CONFIG).coreGroupsRetrieve({ groupUuid: pk, }); } getSuccessMessage(): string { return this.instance ? msg("Successfully updated group.") : msg("Successfully created group."); } async send(data: Group): Promise { if (this.instance?.pk) { return new CoreApi(DEFAULT_CONFIG).coreGroupsPartialUpdate({ groupUuid: this.instance.pk, patchedGroupRequest: data, }); } else { data.users = []; return new CoreApi(DEFAULT_CONFIG).coreGroupsCreate({ groupRequest: data, }); } } renderForm(): TemplateResult { return html`

${msg("Users added to this group will be superusers.")}

=> { const args: CoreGroupsListRequest = { ordering: "name", }; if (query !== undefined) { args.search = query; } const groups = await new CoreApi(DEFAULT_CONFIG).coreGroupsList(args); if (this.instance) { return groups.results.filter((g) => g.pk !== this.instance?.pk); } return groups.results; }} .renderElement=${(group: Group): string => { return group.name; }} .value=${(group: Group | undefined): string | undefined => { return group?.pk; }} .selected=${(group: Group): boolean => { return group.pk === this.instance?.parent; }} ?blankable=${true} > => { return new RbacApi(DEFAULT_CONFIG) .rbacRolesList({ page: page, search: search, }) .then((results) => { return { pagination: results.pagination, options: results.results.map(rbacRolePair), }; }); }} .selected=${(this.instance?.rolesObj ?? []).map(rbacRolePair)} available-label="${msg("Available Roles")}" selected-label="${msg("Selected Roles")}" >

${msg( "Select roles to grant this groups' users' permissions from the selected roles.", )}

${msg("Set custom attributes using YAML or JSON.")}

`; } }