import "@goauthentik/admin/providers/RelatedApplicationButton"; import "@goauthentik/admin/providers/ldap/LDAPProviderForm"; import { DEFAULT_CONFIG } from "@goauthentik/common/api/config"; import { EVENT_REFRESH } from "@goauthentik/common/constants"; import { me } from "@goauthentik/common/users"; import { AKElement } from "@goauthentik/elements/Base"; import "@goauthentik/elements/CodeMirror"; import "@goauthentik/elements/Tabs"; import "@goauthentik/elements/buttons/ModalButton"; import "@goauthentik/elements/buttons/SpinnerButton"; import "@goauthentik/elements/events/ObjectChangelog"; import { t } from "@lingui/macro"; import { CSSResult, TemplateResult, html } from "lit"; import { until } from "lit-html/directives/until.js"; import { customElement, property } from "lit/decorators.js"; import { ifDefined } from "lit/directives/if-defined.js"; import AKGlobal from "@goauthentik/common/styles/authentik.css"; import PFBanner from "@patternfly/patternfly/components/Banner/banner.css"; 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 PFForm from "@patternfly/patternfly/components/Form/form.css"; import PFFormControl from "@patternfly/patternfly/components/FormControl/form-control.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 { LDAPProvider, ProvidersApi } from "@goauthentik/api"; @customElement("ak-provider-ldap-view") export class LDAPProviderViewPage extends AKElement { @property() set args(value: { [key: string]: number }) { this.providerID = value.id; } @property({ type: Number }) set providerID(value: number) { new ProvidersApi(DEFAULT_CONFIG) .providersLdapRetrieve({ id: value, }) .then((prov) => (this.provider = prov)); } @property({ attribute: false }) provider?: LDAPProvider; static get styles(): CSSResult[] { return [ PFBase, PFButton, PFBanner, PFForm, PFFormControl, PFList, PFGrid, PFPage, PFContent, PFCard, PFDescriptionList, AKGlobal, ]; } constructor() { super(); this.addEventListener(EVENT_REFRESH, () => { if (!this.provider?.pk) return; this.providerID = this.provider?.pk; }); } render(): TemplateResult { if (!this.provider) { return html``; } return html`
${this.renderTabOverview()}
`; } renderTabOverview(): TemplateResult { if (!this.provider) { return html``; } return html` ${ this.provider?.outpostSet.length < 1 ? html`
${t`Warning: Provider is not used by any Outpost.`}
` : html`` }
${t`Name`}
${this.provider.name}
${t`Assigned to application`}
${t`Base DN`}
${this.provider.baseDn}
${t`How to connect`}

${t`Connect to the LDAP Server on port 389:`}

  • ${t`Check the IP of the Kubernetes service, or`}
  • ${t`The Host IP of the docker host`}
{ return `cn=${ m.user.username },ou=users,${this.provider?.baseDn?.toLowerCase()}`; }), )} />
`; } }