Можете да използвате isModified метод в полето „парола“.
Използвам го по този начин, изпълнявам bcrypt само ако свойството на паролата е променено:
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();
}
});