You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
nodebb/src/user/password.js

48 lines
1.1 KiB
JavaScript

'use strict';
const nconf = require('nconf');
const db = require('../database');
const Password = require('../password');
module.exports = function (User) {
User.hashPassword = async function (password) {
if (!password) {
return password;
}
return await Password.hash(nconf.get('bcrypt_rounds') || 12, password);
};
User.isPasswordCorrect = async function (uid, password, ip) {
password = password || '';
let {
password: hashedPassword,
'password:shaWrapped': shaWrapped,
} = await db.getObjectFields(`user:${uid}`, ['password', 'password:shaWrapped']);
if (!hashedPassword) {
// Non-existant user, submit fake hash for comparison
hashedPassword = '';
}
try {
User.isPasswordValid(password, 0);
} catch (e) {
return false;
}
await User.auth.logAttempt(uid, ip);
const ok = await Password.compare(password, hashedPassword, !!parseInt(shaWrapped, 10));
if (ok) {
await User.auth.clearLoginAttempts(uid);
}
return ok;
};
User.hasPassword = async function (uid) {
const hashedPassword = await db.getObjectField(`user:${uid}`, 'password');
return !!hashedPassword;
};
};