spee.ch/task-scripts/update-password.js

45 lines
1.1 KiB
JavaScript
Raw Normal View History

2017-12-12 09:21:20 -08:00
// load dependencies
const logger = require('winston');
2018-03-09 11:20:13 -08:00
const db = require('../models');
2017-12-12 10:51:29 -08:00
// configure logging
2018-03-09 11:20:13 -08:00
require('../helpers/configureLogger.js')(logger);
2017-12-12 09:21:20 -08:00
const userName = process.argv[2];
logger.debug('user name:', userName);
const oldPassword = process.argv[3];
logger.debug('old password:', oldPassword);
const newPassword = process.argv[4];
logger.debug('new password:', newPassword);
db.sequelize.sync() // sync sequelize
.then(() => {
logger.info('finding user profile');
return db.User.findOne({
where: {
userName: userName,
},
});
})
.then(user => {
if (!user) {
throw new Error('no user found');
}
return Promise.all([
user.comparePassword(oldPassword),
user,
]);
})
.then(([isMatch, user]) => {
if (!isMatch) {
throw new Error('Incorrect old password.');
}
logger.debug('Password was a match, updating password');
return user.changePassword(newPassword);
2017-12-12 09:21:20 -08:00
})
.then(() => {
logger.debug('Password successfully updated');
})
.catch((error) => {
2017-12-12 10:51:29 -08:00
logger.error(error);
2017-12-12 09:21:20 -08:00
});