import { t } from "@lingui/macro"; import { CSSResult, customElement, html, LitElement, property, TemplateResult } from "lit-element"; import PFPage from "@patternfly/patternfly/components/Page/page.css"; import PFContent from "@patternfly/patternfly/components/Content/content.css"; import PFGallery from "@patternfly/patternfly/layouts/Gallery/gallery.css"; import PFCard from "@patternfly/patternfly/components/Card/card.css"; import PFDescriptionList from "@patternfly/patternfly/components/DescriptionList/description-list.css"; import PFSizing from "@patternfly/patternfly/utilities/Sizing/sizing.css"; import PFFlex from "@patternfly/patternfly/utilities/Flex/flex.css"; import PFDisplay from "@patternfly/patternfly/utilities/Display/display.css"; import AKGlobal from "../../../authentik.css"; import PFBase from "@patternfly/patternfly/patternfly-base.css"; import PFButton from "@patternfly/patternfly/components/Button/button.css"; import "../../../elements/buttons/SpinnerButton"; import "../../../elements/buttons/ActionButton"; import "../../../elements/CodeMirror"; import "../../../elements/Tabs"; import "../../../elements/events/ObjectChangelog"; import "../../../elements/forms/ModalForm"; import "./LDAPSourceForm"; import { until } from "lit-html/directives/until"; import { LDAPSource, SourcesApi, TaskStatusEnum } from "authentik-api"; import { DEFAULT_CONFIG } from "../../../api/Config"; import { EVENT_REFRESH } from "../../../constants"; @customElement("ak-source-ldap-view") export class LDAPSourceViewPage extends LitElement { @property({ type: String }) set sourceSlug(slug: string) { new SourcesApi(DEFAULT_CONFIG).sourcesLdapRead({ slug: slug }).then((source) => { this.source = source; }); } @property({ attribute: false }) source!: LDAPSource; static get styles(): CSSResult[] { return [PFBase, PFPage, PFButton, PFFlex, PFDisplay, PFGallery, PFContent, PFCard, PFDescriptionList, PFSizing, AKGlobal]; } constructor() { super(); this.addEventListener(EVENT_REFRESH, () => { if (!this.source?.slug) return; this.sourceSlug = this.source?.slug; }); } render(): TemplateResult { if (!this.source) { return html``; } return html`
${t`Name`}
${this.source.name}
${t`Server URI`}
${this.source.serverUri}
${t`Base DN`}
  • ${this.source.baseDn}

${t`Sync status`}

${until(new SourcesApi(DEFAULT_CONFIG).sourcesLdapSyncStatus({ slug: this.source.slug }).then((ls) => { let header = html``; if (ls.status === TaskStatusEnum.Warning) { header = html`

${t`Task finished with warnings`}

`; } else if (status === TaskStatusEnum.Error) { header = html`

${t`Task finished with errors`}

`; } else { header = html`

${t`Last sync: ${ls.taskFinishTimestamp.toLocaleString()}`}

`; } return html` ${header}
    ${ls.messages.map(m => { return html`
  • ${m}
  • `; })}
`; }).catch(() => { return html`

${t`Not synced yet.`}

`; }), "loading")}
`; } }