mirror of
https://github.com/logto-io/logto.git
synced 2024-12-30 20:33:54 -05:00
feat(core): check password policy before changing password (#6649)
This commit is contained in:
parent
e3be97b528
commit
72a57e23cd
2 changed files with 20 additions and 2 deletions
|
@ -12,13 +12,15 @@ import {
|
|||
verifyUserSensitivePermission,
|
||||
} from '../../libraries/verification.js';
|
||||
import assertThat from '../../utils/assert-that.js';
|
||||
import { PasswordValidator } from '../experience/classes/libraries/password-validator.js';
|
||||
import type { UserRouter, RouterInitArgs } from '../types.js';
|
||||
|
||||
export default function profileRoutes<T extends UserRouter>(
|
||||
...[router, { queries, libraries }]: RouterInitArgs<T>
|
||||
) {
|
||||
const {
|
||||
users: { updateUserById },
|
||||
users: { updateUserById, findUserById },
|
||||
signInExperiences: { findDefaultSignInExperience },
|
||||
} = queries;
|
||||
|
||||
const {
|
||||
|
@ -80,7 +82,10 @@ export default function profileRoutes<T extends UserRouter>(
|
|||
const { id: userId } = ctx.auth;
|
||||
const { password, verificationRecordId } = ctx.guard.body;
|
||||
|
||||
// TODO(LOG-9947): apply password policy
|
||||
const user = await findUserById(userId);
|
||||
const signInExperience = await findDefaultSignInExperience();
|
||||
const passwordPolicyChecker = new PasswordValidator(signInExperience.passwordPolicy, user);
|
||||
await passwordPolicyChecker.validatePassword(password, user);
|
||||
|
||||
await verifyUserSensitivePermission({
|
||||
userId,
|
||||
|
|
|
@ -128,6 +128,19 @@ describe('profile', () => {
|
|||
await deleteDefaultTenantUser(user.id);
|
||||
});
|
||||
|
||||
it('should fail if password does not meet the password policy', async () => {
|
||||
const { user, username, password } = await createDefaultTenantUserWithPassword();
|
||||
const api = await signInAndGetUserApi(username, password);
|
||||
const newPassword = '123456';
|
||||
|
||||
await expectRejects(updatePassword(api, 'invalid-varification-record-id', newPassword), {
|
||||
code: 'password.rejected',
|
||||
status: 422,
|
||||
});
|
||||
|
||||
await deleteDefaultTenantUser(user.id);
|
||||
});
|
||||
|
||||
it('should be able to update password', async () => {
|
||||
const { user, username, password } = await createDefaultTenantUserWithPassword();
|
||||
const api = await signInAndGetUserApi(username, password);
|
||||
|
|
Loading…
Reference in a new issue