2021-11-26 13:08:45 +00:00
|
|
|
import { t } from "@lingui/macro";
|
|
|
|
|
|
|
|
import { CSSResult, LitElement, TemplateResult, html } from "lit";
|
2021-11-04 21:34:48 +00:00
|
|
|
import { customElement, property } from "lit/decorators.js";
|
|
|
|
import { ifDefined } from "lit/directives/if-defined.js";
|
2021-02-04 08:54:00 +00:00
|
|
|
|
2021-11-26 13:08:45 +00:00
|
|
|
import AKGlobal from "../../authentik.css";
|
|
|
|
import PFPage from "@patternfly/patternfly/components/Page/page.css";
|
|
|
|
|
2021-09-21 09:31:37 +00:00
|
|
|
import { Provider, ProvidersApi } from "@goauthentik/api";
|
|
|
|
|
|
|
|
import { DEFAULT_CONFIG } from "../../api/Config";
|
2021-03-17 16:11:39 +00:00
|
|
|
import "../../elements/EmptyState";
|
2021-04-10 15:06:54 +00:00
|
|
|
import "../../elements/PageHeader";
|
2021-09-21 09:31:37 +00:00
|
|
|
import "../../elements/buttons/SpinnerButton";
|
|
|
|
import "./ldap/LDAPProviderViewPage";
|
2021-04-01 13:39:59 +00:00
|
|
|
import "./oauth2/OAuth2ProviderViewPage";
|
|
|
|
import "./proxy/ProxyProviderViewPage";
|
2021-09-21 09:31:37 +00:00
|
|
|
import "./saml/SAMLProviderViewPage";
|
2021-02-04 08:54:00 +00:00
|
|
|
|
|
|
|
@customElement("ak-provider-view")
|
|
|
|
export class ProviderViewPage extends LitElement {
|
2021-08-03 15:52:21 +00:00
|
|
|
@property({ type: Number })
|
2021-02-04 08:54:00 +00:00
|
|
|
set providerID(value: number) {
|
2021-08-03 15:52:21 +00:00
|
|
|
new ProvidersApi(DEFAULT_CONFIG)
|
|
|
|
.providersAllRetrieve({
|
|
|
|
id: value,
|
|
|
|
})
|
|
|
|
.then((prov) => (this.provider = prov));
|
2021-02-04 08:54:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@property({ attribute: false })
|
|
|
|
provider?: Provider;
|
|
|
|
|
2021-11-26 13:08:45 +00:00
|
|
|
static get styles(): CSSResult[] {
|
|
|
|
return [PFPage, AKGlobal];
|
|
|
|
}
|
|
|
|
|
2021-04-10 15:06:54 +00:00
|
|
|
renderProvider(): TemplateResult {
|
2021-02-06 16:55:41 +00:00
|
|
|
if (!this.provider) {
|
2021-03-17 18:00:57 +00:00
|
|
|
return html`<ak-empty-state ?loading=${true} ?fullHeight=${true}></ak-empty-state>`;
|
2021-02-06 16:55:41 +00:00
|
|
|
}
|
2021-04-03 09:32:17 +00:00
|
|
|
switch (this.provider?.component) {
|
|
|
|
case "ak-provider-saml-form":
|
2021-08-03 15:52:21 +00:00
|
|
|
return html`<ak-provider-saml-view
|
|
|
|
providerID=${ifDefined(this.provider.pk)}
|
|
|
|
></ak-provider-saml-view>`;
|
2021-04-03 09:32:17 +00:00
|
|
|
case "ak-provider-oauth2-form":
|
2021-08-03 15:52:21 +00:00
|
|
|
return html`<ak-provider-oauth2-view
|
|
|
|
providerID=${ifDefined(this.provider.pk)}
|
|
|
|
></ak-provider-oauth2-view>`;
|
2021-04-03 09:32:17 +00:00
|
|
|
case "ak-provider-proxy-form":
|
2021-08-03 15:52:21 +00:00
|
|
|
return html`<ak-provider-proxy-view
|
|
|
|
providerID=${ifDefined(this.provider.pk)}
|
|
|
|
></ak-provider-proxy-view>`;
|
2021-05-05 19:57:13 +00:00
|
|
|
case "ak-provider-ldap-form":
|
2021-08-03 15:52:21 +00:00
|
|
|
return html`<ak-provider-ldap-view
|
|
|
|
providerID=${ifDefined(this.provider.pk)}
|
|
|
|
></ak-provider-ldap-view>`;
|
2021-02-06 16:55:41 +00:00
|
|
|
default:
|
2021-04-03 09:32:17 +00:00
|
|
|
return html`<p>Invalid provider type ${this.provider?.component}</p>`;
|
2021-02-06 16:55:41 +00:00
|
|
|
}
|
|
|
|
}
|
2021-04-10 15:06:54 +00:00
|
|
|
|
|
|
|
render(): TemplateResult {
|
|
|
|
return html`<ak-page-header
|
2021-08-03 15:52:21 +00:00
|
|
|
icon="pf-icon pf-icon-integration"
|
|
|
|
header=${ifDefined(this.provider?.name)}
|
|
|
|
description=${ifDefined(this.provider?.verboseName)}
|
|
|
|
>
|
|
|
|
</ak-page-header>
|
2021-11-26 13:08:45 +00:00
|
|
|
<ak-tabs>
|
2021-11-26 19:48:06 +00:00
|
|
|
<section slot="page-overview" data-tab-title="${t`Overview`}">
|
2021-11-26 13:08:45 +00:00
|
|
|
${this.renderProvider()}
|
|
|
|
</section>
|
|
|
|
<section
|
|
|
|
slot="page-changelog"
|
|
|
|
data-tab-title="${t`Changelog`}"
|
|
|
|
class="pf-c-page__main-section pf-m-no-padding-mobile"
|
|
|
|
>
|
|
|
|
<div class="pf-c-card">
|
|
|
|
<div class="pf-c-card__body">
|
|
|
|
<ak-object-changelog
|
|
|
|
targetModelPk=${this.provider?.pk || ""}
|
|
|
|
targetModelName=${this.provider?.metaModelName || ""}
|
|
|
|
>
|
|
|
|
</ak-object-changelog>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
</ak-tabs>`;
|
2021-04-10 15:06:54 +00:00
|
|
|
}
|
2021-02-04 08:54:00 +00:00
|
|
|
}
|