mirror of
https://github.com/goauthentik/authentik
synced 2026-05-05 06:32:15 +02:00
When submitting some forms with the Enter key instead of clicking "Confirm"/etc, the form would not get submitted correctly This would in the worst case is when setting a user's password, where the new password can end up in the URL, but the password was not actually saved to the user. Signed-off-by: Jens Langhammer <jens@goauthentik.io> # Conflicts: # web/src/admin/applications/ApplicationCheckAccessForm.ts # web/src/admin/crypto/CertificateGenerateForm.ts # web/src/admin/flows/FlowImportForm.ts # web/src/admin/groups/RelatedGroupList.ts # web/src/admin/policies/PolicyTestForm.ts # web/src/admin/property-mappings/PropertyMappingTestForm.ts # web/src/admin/providers/saml/SAMLProviderImportForm.ts # web/src/admin/users/RelatedUserList.ts # web/src/admin/users/ServiceAccountForm.ts # web/src/admin/users/UserPasswordForm.ts # web/src/admin/users/UserResetEmailForm.ts # Conflicts: # web/src/admin/property-mappings/PropertyMappingTestForm.ts
39 lines
1.2 KiB
TypeScript
39 lines
1.2 KiB
TypeScript
import { DEFAULT_CONFIG } from "@goauthentik/common/api/config";
|
|
import "@goauthentik/elements/buttons/SpinnerButton";
|
|
import { Form } from "@goauthentik/elements/forms/Form";
|
|
import "@goauthentik/elements/forms/HorizontalFormElement";
|
|
|
|
import { t } from "@lingui/macro";
|
|
|
|
import { TemplateResult, html } from "lit";
|
|
import { customElement, property } from "lit/decorators.js";
|
|
|
|
import { CoreApi, UserPasswordSetRequest } from "@goauthentik/api";
|
|
|
|
@customElement("ak-user-password-form")
|
|
export class UserPasswordForm extends Form<UserPasswordSetRequest> {
|
|
@property({ type: Number })
|
|
instancePk?: number;
|
|
|
|
getSuccessMessage(): string {
|
|
return t`Successfully updated password.`;
|
|
}
|
|
|
|
async send(data: UserPasswordSetRequest): Promise<void> {
|
|
return new CoreApi(DEFAULT_CONFIG).coreUsersSetPasswordCreate({
|
|
id: this.instancePk || 0,
|
|
userPasswordSetRequest: data,
|
|
});
|
|
}
|
|
|
|
renderInlineForm(): TemplateResult {
|
|
return html`<ak-form-element-horizontal
|
|
label=${t`Password`}
|
|
?required=${true}
|
|
name="password"
|
|
>
|
|
<input type="password" value="" class="pf-c-form-control" required />
|
|
</ak-form-element-horizontal>`;
|
|
}
|
|
}
|