import "@goauthentik/admin/rbac/ObjectPermissionsPage"; import "@goauthentik/admin/sources/ldap/LDAPSourceConnectivity"; import "@goauthentik/admin/sources/ldap/LDAPSourceForm"; import { DEFAULT_CONFIG } from "@goauthentik/common/api/config"; import { EVENT_REFRESH } from "@goauthentik/common/constants"; import "@goauthentik/components/events/ObjectChangelog"; import { AKElement } from "@goauthentik/elements/Base"; import "@goauthentik/elements/CodeMirror"; import "@goauthentik/elements/SyncStatusCard"; import "@goauthentik/elements/Tabs"; import "@goauthentik/elements/buttons/ActionButton"; import "@goauthentik/elements/buttons/SpinnerButton"; import "@goauthentik/elements/forms/ModalForm"; import { msg } from "@lit/localize"; import { CSSResult, TemplateResult, html } from "lit"; import { customElement, property, state } from "lit/decorators.js"; import PFButton from "@patternfly/patternfly/components/Button/button.css"; import PFCard from "@patternfly/patternfly/components/Card/card.css"; import PFContent from "@patternfly/patternfly/components/Content/content.css"; import PFDescriptionList from "@patternfly/patternfly/components/DescriptionList/description-list.css"; import PFList from "@patternfly/patternfly/components/List/list.css"; import PFPage from "@patternfly/patternfly/components/Page/page.css"; import PFGrid from "@patternfly/patternfly/layouts/Grid/grid.css"; import PFBase from "@patternfly/patternfly/patternfly-base.css"; import { LDAPSource, RbacPermissionsAssignedByUsersListModelEnum, SourcesApi, SyncStatus, } from "@goauthentik/api"; @customElement("ak-source-ldap-view") export class LDAPSourceViewPage extends AKElement { @property({ type: String }) set sourceSlug(slug: string) { new SourcesApi(DEFAULT_CONFIG) .sourcesLdapRetrieve({ slug: slug, }) .then((source) => { this.source = source; }); } @property({ attribute: false }) source!: LDAPSource; @state() syncState?: SyncStatus; static get styles(): CSSResult[] { return [PFBase, PFPage, PFButton, PFGrid, PFContent, PFCard, PFDescriptionList, PFList]; } constructor() { super(); this.addEventListener(EVENT_REFRESH, () => { if (!this.source?.slug) return; this.sourceSlug = this.source?.slug; }); } load(): void { new SourcesApi(DEFAULT_CONFIG) .sourcesLdapSyncStatusRetrieve({ slug: this.source.slug, }) .then((state) => { this.syncState = state; }); } render(): TemplateResult { if (!this.source) { return html``; } return html`
{ this.load(); }} >
${msg("Name")}
${this.source.name}
${msg("Server URI")}
${this.source.serverUri}
${msg("Base DN")}
  • ${this.source.baseDn}

${msg("Connectivity")}

{ return new SourcesApi(DEFAULT_CONFIG).sourcesLdapSyncStatusRetrieve( { slug: this.source?.slug, }, ); }} .triggerSync=${() => { return new SourcesApi(DEFAULT_CONFIG).sourcesLdapPartialUpdate({ slug: this.source?.slug || "", patchedLDAPSourceRequest: {}, }); }} >
`; } }