Merge pull request #3556 from STRML/fix/validatePassword
fix(validatePassword): Reword password too long error.
This commit is contained in:
commit
bc8778908e
|
@ -16,6 +16,8 @@ var path = require('path');
|
|||
var qs = require('querystring');
|
||||
var SALT_WORK_FACTOR = 10;
|
||||
var crypto = require('crypto');
|
||||
// bcrypt's max length is 72 bytes;
|
||||
// See https://github.com/kelektiv/node.bcrypt.js/blob/45f498ef6dc6e8234e58e07834ce06a50ff16352/src/node_blf.h#L59
|
||||
var MAX_PASSWORD_LENGTH = 72;
|
||||
var bcrypt;
|
||||
try {
|
||||
|
@ -993,18 +995,22 @@ module.exports = function(User) {
|
|||
|
||||
User.validatePassword = function(plain) {
|
||||
var err;
|
||||
if (plain && typeof plain === 'string' && plain.length <= MAX_PASSWORD_LENGTH) {
|
||||
return true;
|
||||
}
|
||||
if (plain.length > MAX_PASSWORD_LENGTH) {
|
||||
err = new Error(g.f('Password too long: %s', plain));
|
||||
err.code = 'PASSWORD_TOO_LONG';
|
||||
} else {
|
||||
err = new Error(g.f('Invalid password: %s', plain));
|
||||
if (!plain || typeof plain !== 'string') {
|
||||
err = new Error(g.f('Invalid password.'));
|
||||
err.code = 'INVALID_PASSWORD';
|
||||
err.statusCode = 422;
|
||||
throw err;
|
||||
}
|
||||
|
||||
// Bcrypt only supports up to 72 bytes; the rest is silently dropped.
|
||||
var len = Buffer.byteLength(plain, 'utf8');
|
||||
if (len > MAX_PASSWORD_LENGTH) {
|
||||
err = new Error(g.f('The password entered was too long. Max length is %d (entered %d)',
|
||||
MAX_PASSWORD_LENGTH, len));
|
||||
err.code = 'PASSWORD_TOO_LONG';
|
||||
err.statusCode = 422;
|
||||
throw err;
|
||||
}
|
||||
err.statusCode = 422;
|
||||
throw err;
|
||||
};
|
||||
|
||||
User._invalidateAccessTokensOfUsers = function(userIds, options, cb) {
|
||||
|
|
|
@ -430,7 +430,7 @@ describe('User', function() {
|
|||
var u = new User({username: 'foo', password: pass73Char});
|
||||
assert(false, 'Error should have been thrown');
|
||||
} catch (e) {
|
||||
expect(e).to.match(/Password too long/);
|
||||
expect(e).to.match(/password entered was too long/);
|
||||
done();
|
||||
}
|
||||
});
|
||||
|
@ -462,7 +462,7 @@ describe('User', function() {
|
|||
if (err) return done(err);
|
||||
User.resetPassword({email: 'b@c.com', password: pass73Char}, function(err) {
|
||||
assert(err);
|
||||
expect(err).to.match(/Password too long/);
|
||||
expect(err).to.match(/password entered was too long/);
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
@ -474,7 +474,7 @@ describe('User', function() {
|
|||
.then(
|
||||
success => { throw new Error('changePassword should have failed'); },
|
||||
err => {
|
||||
expect(err.message).to.match(/Password too long/);
|
||||
expect(err.message).to.match(/password entered was too long/);
|
||||
|
||||
// workaround for chai problem
|
||||
// object tested must be an array, an object, or a string,
|
||||
|
@ -493,7 +493,7 @@ describe('User', function() {
|
|||
.then(
|
||||
success => { throw new Error('setPassword should have failed'); },
|
||||
err => {
|
||||
expect(err.message).to.match(/Password too long/);
|
||||
expect(err.message).to.match(/password entered was too long/);
|
||||
|
||||
// workaround for chai problem
|
||||
// object tested must be an array, an object, or a string,
|
||||
|
|
Loading…
Reference in New Issue