2020-08-18 20:39:57 +03:00
|
|
|
import { salt1, salt2, g, p, srp_id, secure_random, srp_B, password, A, M1, passwordHashed } from '../mock/srp';
|
2020-08-18 21:31:30 +03:00
|
|
|
import { computeSRP, makePasswordHash } from '../lib/crypto/srp';
|
2020-08-18 20:39:57 +03:00
|
|
|
|
|
|
|
test('2FA hash', async() => {
|
|
|
|
const bytes = await makePasswordHash(password, salt1, salt2);
|
|
|
|
expect(bytes).toEqual(passwordHashed);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('2FA whole (with negative)', async() => {
|
2020-08-18 21:31:30 +03:00
|
|
|
return await computeSRP(password, {
|
2020-09-17 22:33:23 +03:00
|
|
|
_: 'account.password',
|
2020-08-18 20:39:57 +03:00
|
|
|
current_algo: {
|
2020-09-17 22:33:23 +03:00
|
|
|
_: 'passwordKdfAlgoSHA256SHA256PBKDF2HMACSHA512iter100000SHA256ModPow',
|
2020-08-18 20:39:57 +03:00
|
|
|
salt1,
|
|
|
|
salt2,
|
|
|
|
p,
|
|
|
|
g
|
|
|
|
},
|
|
|
|
srp_id,
|
|
|
|
srp_B,
|
2020-09-17 22:33:23 +03:00
|
|
|
secure_random,
|
|
|
|
|
|
|
|
new_algo: null,
|
|
|
|
new_secure_algo: null
|
2021-02-21 17:22:59 +04:00
|
|
|
}, false).then((res: any) => {
|
2020-08-18 20:39:57 +03:00
|
|
|
expect(res.srp_id).toEqual(srp_id);
|
|
|
|
expect(res.A).toEqual(A);
|
|
|
|
expect(res.M1).toEqual(M1);
|
|
|
|
|
|
|
|
return res;
|
|
|
|
}).catch(err => {
|
|
|
|
throw err;
|
|
|
|
});
|
|
|
|
});
|