import { t } from "@lingui/macro"; import { CSSResult, LitElement, TemplateResult, html } from "lit"; import { customElement, property } from "lit/decorators.js"; import AKGlobal from "../../../authentik.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 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 { OAuthSource, ProviderTypeEnum, SourcesApi } from "@goauthentik/api"; import { DEFAULT_CONFIG } from "../../../api/Config"; import { EVENT_REFRESH } from "../../../constants"; import "../../../elements/CodeMirror"; import "../../../elements/Tabs"; import "../../../elements/buttons/SpinnerButton"; import "../../../elements/events/ObjectChangelog"; import "../../../elements/forms/ModalForm"; import "../../policies/BoundPoliciesList"; import "./OAuthSourceForm"; export function ProviderToLabel(provider?: ProviderTypeEnum): string { if (!provider) return ""; switch (provider) { case ProviderTypeEnum.Apple: return "Apple"; case ProviderTypeEnum.Azuread: return "Azure Active Directory"; case ProviderTypeEnum.Discord: return "Discord"; case ProviderTypeEnum.Facebook: return "Facebook"; case ProviderTypeEnum.Github: return "GitHub"; case ProviderTypeEnum.Google: return "Google"; case ProviderTypeEnum.Openidconnect: return t`Generic OpenID Connect`; case ProviderTypeEnum.Reddit: return "Reddit"; case ProviderTypeEnum.Twitter: return "Twitter"; } } @customElement("ak-source-oauth-view") export class OAuthSourceViewPage extends LitElement { @property({ type: String }) set sourceSlug(value: string) { new SourcesApi(DEFAULT_CONFIG) .sourcesOauthRetrieve({ slug: value, }) .then((source) => { this.source = source; }); } @property({ attribute: false }) source?: OAuthSource; static get styles(): CSSResult[] { return [PFBase, PFPage, PFButton, PFGrid, PFContent, PFCard, PFDescriptionList, AKGlobal]; } constructor() { super(); this.addEventListener(EVENT_REFRESH, () => { if (!this.source?.pk) return; this.sourceSlug = this.source?.slug; }); } render(): TemplateResult { if (!this.source) { return html``; } return html`
${t`Name`}
${this.source.name}
${t`Provider Type`}
${ProviderToLabel(this.source.providerType)}
${t`Callback URL`}
${this.source.callbackUrl}
${t`Access Key`}
${this.source.consumerKey}
${t`Authorization URL`}
${this.source.type?.authorizationUrl || this.source.authorizationUrl}
${t`Token URL`}
${this.source.type?.accessTokenUrl || this.source.accessTokenUrl}
${t`These bindings control which users can access this source. You can only use policies here as access is checked before the user is authenticated.`}
`; } }