fix(auth): prevent reuse of current password on first-access change
Some checks failed
Aegis CI / lint-and-test (push) Has been cancelled
Some checks failed
Aegis CI / lint-and-test (push) Has been cancelled
When must_change_password is true the user must pick a genuinely new password. Added a verify_password check against the existing hash before accepting the new value, raising BusinessRuleViolation if they match. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -41,5 +41,9 @@ def change_password(
|
|||||||
"""
|
"""
|
||||||
if not verify_password(current_password, user.hashed_password):
|
if not verify_password(current_password, user.hashed_password):
|
||||||
raise BusinessRuleViolation("Current password is incorrect")
|
raise BusinessRuleViolation("Current password is incorrect")
|
||||||
|
if verify_password(new_password, user.hashed_password):
|
||||||
|
raise BusinessRuleViolation(
|
||||||
|
"New password must be different from the current password"
|
||||||
|
)
|
||||||
user.hashed_password = hash_password(new_password)
|
user.hashed_password = hash_password(new_password)
|
||||||
user.must_change_password = False
|
user.must_change_password = False
|
||||||
|
|||||||
Reference in New Issue
Block a user