Możesz użyć isModified w polu „hasło”.
Używam go w ten sposób, uruchamiam bcrypt tylko wtedy, gdy zmieniono właściwość hasła:
UserSchema.pre('save', function (next) {
var user = this;
if (user.isModified('password')) {
bcrypt.genSalt(10, (err, salt) => {
bcrypt.hash(user.password, salt, (err, hash) => {
user.password = hash;
next();
});
});
} else {
next();
}
});