import { gettext } from "django"; import { CSSResult, customElement, html, property, TemplateResult } from "lit-element"; import { COMMON_STYLES } from "../../common/styles"; import "../../elements/buttons/ModalButton"; import "../../elements/buttons/SpinnerButton"; import "../../elements/CodeMirror"; import "../../elements/Tabs"; import { Page } from "../../elements/Page"; import { convertToTitle } from "../../utils"; import "./RelatedApplicationButton"; import { OAuth2Provider, OAuth2ProviderSetupURLs, ProvidersApi } from "authentik-api"; import { DEFAULT_CONFIG } from "../../api/Config"; import { AdminURLManager } from "../../api/legacy"; @customElement("ak-provider-oauth2-view") export class OAuth2ProviderViewPage extends Page { pageTitle(): string { return gettext(`OAuth Provider ${this.provider?.name || ""}`); } pageDescription(): string | undefined { return; } pageIcon(): string { return "pf-icon pf-icon-integration"; } @property({type: Number}) set providerID(value: number) { const api = new ProvidersApi(DEFAULT_CONFIG); api.providersOauth2Read({ id: value }).then((prov) => { this.provider = prov; }); api.providersOauth2SetupUrls({ id: value }).then((prov) => { this.providerUrls = prov; }); } @property({ attribute: false }) provider?: OAuth2Provider; @property({ attribute: false }) providerUrls?: OAuth2ProviderSetupURLs; static get styles(): CSSResult[] { return COMMON_STYLES; } constructor() { super(); this.addEventListener("ak-refresh", () => { if (!this.provider?.pk) return; this.providerID = this.provider?.pk; }); } renderContent(): TemplateResult { if (!this.provider) { return html``; } return html`
${gettext("Name")}
${this.provider.name}
${gettext("Assigned to application")}
${gettext("Client type")}
${convertToTitle(this.provider.clientType || "")}
${gettext("Client ID")}
${this.provider.clientId}
${gettext("Redirect URIs")}
${this.provider.redirectUris}

`; } }