import { gettext } from "django"; import { CSSResult, customElement, html, 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 "../../elements/buttons/ModalButton"; import "../../elements/buttons/SpinnerButton"; import "../../elements/CodeMirror"; import "../../elements/Tabs"; import "../../elements/events/ObjectChangelog"; import { Page } from "../../elements/Page"; import { OAuthSource, SourcesApi } from "authentik-api"; import { DEFAULT_CONFIG } from "../../api/Config"; import { AdminURLManager } from "../../api/legacy"; import { EVENT_REFRESH } from "../../constants"; @customElement("ak-source-oauth-view") export class OAuthSourceViewPage extends Page { pageTitle(): string { return gettext(`OAuth Source ${this.source?.name || ""}`); } pageDescription(): string | undefined { return; } pageIcon(): string { return "pf-icon pf-icon-middleware"; } @property({ type: String }) set sourceSlug(value: string) { new SourcesApi(DEFAULT_CONFIG).sourcesOauthRead({ slug: value }).then((source) => { this.source = source; }); } @property({ attribute: false }) source?: OAuthSource; static get styles(): CSSResult[] { return [PFBase, PFPage, PFFlex, PFDisplay, PFGallery, PFContent, PFCard, PFDescriptionList, PFSizing, AKGlobal]; } constructor() { super(); this.addEventListener(EVENT_REFRESH, () => { if (!this.source?.pk) return; this.sourceSlug = this.source?.slug; }); } renderContent(): TemplateResult { if (!this.source) { return html``; } return html`
${gettext("Name")}
${this.source.name}
${gettext("Provider Type")}
${this.source.providerType}
${gettext("Callback URL")}
${this.source.callbackUrl}
${gettext("Access Key")}
${this.source.consumerKey}
${gettext("Authorization URL")}
${this.source.authorizationUrl}
${gettext("Token URL")}
${this.source.accessTokenUrl}
`; } }