Я не могу найти проблему в моей модели sequelize. Когда я перенаправляю (загружаю) своих пользователей, я получаю другой набор pwd и поэтому не могу войти в систему. Когда я обновляю запись db на правильный pwd, он, очевидно, работает. Кажется, что-то не так, может быть, с массовым крючком обновления или чем-то еще? Это очень странно.Sequelize bulk update различное поведение
'use strict';
var crypto = require('crypto');
var validatePresenceOf = function(value) {
return value && value.length;
};
module.exports = function(sequelize, DataTypes) {
var User = sequelize.define('user', {
name: { type: DataTypes.STRING },
email: { type: DataTypes.STRING, unique: true, allowNull: false, validate: {notEmpty: true},
set: function(email) {
this.setDataValue('email', email.toLowerCase());
}
},
role: { type: DataTypes.STRING, defaultValue: 'user' },
password: { type: DataTypes.STRING, allowNull: false, validate: { notEmpty: true, isEmail: true },
},
provider: { type: DataTypes.STRING },
salt: { type: DataTypes.STRING }
}, {
underscored: true,
getterMethods: {
profile: function() {
return {
name: this.name,
role: this.role
}
}
},
hooks: {
beforeBulkCreate: function(users, fields, fn) {
var totalUpdated = 0;
users.forEach(function(user) {
user.updatePassword(function(err) {
if (err) {
return fn(err);
}
totalUpdated += 1;
if (totalUpdated === users.length) {
return fn();
}
});
});
},
beforeCreate: function(user, fields, fn) {
user.updatePassword(fn);
},
beforeUpdate: function(user, fields, fn) {
if (user.changed('password')) {
user.updatePassword(fn);
}
}
},
instanceMethods: {
/**
* Authenticate - check if the passwords are the same
*
* @param {String} plainText
* {function} callBack
* @api public
*/
authenticate: function(password, callback) {
if (!callback) {
return this.password === this.encryptPassword(password);
}
var _this = this;
this.encryptPassword(password, function(err, pwdGen) {
if (err) {
callback(err);
}
if (_this.password === pwdGen) {
callback(null, true);
}
else {
callback(null, false);
}
});
},
/**
* Make salt
*
* @return {String}
* @api public
*/
makeSalt: function(byteSize, callback) {
var defaultByteSize = 16;
if (typeof arguments[0] === 'function') {
callback = arguments[0];
byteSize = defaultByteSize;
}
else if (typeof arguments[1] === 'function') {
callback = arguments[1];
}
if (!byteSize) {
byteSize = defaultByteSize;
}
if (!callback) {
return crypto.randomBytes(byteSize).toString('base64');
}
return crypto.randomBytes(byteSize, function(err, salt) {
if (err) {
callback(err);
}
return callback(null, salt.toString('base64'));
});
},
/**
* Encrypt password
*
* @param {String} password
* @return {String}
* @api public
*/
encryptPassword: function(password, callback) {
if (!password || !this.salt) {
if (!callback) {
return null;
}
return callback(null);
}
var defaultIterations = 10000;
var defaultKeyLength = 64;
var salt = new Buffer(this.salt, 'base64');
if (!callback) {
return crypto.pbkdf2Sync(password, salt, defaultIterations, defaultKeyLength)
.toString('base64');
}
return crypto.pbkdf2(password, salt, defaultIterations, defaultKeyLength,
function(err, key) {
if (err) {
callback(err);
}
return callback(null, key.toString('base64'));
});
},
updatePassword: function(fn) {
// Handle new/update passwords
if (this.password) {
if (!validatePresenceOf(this.password)) {
fn(new Error('Invalid password'));
}
// Make salt with a callback
var _this = this;
this.makeSalt(function(saltErr, salt) {
if (saltErr) {
fn(saltErr);
}
_this.salt = salt;
_this.encryptPassword(_this.password, function(encryptErr, hashedPassword) {
if (encryptErr) {
fn(encryptErr);
}
_this.password = hashedPassword;
fn(null);
});
});
} else {
fn(null);
}
}
}
});
return User;
}