Se stai usando findOneAndUpdate()
per aggiornare, prova a utilizzare pre("findOneAndUpdate")
middleware per modificare la password in modo simile al tuo pre("save")
. Il pre("findOneAndUpdate")
il middleware verrà chiamato ogni volta che utilizzi Model.findOndAndUpate()
per aggiornare i tuoi modelli.
Puoi fare lo stesso con updateOne()
con pre("updateOne")
Esempio:
// 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 }
);
}