tweb/src/lib/crypto/computeDhKey.ts
2022-08-09 17:35:11 +02:00

18 lines
733 B
TypeScript

/*
* https://github.com/morethanwords/tweb
* Copyright (C) 2019-2021 Eduard Kuzmenko
* https://github.com/morethanwords/tweb/blob/master/LICENSE
*/
import {bigIntFromBytes, bigIntToSigned} from '../../helpers/bigInt/bigIntConversion';
import cryptoWorker from './cryptoMessagePort';
export default async function computeDhKey(g_b: Uint8Array, a: Uint8Array, p: Uint8Array) {
const key = await cryptoWorker.invokeCrypto('mod-pow', g_b, a, p);
const keySha1Hashed = await cryptoWorker.invokeCrypto('sha1', key);
const key_fingerprint = keySha1Hashed.slice(-8).reverse();
const key_fingerprint_long = bigIntToSigned(bigIntFromBytes(key_fingerprint)).toString(10);
return {key, key_fingerprint: key_fingerprint_long};
}