import { t } from "@lingui/macro"; import { CSSResult, customElement, html, property, TemplateResult } from "lit-element"; import { AKResponse } from "../../api/Client"; import { Table, TableColumn } from "../table/Table"; import PFFlex from "@patternfly/patternfly/layouts/Flex/flex.css"; import "../forms/DeleteForm"; import { PAGE_SIZE } from "../../constants"; import { RefreshTokenModel, Oauth2Api } from "authentik-api"; import { DEFAULT_CONFIG } from "../../api/Config"; @customElement("ak-user-oauth-refresh-list") export class UserOAuthRefreshList extends Table { expandable = true; @property({ type: Number }) userId?: number; static get styles(): CSSResult[] { return super.styles.concat(PFFlex); } apiEndpoint(page: number): Promise> { return new Oauth2Api(DEFAULT_CONFIG).oauth2RefreshTokensList({ user: this.userId, ordering: "expires", page: page, pageSize: PAGE_SIZE, }); } order = "-expires"; columns(): TableColumn[] { return [ new TableColumn(t`Provider`, "provider"), new TableColumn(t`Expires`, "expires"), new TableColumn(t`Scopes`, "scope"), new TableColumn(""), ]; } renderExpanded(item: RefreshTokenModel): TemplateResult { return html`

${t`ID Token`}

${item.idToken}
`; } row(item: RefreshTokenModel): TemplateResult[] { return [ html` ${item.provider?.name} `, html`${item.expires?.toLocaleString()}`, html`${item.scope.join(", ")}`, html` { return new Oauth2Api(DEFAULT_CONFIG).oauth2RefreshTokensDestroy({ id: item.pk || 0, }); }}> `, ]; } }