spee.ch/models/user.js

91 lines
2.5 KiB
JavaScript
Raw Normal View History

'use strict';
const bcrypt = require('bcrypt');
const logger = require('winston');
2017-09-16 17:50:22 -07:00
module.exports = (sequelize, { STRING }) => {
2017-09-15 14:41:47 -07:00
const User = sequelize.define(
2017-09-16 17:50:22 -07:00
'User',
2017-09-15 14:41:47 -07:00
{
2017-09-25 20:30:45 -07:00
userName: {
2017-09-15 14:41:47 -07:00
type : STRING,
allowNull: false,
},
password: {
type : STRING,
allowNull: false,
},
},
{
freezeTableName: true,
}
2017-09-18 10:14:06 -07:00
);
2017-09-15 14:41:47 -07:00
User.associate = db => {
2017-09-25 22:49:27 -07:00
User.hasOne(db.Channel);
2017-09-15 14:41:47 -07:00
};
User.prototype.comparePassword = function (password, callback) {
bcrypt.compare(password, this.password, callback);
2017-09-18 10:14:06 -07:00
};
2017-11-30 14:46:32 -08:00
User.prototype.changePassword = function (newPassword) {
return new Promise((resolve, reject) => {
// generate a salt string to use for hashing
bcrypt.genSalt((saltError, salt) => {
if (saltError) {
logger.error('salt error', saltError);
reject(saltError);
return;
}
// generate a hashed version of the user's password
bcrypt.hash(newPassword, salt, (hashError, hash) => {
// if there is an error with the hash generation return the error
if (hashError) {
logger.error('hash error', hashError);
reject(hashError);
return;
}
// replace the current password with the new hash
this
.update({password: hash})
.then(() => {
resolve();
})
.catch(error => {
reject(error);
});
});
});
});
};
// pre-save hook method to hash the user's password before the user's info is saved to the db.
User.hook('beforeCreate', (user, options) => {
2017-11-30 14:46:32 -08:00
logger.debug('User.beforeCreate hook...');
return new Promise((resolve, reject) => {
// generate a salt string to use for hashing
bcrypt.genSalt((saltError, salt) => {
if (saltError) {
logger.error('salt error', saltError);
reject(saltError);
return;
}
// generate a hashed version of the user's password
bcrypt.hash(user.password, salt, (hashError, hash) => {
// if there is an error with the hash generation return the error
if (hashError) {
logger.error('hash error', hashError);
reject(hashError);
return;
}
// replace the password string with the hash password value
user.password = hash;
resolve();
});
});
});
});
2017-09-15 14:41:47 -07:00
return User;
};