import { ExpressionPolicy, PoliciesApi } from "authentik-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 { ifDefined } from "lit-html/directives/if-defined"; import "../../../elements/forms/HorizontalFormElement"; import "../../../elements/forms/FormGroup"; import "../../../elements/CodeMirror"; import { first } from "../../../utils"; @customElement("ak-policy-expression-form") export class ExpressionPolicyForm extends Form { set policyUUID(value: string) { new PoliciesApi(DEFAULT_CONFIG).policiesExpressionRead({ policyUuid: value, }).then(policy => { this.policy = policy; }); } @property({attribute: false}) policy?: ExpressionPolicy; getSuccessMessage(): string { if (this.policy) { return t`Successfully updated policy.`; } else { return t`Successfully created policy.`; } } send = (data: ExpressionPolicy): Promise => { if (this.policy) { return new PoliciesApi(DEFAULT_CONFIG).policiesExpressionUpdate({ policyUuid: this.policy.pk || "", data: data }); } else { return new PoliciesApi(DEFAULT_CONFIG).policiesExpressionCreate({ data: data }); } }; renderForm(): TemplateResult { return html`

${t`When this option is enabled, all executions of this policy will be logged. By default, only execution errors are logged.`}

${t`Policy-specific settings`}
`; } }