import { CoreApi, PoliciesApi, Policy, PolicyTestRequest, PolicyTestResult } from "@goauthentik/api"; import { t } from "@lingui/macro"; import { customElement, property } from "lit-element"; import { html, TemplateResult } from "lit-html"; import { DEFAULT_CONFIG } from "../../api/Config"; import { Form } from "../../elements/forms/Form"; import { until } from "lit-html/directives/until"; import "../../elements/forms/HorizontalFormElement"; import "../../elements/CodeMirror"; import YAML from "yaml"; import { first } from "../../utils"; @customElement("ak-policy-test-form") export class PolicyTestForm extends Form { @property({ attribute: false }) policy?: Policy; @property({ attribute: false }) result?: PolicyTestResult; @property({ attribute: false }) request?: PolicyTestRequest; getSuccessMessage(): string { return t`Successfully sent test-request.`; } send = (data: PolicyTestRequest): Promise => { this.request = data; return new PoliciesApi(DEFAULT_CONFIG) .policiesAllTestCreate({ policyUuid: this.policy?.pk || "", policyTestRequest: data, }) .then((result) => (this.result = result)); }; renderResult(): TemplateResult { return html`
${this.result?.passing ? t`Yes` : t`No`}
    ${(this.result?.messages || []).length > 0 ? this.result?.messages?.map((m) => { return html`
  • ${m}
  • `; }) : html`
  • -
  • `}
`; } renderForm(): TemplateResult { return html`
>

${t`Set custom attributes using YAML or JSON.`}

${this.result ? this.renderResult() : html``}
`; } }