2018-06-02 21:48:23 +02:00
|
|
|
var should = require('should'),
|
2017-03-21 08:24:11 +00:00
|
|
|
uuid = require('uuid'),
|
2020-03-30 16:26:47 +01:00
|
|
|
security = require('../../../../core/server/lib/security');
|
2016-10-13 14:54:44 +02:00
|
|
|
|
|
|
|
describe('Utils: tokens', function () {
|
|
|
|
it('generate', function () {
|
|
|
|
var expires = Date.now() + 60 * 1000,
|
|
|
|
dbHash = uuid.v4(), token;
|
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
token = security.tokens.resetToken.generateHash({
|
2016-10-13 14:54:44 +02:00
|
|
|
email: 'test1@ghost.org',
|
|
|
|
expires: expires,
|
2016-11-07 12:18:50 +01:00
|
|
|
password: 'password',
|
2016-10-13 14:54:44 +02:00
|
|
|
dbHash: dbHash
|
|
|
|
});
|
|
|
|
|
|
|
|
should.exist(token);
|
|
|
|
token.length.should.be.above(0);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('compare: success', function () {
|
|
|
|
var expires = Date.now() + 60 * 1000,
|
|
|
|
dbHash = uuid.v4(), token, tokenIsCorrect;
|
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
token = security.tokens.resetToken.generateHash({
|
2016-10-13 14:54:44 +02:00
|
|
|
email: 'test1@ghost.org',
|
|
|
|
expires: expires,
|
|
|
|
password: '12345678',
|
|
|
|
dbHash: dbHash
|
|
|
|
});
|
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
tokenIsCorrect = security.tokens.resetToken.compare({
|
2016-10-13 14:54:44 +02:00
|
|
|
token: token,
|
|
|
|
dbHash: dbHash,
|
|
|
|
password: '12345678'
|
|
|
|
});
|
|
|
|
|
|
|
|
tokenIsCorrect.should.eql(true);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('compare: error', function () {
|
|
|
|
var expires = Date.now() + 60 * 1000,
|
|
|
|
dbHash = uuid.v4(), token, tokenIsCorrect;
|
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
token = security.tokens.resetToken.generateHash({
|
2016-10-13 14:54:44 +02:00
|
|
|
email: 'test1@ghost.org',
|
|
|
|
expires: expires,
|
|
|
|
password: '12345678',
|
|
|
|
dbHash: dbHash
|
|
|
|
});
|
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
tokenIsCorrect = security.tokens.resetToken.compare({
|
2016-10-13 14:54:44 +02:00
|
|
|
token: token,
|
|
|
|
dbHash: dbHash,
|
|
|
|
password: '123456'
|
|
|
|
});
|
|
|
|
|
|
|
|
tokenIsCorrect.should.eql(false);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('extract', function () {
|
|
|
|
var expires = Date.now() + 60 * 1000,
|
|
|
|
dbHash = uuid.v4(), token, parts, email = 'test1@ghost.org';
|
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
token = security.tokens.resetToken.generateHash({
|
2016-10-13 14:54:44 +02:00
|
|
|
email: email,
|
|
|
|
expires: expires,
|
|
|
|
password: '12345678',
|
|
|
|
dbHash: dbHash
|
|
|
|
});
|
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
parts = security.tokens.resetToken.extract({
|
2016-10-13 14:54:44 +02:00
|
|
|
token: token
|
|
|
|
});
|
|
|
|
|
|
|
|
parts.email.should.eql(email);
|
|
|
|
parts.expires.should.eql(expires);
|
|
|
|
should.not.exist(parts.password);
|
|
|
|
should.not.exist(parts.dbHash);
|
|
|
|
});
|
|
|
|
|
2016-11-07 12:18:50 +01:00
|
|
|
it('extract', function () {
|
|
|
|
var expires = Date.now() + 60 * 1000,
|
|
|
|
dbHash = uuid.v4(), token, parts, email = 'test3@ghost.org';
|
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
token = security.tokens.resetToken.generateHash({
|
2016-11-07 12:18:50 +01:00
|
|
|
email: email,
|
|
|
|
expires: expires,
|
|
|
|
password: '$2a$10$t5dY1uRRdjvqfNlXhae3uuc0nuhi.Rd7/K/9JaHHwSkLm6UUa3NsW',
|
|
|
|
dbHash: dbHash
|
|
|
|
});
|
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
parts = security.tokens.resetToken.extract({
|
2016-11-07 12:18:50 +01:00
|
|
|
token: token
|
|
|
|
});
|
|
|
|
|
|
|
|
parts.email.should.eql(email);
|
|
|
|
parts.expires.should.eql(expires);
|
|
|
|
should.not.exist(parts.password);
|
|
|
|
should.not.exist(parts.dbHash);
|
|
|
|
});
|
|
|
|
|
2016-10-13 14:54:44 +02:00
|
|
|
it('can validate an URI encoded reset token', function () {
|
|
|
|
var expires = Date.now() + 60 * 1000,
|
2016-11-07 12:18:50 +01:00
|
|
|
email = 'test1@ghost.org',
|
|
|
|
dbHash = uuid.v4(), token, tokenIsCorrect, parts;
|
2016-10-13 14:54:44 +02:00
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
token = security.tokens.resetToken.generateHash({
|
2016-11-07 12:18:50 +01:00
|
|
|
email: email,
|
2016-10-13 14:54:44 +02:00
|
|
|
expires: expires,
|
|
|
|
password: '12345678',
|
|
|
|
dbHash: dbHash
|
|
|
|
});
|
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
token = security.url.encodeBase64(token);
|
2016-10-13 14:54:44 +02:00
|
|
|
token = encodeURIComponent(token);
|
|
|
|
token = decodeURIComponent(token);
|
2017-12-14 13:26:48 +01:00
|
|
|
token = security.url.decodeBase64(token);
|
2016-10-13 14:54:44 +02:00
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
parts = security.tokens.resetToken.extract({
|
2016-11-07 12:18:50 +01:00
|
|
|
token: token
|
|
|
|
});
|
|
|
|
|
|
|
|
parts.email.should.eql(email);
|
|
|
|
parts.expires.should.eql(expires);
|
|
|
|
|
2017-12-14 13:26:48 +01:00
|
|
|
tokenIsCorrect = security.tokens.resetToken.compare({
|
2016-10-13 14:54:44 +02:00
|
|
|
token: token,
|
|
|
|
dbHash: dbHash,
|
|
|
|
password: '12345678'
|
|
|
|
});
|
|
|
|
|
|
|
|
tokenIsCorrect.should.eql(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|