Jeśli używasz findOneAndUpdate()
aby zaktualizować, spróbuj użyć pre("findOneAndUpdate")
oprogramowanie pośrednie do modyfikacji hasła podobne do twojego pre("save")
. pre("findOneAndUpdate")
oprogramowanie pośrednie będzie wywoływane za każdym razem, gdy użyjesz Model.findOndAndUpate()
aby zaktualizować swoje modele.
Możesz zrobić to samo za pomocą updateOne()
z pre("updateOne")
Próbka:
// userSchema--------------------
...
userSchema.pre('save', async function (next) {
try {
if (!this.isModified('password')) {
return next();
}
const hashed = await bcrypt.hash(this.password, 10);
this.password = hashed;
} catch (err) {
return next(err);
}
});
userSchema.pre('findOneAndUpdate', async function (next) {
try {
if (this._update.password) {
const hashed = await bcrypt.hash(this._update.password, 10)
this._update.password = hashed;
}
next();
} catch (err) {
return next(err);
}
});
// changepass--------------------
...
if(valid){
//" ?? update password and hash ?? "
const result = await db.user.findOneAndUpdate(
{ username: req.body.username },
{ password: req.body.newPassword },
{ useFindAndModify: false }
);
}