import { DEFAULT_CONFIG } from "@goauthentik/common/api/config"; import { intentToLabel } from "@goauthentik/common/labels"; import { me } from "@goauthentik/common/users"; import { getRelativeTime } from "@goauthentik/common/utils"; import "@goauthentik/components/ak-status-label"; import "@goauthentik/elements/buttons/Dropdown"; import "@goauthentik/elements/buttons/ModalButton"; import "@goauthentik/elements/buttons/TokenCopyButton"; import "@goauthentik/elements/forms/DeleteBulkForm"; import "@goauthentik/elements/forms/ModalForm"; import { PaginatedResponse } from "@goauthentik/elements/table/Table"; import { Table, TableColumn } from "@goauthentik/elements/table/Table"; import "@goauthentik/user/user-settings/tokens/UserTokenForm"; import "@patternfly/elements/pf-tooltip/pf-tooltip.js"; import { msg } from "@lit/localize"; import { CSSResult, TemplateResult, html } from "lit"; import { customElement, property } from "lit/decorators.js"; import PFDescriptionList from "@patternfly/patternfly/components/DescriptionList/description-list.css"; import { CoreApi, IntentEnum, Token } from "@goauthentik/api"; @customElement("ak-user-token-list") export class UserTokenList extends Table { searchEnabled(): boolean { return true; } expandable = true; checkbox = true; clearOnRefresh = true; @property() order = "expires"; async apiEndpoint(): Promise> { return new CoreApi(DEFAULT_CONFIG).coreTokensList({ ...(await this.defaultEndpointConfig()), managed: "", // The user might have access to other tokens that aren't for their user // but only show tokens for their user here userUsername: (await me()).user.username, }); } columns(): TableColumn[] { return [new TableColumn(msg("Identifier"), "identifier"), new TableColumn("")]; } static get styles(): CSSResult[] { return super.styles.concat(PFDescriptionList); } renderToolbar(): TemplateResult { return html` ${msg("Create")} ${msg("Create Token")} ${msg("Create")} ${msg("Create App password")} ${super.renderToolbar()} `; } renderExpanded(item: Token): TemplateResult { return html`
${msg("User")}
${item.userObj?.username}
${msg("Expiring")}
${msg("Expiring")}
${item.expiring ? html` ${getRelativeTime(item.expires!)} ` : msg("-")}
${msg("Intent")}
${intentToLabel(item.intent ?? IntentEnum.Api)}
`; } renderToolbarSelected(): TemplateResult { const disabled = this.selectedElements.length < 1; return html` [{ key: msg("Identifier"), value: item.identifier }]} .delete=${(item: Token) => new CoreApi(DEFAULT_CONFIG).coreTokensDestroy({ identifier: item.identifier, })} > `; } row(item: Token): TemplateResult[] { return [ html`${item.identifier}`, html` ${msg("Update")} ${msg("Update Token")} `, ]; } } declare global { interface HTMLElementTagNameMap { "ak-user-token-list": UserTokenList; } }