import "@goauthentik/admin/providers/RelatedApplicationButton"; import "@goauthentik/admin/providers/saml/SAMLProviderForm"; import { DEFAULT_CONFIG } from "@goauthentik/common/api/config"; import { EVENT_REFRESH } from "@goauthentik/common/constants"; import { MessageLevel } from "@goauthentik/common/messages"; import { AKElement } from "@goauthentik/elements/Base"; import "@goauthentik/elements/CodeMirror"; import "@goauthentik/elements/EmptyState"; import "@goauthentik/elements/Tabs"; import "@goauthentik/elements/buttons/ActionButton"; import "@goauthentik/elements/buttons/ModalButton"; import "@goauthentik/elements/buttons/SpinnerButton"; import "@goauthentik/elements/events/ObjectChangelog"; import { showMessage } from "@goauthentik/elements/messages/MessageContainer"; import { msg } from "@lit/localize"; import { CSSResult, TemplateResult, html } from "lit"; import { customElement, property, state } from "lit/decorators.js"; import { ifDefined } from "lit/directives/if-defined.js"; 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 { CertificateKeyPair, CryptoApi, ProvidersApi, SAMLMetadata, SAMLProvider, } from "@goauthentik/api"; interface SAMLPreviewAttribute { attributes: { Name: string; Value: string[]; }[]; nameID: string; } @customElement("ak-provider-saml-view") export class SAMLProviderViewPage extends AKElement { @property() set args(value: { [key: string]: number }) { this.providerID = value.id; } @property({ type: Number }) set providerID(value: number) { new ProvidersApi(DEFAULT_CONFIG) .providersSamlRetrieve({ id: value, }) .then((prov) => { this.provider = prov; if (prov.signingKp) { new CryptoApi(DEFAULT_CONFIG) .cryptoCertificatekeypairsRetrieve({ kpUuid: prov.signingKp, }) .then((kp) => (this.signer = kp)); } if (prov.verificationKp) { new CryptoApi(DEFAULT_CONFIG) .cryptoCertificatekeypairsRetrieve({ kpUuid: prov.verificationKp, }) .then((kp) => (this.verifier = kp)); } }); } @property({ attribute: false }) provider?: SAMLProvider; @state() preview?: SAMLPreviewAttribute; @state() metadata?: SAMLMetadata; @state() signer?: CertificateKeyPair; @state() verifier?: CertificateKeyPair; static get styles(): CSSResult[] { return [ PFBase, PFButton, PFPage, PFGrid, PFContent, PFCard, PFList, PFDescriptionList, PFForm, PFFormControl, PFBanner, ]; } constructor() { super(); this.addEventListener(EVENT_REFRESH, () => { if (!this.provider?.pk) return; this.providerID = this.provider?.pk; }); } renderRelatedObjects(): TemplateResult { const relatedObjects = []; if (this.provider?.assignedApplicationName) { relatedObjects.push(html`
${value}