import "@goauthentik/admin/providers/google_workspace/GoogleWorkspaceProviderForm"; import "@goauthentik/admin/providers/google_workspace/GoogleWorkspaceProviderGroupList"; import "@goauthentik/admin/providers/google_workspace/GoogleWorkspaceProviderUserList"; import "@goauthentik/admin/rbac/ObjectPermissionsPage"; import { DEFAULT_CONFIG } from "@goauthentik/common/api/config"; import { EVENT_REFRESH } from "@goauthentik/common/constants"; import "@goauthentik/components/events/ObjectChangelog"; import { AKElement } from "@goauthentik/elements/Base"; import "@goauthentik/elements/Markdown"; import "@goauthentik/elements/SyncStatusCard"; import "@goauthentik/elements/Tabs"; import "@goauthentik/elements/buttons/ActionButton"; import "@goauthentik/elements/buttons/ModalButton"; import { msg } from "@lit/localize"; import { CSSResult, PropertyValues, TemplateResult, html } from "lit"; import { customElement, property, state } from "lit/decorators.js"; 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 PFStack from "@patternfly/patternfly/layouts/Stack/stack.css"; import PFBase from "@patternfly/patternfly/patternfly-base.css"; import { GoogleWorkspaceProvider, ProvidersApi, RbacPermissionsAssignedByUsersListModelEnum, SyncStatus, } from "@goauthentik/api"; @customElement("ak-provider-google-workspace-view") export class GoogleWorkspaceProviderViewPage extends AKElement { @property({ type: Number }) providerID?: number; @state() provider?: GoogleWorkspaceProvider; @state() syncState?: SyncStatus; static get styles(): CSSResult[] { return [ PFBase, PFButton, PFForm, PFFormControl, PFStack, PFList, PFGrid, PFPage, PFContent, PFCard, PFDescriptionList, ]; } constructor() { super(); this.addEventListener(EVENT_REFRESH, () => { if (!this.provider?.pk) return; this.providerID = this.provider?.pk; }); } fetchProvider(id: number) { new ProvidersApi(DEFAULT_CONFIG) .providersGoogleWorkspaceRetrieve({ id }) .then((prov) => (this.provider = prov)); } willUpdate(changedProperties: PropertyValues) { if (changedProperties.has("providerID") && this.providerID) { this.fetchProvider(this.providerID); } } render(): TemplateResult { if (!this.provider) { return html``; } return html`
{ new ProvidersApi(DEFAULT_CONFIG) .providersGoogleWorkspaceSyncStatusRetrieve({ id: this.provider?.pk || 0, }) .then((state) => { this.syncState = state; }) .catch(() => { this.syncState = undefined; }); }} > ${this.renderTabOverview()}
`; } renderTabOverview(): TemplateResult { if (!this.provider) { return html``; } return html`${!this.provider?.assignedBackchannelApplicationName ? html`
${msg( "Warning: Provider is not assigned to an application as backchannel provider.", )}
` : html``}
${msg("Name")}
${this.provider.name}
{ return new ProvidersApi( DEFAULT_CONFIG, ).providersGoogleWorkspaceSyncStatusRetrieve({ id: this.provider?.pk || 0, }); }} .triggerSync=${() => { return new ProvidersApi( DEFAULT_CONFIG, ).providersGoogleWorkspacePartialUpdate({ id: this.provider?.pk || 0, patchedGoogleWorkspaceProviderRequest: {}, }); }} >
`; } } declare global { interface HTMLElementTagNameMap { "ak-provider-google-workspace-view": GoogleWorkspaceProviderViewPage; } }