@bitgo-beta/sdk-lib-mpc 8.2.1-alpha.6 → 8.2.1-alpha.61
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +447 -0
- package/dist/src/curves/constant.d.ts +2 -0
- package/dist/src/curves/constant.d.ts.map +1 -0
- package/dist/src/curves/constant.js +6 -0
- package/dist/src/curves/{baseCurve.d.ts → ed25519.d.ts} +9 -7
- package/dist/src/curves/ed25519.d.ts.map +1 -0
- package/dist/src/curves/ed25519.js +72 -0
- package/dist/src/curves/ed25519Bip32HdTree.d.ts +10 -0
- package/dist/src/curves/ed25519Bip32HdTree.d.ts.map +1 -0
- package/dist/src/curves/ed25519Bip32HdTree.js +85 -0
- package/dist/src/curves/index.d.ts +6 -1
- package/dist/src/curves/index.d.ts.map +1 -1
- package/dist/src/curves/index.js +7 -2
- package/dist/src/curves/secp256k1.d.ts +3 -1
- package/dist/src/curves/secp256k1.d.ts.map +1 -1
- package/dist/src/curves/secp256k1.js +14 -7
- package/dist/src/curves/secp256k1Bip32HdTree.d.ts +8 -0
- package/dist/src/curves/secp256k1Bip32HdTree.d.ts.map +1 -0
- package/dist/src/curves/secp256k1Bip32HdTree.js +54 -0
- package/dist/src/curves/types.d.ts +36 -0
- package/dist/src/curves/types.d.ts.map +1 -0
- package/dist/src/curves/types.js +3 -0
- package/dist/src/curves/util.d.ts +2 -0
- package/dist/src/curves/util.d.ts.map +1 -0
- package/dist/src/curves/util.js +11 -0
- package/dist/src/hashCommitment.d.ts +17 -0
- package/dist/src/hashCommitment.d.ts.map +1 -0
- package/dist/src/hashCommitment.js +45 -0
- package/dist/src/index.d.ts +6 -2
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +20 -3
- package/dist/src/schnorrProof.d.ts +22 -0
- package/dist/src/schnorrProof.d.ts.map +1 -0
- package/dist/src/schnorrProof.js +62 -0
- package/dist/src/shamir/index.d.ts +3 -0
- package/dist/src/shamir/index.d.ts.map +1 -0
- package/dist/src/shamir/index.js +15 -0
- package/dist/src/shamir/shamir.d.ts +38 -0
- package/dist/src/shamir/shamir.d.ts.map +1 -0
- package/dist/src/shamir/shamir.js +136 -0
- package/dist/src/shamir/types.d.ts +5 -0
- package/dist/src/shamir/types.d.ts.map +1 -0
- package/dist/src/shamir/types.js +3 -0
- package/dist/src/tss/ecdsa/index.d.ts +1 -0
- package/dist/src/tss/ecdsa/index.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/index.js +3 -2
- package/dist/src/tss/ecdsa/rangeproof.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/rangeproof.js +4 -1
- package/dist/src/tss/ecdsa/types.d.ts +6 -1
- package/dist/src/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/types.js +1 -1
- package/dist/src/tss/ecdsa/zkVProof.d.ts +25 -0
- package/dist/src/tss/ecdsa/zkVProof.d.ts.map +1 -0
- package/dist/src/tss/ecdsa/zkVProof.js +71 -0
- package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts +43 -0
- package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/commsLayer.js +212 -0
- package/dist/src/tss/ecdsa-dkls/dkg.d.ts +20 -0
- package/dist/src/tss/ecdsa-dkls/dkg.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/dkg.js +153 -0
- package/dist/src/tss/ecdsa-dkls/dsg.d.ts +30 -0
- package/dist/src/tss/ecdsa-dkls/dsg.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/dsg.js +169 -0
- package/dist/src/tss/ecdsa-dkls/index.d.ts +4 -0
- package/dist/src/tss/ecdsa-dkls/index.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/index.js +26 -0
- package/dist/src/tss/ecdsa-dkls/types.d.ts +74 -0
- package/dist/src/tss/ecdsa-dkls/types.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/types.js +70 -0
- package/dist/src/tss/index.d.ts +1 -0
- package/dist/src/tss/index.d.ts.map +1 -1
- package/dist/src/tss/index.js +2 -1
- package/dist/src/types.d.ts +14 -0
- package/dist/src/types.d.ts.map +1 -0
- package/dist/src/types.js +3 -0
- package/dist/src/util.d.ts +8 -2
- package/dist/src/util.d.ts.map +1 -1
- package/dist/src/util.js +30 -8
- package/dist/tsconfig.tsbuildinfo +1 -3645
- package/package.json +9 -4
- package/dist/src/curves/baseCurve.d.ts.map +0 -1
- package/dist/src/curves/baseCurve.js +0 -6
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { BaseCurve as Curve } from '../../curves';
|
|
3
|
+
import { ZkVProof } from './types';
|
|
4
|
+
/**
|
|
5
|
+
* Create a ZK Proof of knowledge of the s and l that are behind the public value V = sR + lG.
|
|
6
|
+
* @param V The curve point V.
|
|
7
|
+
* @param s The s that multiplies R.
|
|
8
|
+
* @param l The l that multiplies the curve genreator G.
|
|
9
|
+
* @param R The curve point R shared by all participants.
|
|
10
|
+
* @param curve The elliptic curve.
|
|
11
|
+
* @param additionalCtx Additional contextual information to associate with the proof.
|
|
12
|
+
* @returns The created proof.
|
|
13
|
+
*/
|
|
14
|
+
export declare function createZkVProof(V: bigint, s: bigint, l: bigint, R: bigint, curve: Curve, additionalCtx?: Buffer): ZkVProof;
|
|
15
|
+
/**
|
|
16
|
+
* Verify a ZK Proof of knowledge of the s and l that are behind the public value V = sR + lG.
|
|
17
|
+
* @param V The curve point V.
|
|
18
|
+
* @param proof The ZK proof.
|
|
19
|
+
* @param R The curve point R shared by all participants.
|
|
20
|
+
* @param curve The elliptic curve.
|
|
21
|
+
* @param additionalCtx Additional contextual information that is supposed to associate with the proof.
|
|
22
|
+
* @returns True if the proof checks out.
|
|
23
|
+
*/
|
|
24
|
+
export declare function verifyZkVProof(V: bigint, proof: ZkVProof, R: bigint, curve: Curve, additionalCtx?: Buffer): boolean;
|
|
25
|
+
//# sourceMappingURL=zkVProof.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"zkVProof.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa/zkVProof.ts"],"names":[],"mappings":";AAMA,OAAO,EAAE,SAAS,IAAI,KAAK,EAAE,MAAM,cAAc,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAGnC;;;;;;;;;GASG;AACH,wBAAgB,cAAc,CAC5B,CAAC,EAAE,MAAM,EACT,CAAC,EAAE,MAAM,EACT,CAAC,EAAE,MAAM,EACT,CAAC,EAAE,MAAM,EACT,KAAK,EAAE,KAAK,EACZ,aAAa,GAAE,MAAwB,GACtC,QAAQ,CAeV;AAyBD;;;;;;;;GAQG;AACH,wBAAgB,cAAc,CAC5B,CAAC,EAAE,MAAM,EACT,KAAK,EAAE,QAAQ,EACf,CAAC,EAAE,MAAM,EACT,KAAK,EAAE,KAAK,EACZ,aAAa,GAAE,MAAwB,GACtC,OAAO,CAOT"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.verifyZkVProof = exports.createZkVProof = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Zero Knowledge Proof of knowledge of the s and l that are behind the public value V = sR + lG.
|
|
6
|
+
* The V value is calculated in step 5A and the proof is created in step 5B of the GG18 signing protocol.
|
|
7
|
+
* @see {@link https://eprint.iacr.org/2019/114.pdf} section 4.3 for reference.
|
|
8
|
+
*/
|
|
9
|
+
const crypto_1 = require("crypto");
|
|
10
|
+
const util_1 = require("../../util");
|
|
11
|
+
/**
|
|
12
|
+
* Create a ZK Proof of knowledge of the s and l that are behind the public value V = sR + lG.
|
|
13
|
+
* @param V The curve point V.
|
|
14
|
+
* @param s The s that multiplies R.
|
|
15
|
+
* @param l The l that multiplies the curve genreator G.
|
|
16
|
+
* @param R The curve point R shared by all participants.
|
|
17
|
+
* @param curve The elliptic curve.
|
|
18
|
+
* @param additionalCtx Additional contextual information to associate with the proof.
|
|
19
|
+
* @returns The created proof.
|
|
20
|
+
*/
|
|
21
|
+
function createZkVProof(V, s, l, R, curve, additionalCtx = Buffer.from('')) {
|
|
22
|
+
const a = curve.scalarRandom();
|
|
23
|
+
const b = curve.scalarRandom();
|
|
24
|
+
const Alpha = curve.pointAdd(curve.pointMultiply(R, a), curve.basePointMult(b));
|
|
25
|
+
const c = nonInteractiveChallenge(V, R, Alpha, curve, additionalCtx);
|
|
26
|
+
const t = curve.scalarAdd(a, curve.scalarMult(c, s));
|
|
27
|
+
const u = curve.scalarAdd(b, curve.scalarMult(c, l));
|
|
28
|
+
return {
|
|
29
|
+
Alpha: Alpha,
|
|
30
|
+
t: t,
|
|
31
|
+
u: u,
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
exports.createZkVProof = createZkVProof;
|
|
35
|
+
/**
|
|
36
|
+
* Calculate challenge for NIZK proof of V using Fiat-Shamir transform.
|
|
37
|
+
*
|
|
38
|
+
* @param V The point to be proven.
|
|
39
|
+
* @param R The point R shared by all participants in the ECDSA signing protocol.
|
|
40
|
+
* @param Alpha The point/public value corresponding to the random scalar values a and b chosen by the prover.
|
|
41
|
+
* @param curve The elliptic curve.
|
|
42
|
+
* @param additionalCtx Additional contextual information to associate with the proof.
|
|
43
|
+
* @returns The calculated challenge.
|
|
44
|
+
*/
|
|
45
|
+
function nonInteractiveChallenge(V, R, Alpha, curve, additionalCtx) {
|
|
46
|
+
const G = curve.basePointMult(BigInt(1));
|
|
47
|
+
const hash = crypto_1.createHash('sha256');
|
|
48
|
+
hash.update(util_1.bigIntToBufferBE(G, curve.pointBytes));
|
|
49
|
+
hash.update(util_1.bigIntToBufferBE(R, curve.pointBytes));
|
|
50
|
+
hash.update(util_1.bigIntToBufferBE(V, curve.pointBytes));
|
|
51
|
+
hash.update(util_1.bigIntToBufferBE(Alpha, curve.pointBytes));
|
|
52
|
+
hash.update(additionalCtx);
|
|
53
|
+
return util_1.bigIntFromBufferBE(hash.digest());
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Verify a ZK Proof of knowledge of the s and l that are behind the public value V = sR + lG.
|
|
57
|
+
* @param V The curve point V.
|
|
58
|
+
* @param proof The ZK proof.
|
|
59
|
+
* @param R The curve point R shared by all participants.
|
|
60
|
+
* @param curve The elliptic curve.
|
|
61
|
+
* @param additionalCtx Additional contextual information that is supposed to associate with the proof.
|
|
62
|
+
* @returns True if the proof checks out.
|
|
63
|
+
*/
|
|
64
|
+
function verifyZkVProof(V, proof, R, curve, additionalCtx = Buffer.from('')) {
|
|
65
|
+
const c = nonInteractiveChallenge(V, R, proof.Alpha, curve, additionalCtx);
|
|
66
|
+
const lhs = curve.pointAdd(curve.pointMultiply(R, proof.t), curve.basePointMult(proof.u));
|
|
67
|
+
const rhs = curve.pointAdd(proof.Alpha, curve.pointMultiply(V, curve.scalarReduce(c)));
|
|
68
|
+
return lhs === rhs;
|
|
69
|
+
}
|
|
70
|
+
exports.verifyZkVProof = verifyZkVProof;
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiemtWUHJvb2YuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHNzL2VjZHNhL3prVlByb29mLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOzs7O0dBSUc7QUFDSCxtQ0FBb0M7QUFHcEMscUNBQWtFO0FBRWxFOzs7Ozs7Ozs7R0FTRztBQUNILFNBQWdCLGNBQWMsQ0FDNUIsQ0FBUyxFQUNULENBQVMsRUFDVCxDQUFTLEVBQ1QsQ0FBUyxFQUNULEtBQVksRUFDWixnQkFBd0IsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7SUFFdkMsTUFBTSxDQUFDLEdBQUcsS0FBSyxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQy9CLE1BQU0sQ0FBQyxHQUFHLEtBQUssQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUMvQixNQUFNLEtBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxhQUFhLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUVoRixNQUFNLENBQUMsR0FBRyx1QkFBdUIsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFFckUsTUFBTSxDQUFDLEdBQUcsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNyRCxNQUFNLENBQUMsR0FBRyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRXJELE9BQU87UUFDTCxLQUFLLEVBQUUsS0FBSztRQUNaLENBQUMsRUFBRSxDQUFDO1FBQ0osQ0FBQyxFQUFFLENBQUM7S0FDTCxDQUFDO0FBQ0osQ0FBQztBQXRCRCx3Q0FzQkM7QUFFRDs7Ozs7Ozs7O0dBU0c7QUFDSCxTQUFTLHVCQUF1QixDQUFDLENBQVMsRUFBRSxDQUFTLEVBQUUsS0FBYSxFQUFFLEtBQVksRUFBRSxhQUFxQjtJQUN2RyxNQUFNLENBQUMsR0FBRyxLQUFLLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRXpDLE1BQU0sSUFBSSxHQUFHLG1CQUFVLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDbEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyx1QkFBZ0IsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7SUFDbkQsSUFBSSxDQUFDLE1BQU0sQ0FBQyx1QkFBZ0IsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7SUFDbkQsSUFBSSxDQUFDLE1BQU0sQ0FBQyx1QkFBZ0IsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7SUFDbkQsSUFBSSxDQUFDLE1BQU0sQ0FBQyx1QkFBZ0IsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7SUFDdkQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUUzQixPQUFPLHlCQUFrQixDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDO0FBQzNDLENBQUM7QUFFRDs7Ozs7Ozs7R0FRRztBQUNILFNBQWdCLGNBQWMsQ0FDNUIsQ0FBUyxFQUNULEtBQWUsRUFDZixDQUFTLEVBQ1QsS0FBWSxFQUNaLGdCQUF3QixNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztJQUV2QyxNQUFNLENBQUMsR0FBRyx1QkFBdUIsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEtBQUssQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLGFBQWEsQ0FBQyxDQUFDO0lBRTNFLE1BQU0sR0FBRyxHQUFHLEtBQUssQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDMUYsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxhQUFhLENBQUMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRXZGLE9BQU8sR0FBRyxLQUFLLEdBQUcsQ0FBQztBQUNyQixDQUFDO0FBYkQsd0NBYUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFplcm8gS25vd2xlZGdlIFByb29mIG9mIGtub3dsZWRnZSBvZiB0aGUgcyBhbmQgbCB0aGF0IGFyZSBiZWhpbmQgdGhlIHB1YmxpYyB2YWx1ZSBWID0gc1IgKyBsRy5cbiAqIFRoZSBWIHZhbHVlIGlzIGNhbGN1bGF0ZWQgaW4gc3RlcCA1QSBhbmQgdGhlIHByb29mIGlzIGNyZWF0ZWQgaW4gc3RlcCA1QiBvZiB0aGUgR0cxOCBzaWduaW5nIHByb3RvY29sLlxuICogQHNlZSB7QGxpbmsgaHR0cHM6Ly9lcHJpbnQuaWFjci5vcmcvMjAxOS8xMTQucGRmfSBzZWN0aW9uIDQuMyBmb3IgcmVmZXJlbmNlLlxuICovXG5pbXBvcnQgeyBjcmVhdGVIYXNoIH0gZnJvbSAnY3J5cHRvJztcbmltcG9ydCB7IEJhc2VDdXJ2ZSBhcyBDdXJ2ZSB9IGZyb20gJy4uLy4uL2N1cnZlcyc7XG5pbXBvcnQgeyBaa1ZQcm9vZiB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgYmlnSW50RnJvbUJ1ZmZlckJFLCBiaWdJbnRUb0J1ZmZlckJFIH0gZnJvbSAnLi4vLi4vdXRpbCc7XG5cbi8qKlxuICogQ3JlYXRlIGEgWksgUHJvb2Ygb2Yga25vd2xlZGdlIG9mIHRoZSBzIGFuZCBsIHRoYXQgYXJlIGJlaGluZCB0aGUgcHVibGljIHZhbHVlIFYgPSBzUiArIGxHLlxuICogQHBhcmFtIFYgVGhlIGN1cnZlIHBvaW50IFYuXG4gKiBAcGFyYW0gcyBUaGUgcyB0aGF0IG11bHRpcGxpZXMgUi5cbiAqIEBwYXJhbSBsIFRoZSBsIHRoYXQgbXVsdGlwbGllcyB0aGUgY3VydmUgZ2VucmVhdG9yIEcuXG4gKiBAcGFyYW0gUiBUaGUgY3VydmUgcG9pbnQgUiBzaGFyZWQgYnkgYWxsIHBhcnRpY2lwYW50cy5cbiAqIEBwYXJhbSBjdXJ2ZSBUaGUgZWxsaXB0aWMgY3VydmUuXG4gKiBAcGFyYW0gYWRkaXRpb25hbEN0eCBBZGRpdGlvbmFsIGNvbnRleHR1YWwgaW5mb3JtYXRpb24gdG8gYXNzb2NpYXRlIHdpdGggdGhlIHByb29mLlxuICogQHJldHVybnMgVGhlIGNyZWF0ZWQgcHJvb2YuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVaa1ZQcm9vZihcbiAgVjogYmlnaW50LFxuICBzOiBiaWdpbnQsXG4gIGw6IGJpZ2ludCxcbiAgUjogYmlnaW50LFxuICBjdXJ2ZTogQ3VydmUsXG4gIGFkZGl0aW9uYWxDdHg6IEJ1ZmZlciA9IEJ1ZmZlci5mcm9tKCcnKVxuKTogWmtWUHJvb2Yge1xuICBjb25zdCBhID0gY3VydmUuc2NhbGFyUmFuZG9tKCk7XG4gIGNvbnN0IGIgPSBjdXJ2ZS5zY2FsYXJSYW5kb20oKTtcbiAgY29uc3QgQWxwaGEgPSBjdXJ2ZS5wb2ludEFkZChjdXJ2ZS5wb2ludE11bHRpcGx5KFIsIGEpLCBjdXJ2ZS5iYXNlUG9pbnRNdWx0KGIpKTtcblxuICBjb25zdCBjID0gbm9uSW50ZXJhY3RpdmVDaGFsbGVuZ2UoViwgUiwgQWxwaGEsIGN1cnZlLCBhZGRpdGlvbmFsQ3R4KTtcblxuICBjb25zdCB0ID0gY3VydmUuc2NhbGFyQWRkKGEsIGN1cnZlLnNjYWxhck11bHQoYywgcykpO1xuICBjb25zdCB1ID0gY3VydmUuc2NhbGFyQWRkKGIsIGN1cnZlLnNjYWxhck11bHQoYywgbCkpO1xuXG4gIHJldHVybiB7XG4gICAgQWxwaGE6IEFscGhhLFxuICAgIHQ6IHQsXG4gICAgdTogdSxcbiAgfTtcbn1cblxuLyoqXG4gKiBDYWxjdWxhdGUgY2hhbGxlbmdlIGZvciBOSVpLIHByb29mIG9mIFYgdXNpbmcgRmlhdC1TaGFtaXIgdHJhbnNmb3JtLlxuICpcbiAqIEBwYXJhbSBWIFRoZSBwb2ludCB0byBiZSBwcm92ZW4uXG4gKiBAcGFyYW0gUiBUaGUgcG9pbnQgUiBzaGFyZWQgYnkgYWxsIHBhcnRpY2lwYW50cyBpbiB0aGUgRUNEU0Egc2lnbmluZyBwcm90b2NvbC5cbiAqIEBwYXJhbSBBbHBoYSBUaGUgcG9pbnQvcHVibGljIHZhbHVlIGNvcnJlc3BvbmRpbmcgdG8gdGhlIHJhbmRvbSBzY2FsYXIgdmFsdWVzIGEgYW5kIGIgY2hvc2VuIGJ5IHRoZSBwcm92ZXIuXG4gKiBAcGFyYW0gY3VydmUgVGhlIGVsbGlwdGljIGN1cnZlLlxuICogQHBhcmFtIGFkZGl0aW9uYWxDdHggQWRkaXRpb25hbCBjb250ZXh0dWFsIGluZm9ybWF0aW9uIHRvIGFzc29jaWF0ZSB3aXRoIHRoZSBwcm9vZi5cbiAqIEByZXR1cm5zIFRoZSBjYWxjdWxhdGVkIGNoYWxsZW5nZS5cbiAqL1xuZnVuY3Rpb24gbm9uSW50ZXJhY3RpdmVDaGFsbGVuZ2UoVjogYmlnaW50LCBSOiBiaWdpbnQsIEFscGhhOiBiaWdpbnQsIGN1cnZlOiBDdXJ2ZSwgYWRkaXRpb25hbEN0eDogQnVmZmVyKTogYmlnaW50IHtcbiAgY29uc3QgRyA9IGN1cnZlLmJhc2VQb2ludE11bHQoQmlnSW50KDEpKTtcblxuICBjb25zdCBoYXNoID0gY3JlYXRlSGFzaCgnc2hhMjU2Jyk7XG4gIGhhc2gudXBkYXRlKGJpZ0ludFRvQnVmZmVyQkUoRywgY3VydmUucG9pbnRCeXRlcykpO1xuICBoYXNoLnVwZGF0ZShiaWdJbnRUb0J1ZmZlckJFKFIsIGN1cnZlLnBvaW50Qnl0ZXMpKTtcbiAgaGFzaC51cGRhdGUoYmlnSW50VG9CdWZmZXJCRShWLCBjdXJ2ZS5wb2ludEJ5dGVzKSk7XG4gIGhhc2gudXBkYXRlKGJpZ0ludFRvQnVmZmVyQkUoQWxwaGEsIGN1cnZlLnBvaW50Qnl0ZXMpKTtcbiAgaGFzaC51cGRhdGUoYWRkaXRpb25hbEN0eCk7XG5cbiAgcmV0dXJuIGJpZ0ludEZyb21CdWZmZXJCRShoYXNoLmRpZ2VzdCgpKTtcbn1cblxuLyoqXG4gKiBWZXJpZnkgYSBaSyBQcm9vZiBvZiBrbm93bGVkZ2Ugb2YgdGhlIHMgYW5kIGwgdGhhdCBhcmUgYmVoaW5kIHRoZSBwdWJsaWMgdmFsdWUgViA9IHNSICsgbEcuXG4gKiBAcGFyYW0gViBUaGUgY3VydmUgcG9pbnQgVi5cbiAqIEBwYXJhbSBwcm9vZiBUaGUgWksgcHJvb2YuXG4gKiBAcGFyYW0gUiBUaGUgY3VydmUgcG9pbnQgUiBzaGFyZWQgYnkgYWxsIHBhcnRpY2lwYW50cy5cbiAqIEBwYXJhbSBjdXJ2ZSBUaGUgZWxsaXB0aWMgY3VydmUuXG4gKiBAcGFyYW0gYWRkaXRpb25hbEN0eCBBZGRpdGlvbmFsIGNvbnRleHR1YWwgaW5mb3JtYXRpb24gdGhhdCBpcyBzdXBwb3NlZCB0byBhc3NvY2lhdGUgd2l0aCB0aGUgcHJvb2YuXG4gKiBAcmV0dXJucyBUcnVlIGlmIHRoZSBwcm9vZiBjaGVja3Mgb3V0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gdmVyaWZ5WmtWUHJvb2YoXG4gIFY6IGJpZ2ludCxcbiAgcHJvb2Y6IFprVlByb29mLFxuICBSOiBiaWdpbnQsXG4gIGN1cnZlOiBDdXJ2ZSxcbiAgYWRkaXRpb25hbEN0eDogQnVmZmVyID0gQnVmZmVyLmZyb20oJycpXG4pOiBib29sZWFuIHtcbiAgY29uc3QgYyA9IG5vbkludGVyYWN0aXZlQ2hhbGxlbmdlKFYsIFIsIHByb29mLkFscGhhLCBjdXJ2ZSwgYWRkaXRpb25hbEN0eCk7XG5cbiAgY29uc3QgbGhzID0gY3VydmUucG9pbnRBZGQoY3VydmUucG9pbnRNdWx0aXBseShSLCBwcm9vZi50KSwgY3VydmUuYmFzZVBvaW50TXVsdChwcm9vZi51KSk7XG4gIGNvbnN0IHJocyA9IGN1cnZlLnBvaW50QWRkKHByb29mLkFscGhhLCBjdXJ2ZS5wb2ludE11bHRpcGx5KFYsIGN1cnZlLnNjYWxhclJlZHVjZShjKSkpO1xuXG4gIHJldHVybiBsaHMgPT09IHJocztcbn1cbiJdfQ==
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { SerializedMessages, AuthEncMessage, AuthEncMessages, PartyGpgKey, AuthMessage } from './types';
|
|
3
|
+
/**
|
|
4
|
+
* Detach signs a binary and encodes it in base64
|
|
5
|
+
* @param data binary to encode in base64 and sign
|
|
6
|
+
* @param privateArmor private key to sign with
|
|
7
|
+
*/
|
|
8
|
+
export declare function detachSignData(data: Buffer, privateArmor: string): Promise<AuthMessage>;
|
|
9
|
+
/**
|
|
10
|
+
* Encrypts and detach signs a binary
|
|
11
|
+
* @param data binary to encrypt and sign
|
|
12
|
+
* @param publicArmor public key to encrypt with
|
|
13
|
+
* @param privateArmor private key to sign with
|
|
14
|
+
*/
|
|
15
|
+
export declare function encryptAndDetachSignData(data: Buffer, publicArmor: string, privateArmor: string): Promise<AuthEncMessage>;
|
|
16
|
+
/**
|
|
17
|
+
* Decrypts and verifies signature on a binary
|
|
18
|
+
* @param encryptedAndSignedMessage message to decrypt and verify
|
|
19
|
+
* @param publicArmor public key to verify signature with
|
|
20
|
+
* @param privateArmor private key to decrypt with
|
|
21
|
+
*/
|
|
22
|
+
export declare function decryptAndVerifySignedData(encryptedAndSignedMessage: AuthEncMessage, publicArmor: string, privateArmor: string): Promise<string>;
|
|
23
|
+
/**
|
|
24
|
+
* Verifies signature on a binary (message passed should be encoded in base64).
|
|
25
|
+
* @param signedMessage message to verify
|
|
26
|
+
* @param publicArmor public key to verify signature with
|
|
27
|
+
*/
|
|
28
|
+
export declare function verifySignedData(signedMessage: AuthMessage, publicArmor: string): Promise<boolean>;
|
|
29
|
+
/**
|
|
30
|
+
* Decrypts and verifies p2p messages + verifies broadcast messages
|
|
31
|
+
* @param messages message to decrypt and verify
|
|
32
|
+
* @param pubVerificationGpgKeys public keys to verify signatures with
|
|
33
|
+
* @param prvDecryptionGpgKeys private keys to decrypt with
|
|
34
|
+
*/
|
|
35
|
+
export declare function decryptAndVerifyIncomingMessages(messages: AuthEncMessages, pubVerificationGpgKeys: PartyGpgKey[], prvDecryptionGpgKeys: PartyGpgKey[]): Promise<SerializedMessages>;
|
|
36
|
+
/**
|
|
37
|
+
* Encrypts and signs p2p messages + signs broadcast messages
|
|
38
|
+
* @param messages messages to encrypt and sign
|
|
39
|
+
* @param pubEncryptionGpgKey public keys to encrypt data to
|
|
40
|
+
* @param prvAuthenticationGpgKey private keys to sign with
|
|
41
|
+
*/
|
|
42
|
+
export declare function encryptAndAuthOutgoingMessages(messages: SerializedMessages, pubEncryptionGpgKeys: PartyGpgKey[], prvAuthenticationGpgKeys: PartyGpgKey[]): Promise<AuthEncMessages>;
|
|
43
|
+
//# sourceMappingURL=commsLayer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commsLayer.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/commsLayer.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,kBAAkB,EAAE,cAAc,EAAE,eAAe,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAGxG;;;;GAIG;AACH,wBAAsB,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC,CAkB7F;AAED;;;;;GAKG;AACH,wBAAsB,wBAAwB,CAC5C,IAAI,EAAE,MAAM,EACZ,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,cAAc,CAAC,CA6BzB;AAED;;;;;GAKG;AACH,wBAAsB,0BAA0B,CAC9C,yBAAyB,EAAE,cAAc,EACzC,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,MAAM,CAAC,CAoBjB;AAED;;;;GAIG;AACH,wBAAsB,gBAAgB,CAAC,aAAa,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAaxG;AAED;;;;;GAKG;AACH,wBAAsB,gCAAgC,CACpD,QAAQ,EAAE,eAAe,EACzB,sBAAsB,EAAE,WAAW,EAAE,EACrC,oBAAoB,EAAE,WAAW,EAAE,GAClC,OAAO,CAAC,kBAAkB,CAAC,CAoC7B;AAED;;;;;GAKG;AACH,wBAAsB,8BAA8B,CAClD,QAAQ,EAAE,kBAAkB,EAC5B,oBAAoB,EAAE,WAAW,EAAE,EACnC,wBAAwB,EAAE,WAAW,EAAE,GACtC,OAAO,CAAC,eAAe,CAAC,CAiC1B"}
|
|
@@ -0,0 +1,212 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
+
}) : function(o, v) {
|
|
12
|
+
o["default"] = v;
|
|
13
|
+
});
|
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
+
if (mod && mod.__esModule) return mod;
|
|
16
|
+
var result = {};
|
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
+
__setModuleDefault(result, mod);
|
|
19
|
+
return result;
|
|
20
|
+
};
|
|
21
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
|
+
exports.encryptAndAuthOutgoingMessages = exports.decryptAndVerifyIncomingMessages = exports.verifySignedData = exports.decryptAndVerifySignedData = exports.encryptAndDetachSignData = exports.detachSignData = void 0;
|
|
23
|
+
const pgp = __importStar(require("openpgp"));
|
|
24
|
+
/**
|
|
25
|
+
* Detach signs a binary and encodes it in base64
|
|
26
|
+
* @param data binary to encode in base64 and sign
|
|
27
|
+
* @param privateArmor private key to sign with
|
|
28
|
+
*/
|
|
29
|
+
async function detachSignData(data, privateArmor) {
|
|
30
|
+
const message = await pgp.createMessage({ binary: data });
|
|
31
|
+
const privateKey = await pgp.readPrivateKey({ armoredKey: privateArmor });
|
|
32
|
+
const signature = await pgp.sign({
|
|
33
|
+
message,
|
|
34
|
+
signingKeys: privateKey,
|
|
35
|
+
format: 'armored',
|
|
36
|
+
detached: true,
|
|
37
|
+
config: {
|
|
38
|
+
rejectCurves: new Set(),
|
|
39
|
+
showVersion: false,
|
|
40
|
+
showComment: false,
|
|
41
|
+
},
|
|
42
|
+
});
|
|
43
|
+
return {
|
|
44
|
+
message: data.toString('base64'),
|
|
45
|
+
signature: signature,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
exports.detachSignData = detachSignData;
|
|
49
|
+
/**
|
|
50
|
+
* Encrypts and detach signs a binary
|
|
51
|
+
* @param data binary to encrypt and sign
|
|
52
|
+
* @param publicArmor public key to encrypt with
|
|
53
|
+
* @param privateArmor private key to sign with
|
|
54
|
+
*/
|
|
55
|
+
async function encryptAndDetachSignData(data, publicArmor, privateArmor) {
|
|
56
|
+
const message = await pgp.createMessage({ binary: data });
|
|
57
|
+
const publicKey = await pgp.readKey({ armoredKey: publicArmor });
|
|
58
|
+
const privateKey = await pgp.readPrivateKey({ armoredKey: privateArmor });
|
|
59
|
+
const encryptedMessage = await pgp.encrypt({
|
|
60
|
+
message,
|
|
61
|
+
encryptionKeys: publicKey,
|
|
62
|
+
format: 'armored',
|
|
63
|
+
config: {
|
|
64
|
+
rejectCurves: new Set(),
|
|
65
|
+
showVersion: false,
|
|
66
|
+
showComment: false,
|
|
67
|
+
},
|
|
68
|
+
});
|
|
69
|
+
const signature = await pgp.sign({
|
|
70
|
+
message,
|
|
71
|
+
signingKeys: privateKey,
|
|
72
|
+
format: 'armored',
|
|
73
|
+
detached: true,
|
|
74
|
+
config: {
|
|
75
|
+
rejectCurves: new Set(),
|
|
76
|
+
showVersion: false,
|
|
77
|
+
showComment: false,
|
|
78
|
+
},
|
|
79
|
+
});
|
|
80
|
+
return {
|
|
81
|
+
encryptedMessage: encryptedMessage,
|
|
82
|
+
signature: signature,
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
exports.encryptAndDetachSignData = encryptAndDetachSignData;
|
|
86
|
+
/**
|
|
87
|
+
* Decrypts and verifies signature on a binary
|
|
88
|
+
* @param encryptedAndSignedMessage message to decrypt and verify
|
|
89
|
+
* @param publicArmor public key to verify signature with
|
|
90
|
+
* @param privateArmor private key to decrypt with
|
|
91
|
+
*/
|
|
92
|
+
async function decryptAndVerifySignedData(encryptedAndSignedMessage, publicArmor, privateArmor) {
|
|
93
|
+
const publicKey = await pgp.readKey({ armoredKey: publicArmor });
|
|
94
|
+
const privateKey = await pgp.readPrivateKey({ armoredKey: privateArmor });
|
|
95
|
+
const decryptedMessage = await pgp.decrypt({
|
|
96
|
+
message: await pgp.readMessage({ armoredMessage: encryptedAndSignedMessage.encryptedMessage }),
|
|
97
|
+
decryptionKeys: [privateKey],
|
|
98
|
+
config: {
|
|
99
|
+
rejectCurves: new Set(),
|
|
100
|
+
showVersion: false,
|
|
101
|
+
showComment: false,
|
|
102
|
+
},
|
|
103
|
+
format: 'binary',
|
|
104
|
+
});
|
|
105
|
+
const verificationResult = await pgp.verify({
|
|
106
|
+
message: await pgp.createMessage({ binary: decryptedMessage.data }),
|
|
107
|
+
signature: await pgp.readSignature({ armoredSignature: encryptedAndSignedMessage.signature }),
|
|
108
|
+
verificationKeys: publicKey,
|
|
109
|
+
});
|
|
110
|
+
await verificationResult.signatures[0].verified;
|
|
111
|
+
return Buffer.from(decryptedMessage.data).toString('base64');
|
|
112
|
+
}
|
|
113
|
+
exports.decryptAndVerifySignedData = decryptAndVerifySignedData;
|
|
114
|
+
/**
|
|
115
|
+
* Verifies signature on a binary (message passed should be encoded in base64).
|
|
116
|
+
* @param signedMessage message to verify
|
|
117
|
+
* @param publicArmor public key to verify signature with
|
|
118
|
+
*/
|
|
119
|
+
async function verifySignedData(signedMessage, publicArmor) {
|
|
120
|
+
const publicKey = await pgp.readKey({ armoredKey: publicArmor });
|
|
121
|
+
const verificationResult = await pgp.verify({
|
|
122
|
+
message: await pgp.createMessage({ binary: Buffer.from(signedMessage.message, 'base64') }),
|
|
123
|
+
signature: await pgp.readSignature({ armoredSignature: signedMessage.signature }),
|
|
124
|
+
verificationKeys: publicKey,
|
|
125
|
+
});
|
|
126
|
+
try {
|
|
127
|
+
await verificationResult.signatures[0].verified;
|
|
128
|
+
return true;
|
|
129
|
+
}
|
|
130
|
+
catch (e) {
|
|
131
|
+
return false;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
exports.verifySignedData = verifySignedData;
|
|
135
|
+
/**
|
|
136
|
+
* Decrypts and verifies p2p messages + verifies broadcast messages
|
|
137
|
+
* @param messages message to decrypt and verify
|
|
138
|
+
* @param pubVerificationGpgKeys public keys to verify signatures with
|
|
139
|
+
* @param prvDecryptionGpgKeys private keys to decrypt with
|
|
140
|
+
*/
|
|
141
|
+
async function decryptAndVerifyIncomingMessages(messages, pubVerificationGpgKeys, prvDecryptionGpgKeys) {
|
|
142
|
+
return {
|
|
143
|
+
p2pMessages: await Promise.all(messages.p2pMessages.map(async (m) => {
|
|
144
|
+
const pubGpgKey = pubVerificationGpgKeys.find((k) => k.partyId === m.from);
|
|
145
|
+
const prvGpgKey = prvDecryptionGpgKeys.find((k) => k.partyId === m.to);
|
|
146
|
+
if (!pubGpgKey) {
|
|
147
|
+
throw Error(`No public key provided for sender with ID: ${m.from}`);
|
|
148
|
+
}
|
|
149
|
+
if (!prvGpgKey) {
|
|
150
|
+
throw Error(`No private key provided for recepient with ID: ${m.to}`);
|
|
151
|
+
}
|
|
152
|
+
return {
|
|
153
|
+
to: m.to,
|
|
154
|
+
from: m.from,
|
|
155
|
+
payload: await decryptAndVerifySignedData(m.payload, pubGpgKey.gpgKey, prvGpgKey.gpgKey),
|
|
156
|
+
commitment: m.commitment,
|
|
157
|
+
};
|
|
158
|
+
})),
|
|
159
|
+
broadcastMessages: await Promise.all(messages.broadcastMessages.map(async (m) => {
|
|
160
|
+
const pubGpgKey = pubVerificationGpgKeys.find((k) => k.partyId === m.from);
|
|
161
|
+
if (!pubGpgKey) {
|
|
162
|
+
throw Error(`No public key provided for sender with ID: ${m.from}`);
|
|
163
|
+
}
|
|
164
|
+
if (!(await verifySignedData(m.payload, pubGpgKey.gpgKey))) {
|
|
165
|
+
throw Error(`Failed to authenticate broadcast message from party: ${m.from}`);
|
|
166
|
+
}
|
|
167
|
+
return {
|
|
168
|
+
from: m.from,
|
|
169
|
+
payload: m.payload.message,
|
|
170
|
+
};
|
|
171
|
+
})),
|
|
172
|
+
};
|
|
173
|
+
}
|
|
174
|
+
exports.decryptAndVerifyIncomingMessages = decryptAndVerifyIncomingMessages;
|
|
175
|
+
/**
|
|
176
|
+
* Encrypts and signs p2p messages + signs broadcast messages
|
|
177
|
+
* @param messages messages to encrypt and sign
|
|
178
|
+
* @param pubEncryptionGpgKey public keys to encrypt data to
|
|
179
|
+
* @param prvAuthenticationGpgKey private keys to sign with
|
|
180
|
+
*/
|
|
181
|
+
async function encryptAndAuthOutgoingMessages(messages, pubEncryptionGpgKeys, prvAuthenticationGpgKeys) {
|
|
182
|
+
return {
|
|
183
|
+
p2pMessages: await Promise.all(messages.p2pMessages.map(async (m) => {
|
|
184
|
+
const pubGpgKey = pubEncryptionGpgKeys.find((k) => k.partyId === m.to);
|
|
185
|
+
const prvGpgKey = prvAuthenticationGpgKeys.find((k) => k.partyId === m.from);
|
|
186
|
+
if (!pubGpgKey) {
|
|
187
|
+
throw Error(`No public key provided for recipient with ID: ${m.to}`);
|
|
188
|
+
}
|
|
189
|
+
if (!prvGpgKey) {
|
|
190
|
+
throw Error(`No private key provided for sender with ID: ${m.from}`);
|
|
191
|
+
}
|
|
192
|
+
return {
|
|
193
|
+
to: m.to,
|
|
194
|
+
from: m.from,
|
|
195
|
+
payload: await encryptAndDetachSignData(Buffer.from(m.payload, 'base64'), pubGpgKey.gpgKey, prvGpgKey.gpgKey),
|
|
196
|
+
commitment: m.commitment,
|
|
197
|
+
};
|
|
198
|
+
})),
|
|
199
|
+
broadcastMessages: await Promise.all(messages.broadcastMessages.map(async (m) => {
|
|
200
|
+
const prvGpgKey = prvAuthenticationGpgKeys.find((k) => k.partyId === m.from);
|
|
201
|
+
if (!prvGpgKey) {
|
|
202
|
+
throw Error(`No private key provided for sender with ID: ${m.from}`);
|
|
203
|
+
}
|
|
204
|
+
return {
|
|
205
|
+
from: m.from,
|
|
206
|
+
payload: await detachSignData(Buffer.from(m.payload, 'base64'), prvGpgKey.gpgKey),
|
|
207
|
+
};
|
|
208
|
+
})),
|
|
209
|
+
};
|
|
210
|
+
}
|
|
211
|
+
exports.encryptAndAuthOutgoingMessages = encryptAndAuthOutgoingMessages;
|
|
212
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commsLayer.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/commsLayer.ts"],"names":[],"mappings":"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","sourcesContent":["import { SerializedMessages, AuthEncMessage, AuthEncMessages, PartyGpgKey, AuthMessage } from './types';\nimport * as pgp from 'openpgp';\n\n/**\n * Detach signs a binary and encodes it in base64\n * @param data binary to encode in base64 and sign\n * @param privateArmor private key to sign with\n */\nexport async function detachSignData(data: Buffer, privateArmor: string): Promise<AuthMessage> {\n  const message = await pgp.createMessage({ binary: data });\n  const privateKey = await pgp.readPrivateKey({ armoredKey: privateArmor });\n  const signature = await pgp.sign({\n    message,\n    signingKeys: privateKey,\n    format: 'armored',\n    detached: true,\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n  return {\n    message: data.toString('base64'),\n    signature: signature,\n  };\n}\n\n/**\n * Encrypts and detach signs a binary\n * @param data binary to encrypt and sign\n * @param publicArmor public key to encrypt with\n * @param privateArmor private key to sign with\n */\nexport async function encryptAndDetachSignData(\n  data: Buffer,\n  publicArmor: string,\n  privateArmor: string\n): Promise<AuthEncMessage> {\n  const message = await pgp.createMessage({ binary: data });\n  const publicKey = await pgp.readKey({ armoredKey: publicArmor });\n  const privateKey = await pgp.readPrivateKey({ armoredKey: privateArmor });\n  const encryptedMessage = await pgp.encrypt({\n    message,\n    encryptionKeys: publicKey,\n    format: 'armored',\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n  const signature = await pgp.sign({\n    message,\n    signingKeys: privateKey,\n    format: 'armored',\n    detached: true,\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n  return {\n    encryptedMessage: encryptedMessage,\n    signature: signature,\n  };\n}\n\n/**\n * Decrypts and verifies signature on a binary\n * @param encryptedAndSignedMessage message to decrypt and verify\n * @param publicArmor public key to verify signature with\n * @param privateArmor private key to decrypt with\n */\nexport async function decryptAndVerifySignedData(\n  encryptedAndSignedMessage: AuthEncMessage,\n  publicArmor: string,\n  privateArmor: string\n): Promise<string> {\n  const publicKey = await pgp.readKey({ armoredKey: publicArmor });\n  const privateKey = await pgp.readPrivateKey({ armoredKey: privateArmor });\n  const decryptedMessage = await pgp.decrypt({\n    message: await pgp.readMessage({ armoredMessage: encryptedAndSignedMessage.encryptedMessage }),\n    decryptionKeys: [privateKey],\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n    format: 'binary',\n  });\n  const verificationResult = await pgp.verify({\n    message: await pgp.createMessage({ binary: decryptedMessage.data }),\n    signature: await pgp.readSignature({ armoredSignature: encryptedAndSignedMessage.signature }),\n    verificationKeys: publicKey,\n  });\n  await verificationResult.signatures[0].verified;\n  return Buffer.from(decryptedMessage.data).toString('base64');\n}\n\n/**\n * Verifies signature on a binary (message passed should be encoded in base64).\n * @param signedMessage message to verify\n * @param publicArmor public key to verify signature with\n */\nexport async function verifySignedData(signedMessage: AuthMessage, publicArmor: string): Promise<boolean> {\n  const publicKey = await pgp.readKey({ armoredKey: publicArmor });\n  const verificationResult = await pgp.verify({\n    message: await pgp.createMessage({ binary: Buffer.from(signedMessage.message, 'base64') }),\n    signature: await pgp.readSignature({ armoredSignature: signedMessage.signature }),\n    verificationKeys: publicKey,\n  });\n  try {\n    await verificationResult.signatures[0].verified;\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Decrypts and verifies p2p messages + verifies broadcast messages\n * @param messages message to decrypt and verify\n * @param pubVerificationGpgKeys public keys to verify signatures with\n * @param prvDecryptionGpgKeys private keys to decrypt with\n */\nexport async function decryptAndVerifyIncomingMessages(\n  messages: AuthEncMessages,\n  pubVerificationGpgKeys: PartyGpgKey[],\n  prvDecryptionGpgKeys: PartyGpgKey[]\n): Promise<SerializedMessages> {\n  return {\n    p2pMessages: await Promise.all(\n      messages.p2pMessages.map(async (m) => {\n        const pubGpgKey = pubVerificationGpgKeys.find((k) => k.partyId === m.from);\n        const prvGpgKey = prvDecryptionGpgKeys.find((k) => k.partyId === m.to);\n        if (!pubGpgKey) {\n          throw Error(`No public key provided for sender with ID: ${m.from}`);\n        }\n        if (!prvGpgKey) {\n          throw Error(`No private key provided for recepient with ID: ${m.to}`);\n        }\n        return {\n          to: m.to,\n          from: m.from,\n          payload: await decryptAndVerifySignedData(m.payload, pubGpgKey.gpgKey, prvGpgKey.gpgKey),\n          commitment: m.commitment,\n        };\n      })\n    ),\n    broadcastMessages: await Promise.all(\n      messages.broadcastMessages.map(async (m) => {\n        const pubGpgKey = pubVerificationGpgKeys.find((k) => k.partyId === m.from);\n        if (!pubGpgKey) {\n          throw Error(`No public key provided for sender with ID: ${m.from}`);\n        }\n        if (!(await verifySignedData(m.payload, pubGpgKey.gpgKey))) {\n          throw Error(`Failed to authenticate broadcast message from party: ${m.from}`);\n        }\n        return {\n          from: m.from,\n          payload: m.payload.message,\n        };\n      })\n    ),\n  };\n}\n\n/**\n * Encrypts and signs p2p messages + signs broadcast messages\n * @param messages messages to encrypt and sign\n * @param pubEncryptionGpgKey public keys to encrypt data to\n * @param prvAuthenticationGpgKey private keys to sign with\n */\nexport async function encryptAndAuthOutgoingMessages(\n  messages: SerializedMessages,\n  pubEncryptionGpgKeys: PartyGpgKey[],\n  prvAuthenticationGpgKeys: PartyGpgKey[]\n): Promise<AuthEncMessages> {\n  return {\n    p2pMessages: await Promise.all(\n      messages.p2pMessages.map(async (m) => {\n        const pubGpgKey = pubEncryptionGpgKeys.find((k) => k.partyId === m.to);\n        const prvGpgKey = prvAuthenticationGpgKeys.find((k) => k.partyId === m.from);\n        if (!pubGpgKey) {\n          throw Error(`No public key provided for recipient with ID: ${m.to}`);\n        }\n        if (!prvGpgKey) {\n          throw Error(`No private key provided for sender with ID: ${m.from}`);\n        }\n        return {\n          to: m.to,\n          from: m.from,\n          payload: await encryptAndDetachSignData(Buffer.from(m.payload, 'base64'), pubGpgKey.gpgKey, prvGpgKey.gpgKey),\n          commitment: m.commitment,\n        };\n      })\n    ),\n    broadcastMessages: await Promise.all(\n      messages.broadcastMessages.map(async (m) => {\n        const prvGpgKey = prvAuthenticationGpgKeys.find((k) => k.partyId === m.from);\n        if (!prvGpgKey) {\n          throw Error(`No private key provided for sender with ID: ${m.from}`);\n        }\n        return {\n          from: m.from,\n          payload: await detachSignData(Buffer.from(m.payload, 'base64'), prvGpgKey.gpgKey),\n        };\n      })\n    ),\n  };\n}\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { KeygenSession, Keyshare } from '@silencelaboratories/dkls-wasm-ll-node';
|
|
3
|
+
import { DeserializedBroadcastMessage, DeserializedMessages, DkgState } from './types';
|
|
4
|
+
export declare class Dkg {
|
|
5
|
+
protected dkgSession: KeygenSession | undefined;
|
|
6
|
+
protected dkgSessionBytes: Uint8Array;
|
|
7
|
+
protected dkgKeyShare: Keyshare;
|
|
8
|
+
protected n: number;
|
|
9
|
+
protected t: number;
|
|
10
|
+
protected chainCodeCommitment: Uint8Array | undefined;
|
|
11
|
+
protected partyIdx: number;
|
|
12
|
+
protected dkgState: DkgState;
|
|
13
|
+
constructor(n: number, t: number, partyIdx: number);
|
|
14
|
+
private _restoreSession;
|
|
15
|
+
private _deserializeState;
|
|
16
|
+
initDkg(): Promise<DeserializedBroadcastMessage>;
|
|
17
|
+
getKeyShare(): Buffer;
|
|
18
|
+
handleIncomingMessages(messagesForIthRound: DeserializedMessages): DeserializedMessages;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=dkg.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dkg.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/dkg.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAW,MAAM,wCAAwC,CAAC;AAC1F,OAAO,EAAE,4BAA4B,EAAE,oBAAoB,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAGvF,qBAAa,GAAG;IACd,SAAS,CAAC,UAAU,EAAE,aAAa,GAAG,SAAS,CAAC;IAChD,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC;IACtC,SAAS,CAAC,WAAW,EAAE,QAAQ,CAAC;IAChC,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,mBAAmB,EAAE,UAAU,GAAG,SAAS,CAAC;IACtD,SAAS,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC3B,SAAS,CAAC,QAAQ,EAAE,QAAQ,CAA0B;gBAE1C,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM;IAOlD,OAAO,CAAC,eAAe;IAMvB,OAAO,CAAC,iBAAiB;IA2BnB,OAAO,IAAI,OAAO,CAAC,4BAA4B,CAAC;IAwBtD,WAAW,IAAI,MAAM;IAMrB,sBAAsB,CAAC,mBAAmB,EAAE,oBAAoB,GAAG,oBAAoB;CA8ExF"}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Dkg = void 0;
|
|
4
|
+
const dkls_wasm_ll_node_1 = require("@silencelaboratories/dkls-wasm-ll-node");
|
|
5
|
+
const types_1 = require("./types");
|
|
6
|
+
const cbor_1 = require("cbor");
|
|
7
|
+
class Dkg {
|
|
8
|
+
constructor(n, t, partyIdx) {
|
|
9
|
+
this.dkgState = types_1.DkgState.Uninitialized;
|
|
10
|
+
this.n = n;
|
|
11
|
+
this.t = t;
|
|
12
|
+
this.partyIdx = partyIdx;
|
|
13
|
+
this.chainCodeCommitment = undefined;
|
|
14
|
+
}
|
|
15
|
+
_restoreSession() {
|
|
16
|
+
if (!this.dkgSession) {
|
|
17
|
+
this.dkgSession = dkls_wasm_ll_node_1.KeygenSession.fromBytes(this.dkgSessionBytes);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
_deserializeState() {
|
|
21
|
+
if (!this.dkgSession) {
|
|
22
|
+
throw Error('Session not intialized');
|
|
23
|
+
}
|
|
24
|
+
const round = cbor_1.decode(this.dkgSession.toBytes()).round;
|
|
25
|
+
switch (round) {
|
|
26
|
+
case 'WaitMsg1':
|
|
27
|
+
this.dkgState = types_1.DkgState.Round1;
|
|
28
|
+
break;
|
|
29
|
+
case 'WaitMsg2':
|
|
30
|
+
this.dkgState = types_1.DkgState.Round2;
|
|
31
|
+
break;
|
|
32
|
+
case 'WaitMsg3':
|
|
33
|
+
this.dkgState = types_1.DkgState.Round3;
|
|
34
|
+
break;
|
|
35
|
+
case 'WaitMsg4':
|
|
36
|
+
this.dkgState = types_1.DkgState.Round4;
|
|
37
|
+
break;
|
|
38
|
+
case 'Ended':
|
|
39
|
+
this.dkgState = types_1.DkgState.Complete;
|
|
40
|
+
break;
|
|
41
|
+
default:
|
|
42
|
+
this.dkgState = types_1.DkgState.InvalidState;
|
|
43
|
+
throw `Invalid State: ${round}`;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
async initDkg() {
|
|
47
|
+
if (this.t > this.n || this.partyIdx >= this.n) {
|
|
48
|
+
throw 'Invalid parameters for DKG';
|
|
49
|
+
}
|
|
50
|
+
if (this.dkgState != types_1.DkgState.Uninitialized) {
|
|
51
|
+
throw 'DKG session already initialized';
|
|
52
|
+
}
|
|
53
|
+
if (typeof window !== 'undefined') {
|
|
54
|
+
const initDkls = require('@silencelaboratories/dkls-wasm-ll-web');
|
|
55
|
+
await initDkls();
|
|
56
|
+
}
|
|
57
|
+
this.dkgSession = new dkls_wasm_ll_node_1.KeygenSession(this.n, this.t, this.partyIdx);
|
|
58
|
+
try {
|
|
59
|
+
const payload = this.dkgSession.createFirstMessage().payload;
|
|
60
|
+
this._deserializeState();
|
|
61
|
+
return {
|
|
62
|
+
payload: payload,
|
|
63
|
+
from: this.partyIdx,
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
catch (e) {
|
|
67
|
+
throw `Error while creating the first message from party ${this.partyIdx}: ${e}`;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
getKeyShare() {
|
|
71
|
+
const keyShareBuff = Buffer.from(this.dkgKeyShare.toBytes());
|
|
72
|
+
this.dkgKeyShare.free();
|
|
73
|
+
return keyShareBuff;
|
|
74
|
+
}
|
|
75
|
+
handleIncomingMessages(messagesForIthRound) {
|
|
76
|
+
let nextRoundMessages = [];
|
|
77
|
+
let nextRoundDeserializedMessages = { broadcastMessages: [], p2pMessages: [] };
|
|
78
|
+
this._restoreSession();
|
|
79
|
+
if (!this.dkgSession) {
|
|
80
|
+
throw Error('Session not initialized');
|
|
81
|
+
}
|
|
82
|
+
try {
|
|
83
|
+
if (this.dkgState == types_1.DkgState.Round3) {
|
|
84
|
+
const commitmentsUnsorted = messagesForIthRound.p2pMessages
|
|
85
|
+
.map((m) => {
|
|
86
|
+
return { from: m.from, commitment: m.commitment };
|
|
87
|
+
})
|
|
88
|
+
.concat([{ from: this.partyIdx, commitment: this.chainCodeCommitment }]);
|
|
89
|
+
const commitmentsSorted = commitmentsUnsorted
|
|
90
|
+
.sort((a, b) => {
|
|
91
|
+
return a.from - b.from;
|
|
92
|
+
})
|
|
93
|
+
.map((c) => c.commitment);
|
|
94
|
+
nextRoundMessages = this.dkgSession.handleMessages(messagesForIthRound.broadcastMessages
|
|
95
|
+
.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, undefined))
|
|
96
|
+
.concat(messagesForIthRound.p2pMessages.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, m.to))), commitmentsSorted);
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
nextRoundMessages = this.dkgSession.handleMessages(messagesForIthRound.broadcastMessages
|
|
100
|
+
.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, undefined))
|
|
101
|
+
.concat(messagesForIthRound.p2pMessages.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, m.to))), undefined);
|
|
102
|
+
}
|
|
103
|
+
if (this.dkgState == types_1.DkgState.Round4) {
|
|
104
|
+
this.dkgKeyShare = this.dkgSession.keyshare();
|
|
105
|
+
this.dkgState = types_1.DkgState.Complete;
|
|
106
|
+
return { broadcastMessages: [], p2pMessages: [] };
|
|
107
|
+
}
|
|
108
|
+
else {
|
|
109
|
+
// Update ronud data.
|
|
110
|
+
this._deserializeState();
|
|
111
|
+
}
|
|
112
|
+
if (this.dkgState == types_1.DkgState.Round2) {
|
|
113
|
+
this.chainCodeCommitment = this.dkgSession.calculateChainCodeCommitment();
|
|
114
|
+
}
|
|
115
|
+
nextRoundDeserializedMessages = {
|
|
116
|
+
p2pMessages: nextRoundMessages
|
|
117
|
+
.filter((m) => m.to_id !== undefined)
|
|
118
|
+
.map((m) => {
|
|
119
|
+
const p2pReturn = {
|
|
120
|
+
payload: m.payload,
|
|
121
|
+
from: m.from_id,
|
|
122
|
+
to: m.to_id,
|
|
123
|
+
commitment: this.chainCodeCommitment,
|
|
124
|
+
};
|
|
125
|
+
return p2pReturn;
|
|
126
|
+
}),
|
|
127
|
+
broadcastMessages: nextRoundMessages
|
|
128
|
+
.filter((m) => m.to_id === undefined)
|
|
129
|
+
.map((m) => {
|
|
130
|
+
const broadcastReturn = {
|
|
131
|
+
payload: m.payload,
|
|
132
|
+
from: m.from_id,
|
|
133
|
+
};
|
|
134
|
+
return broadcastReturn;
|
|
135
|
+
}),
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
catch (e) {
|
|
139
|
+
throw `Error while creating messages from party ${this.partyIdx}, round ${this.dkgState}: ${e}`;
|
|
140
|
+
}
|
|
141
|
+
finally {
|
|
142
|
+
nextRoundMessages.forEach((m) => m.free());
|
|
143
|
+
// Session is freed when keyshare is called.
|
|
144
|
+
if (this.dkgState !== types_1.DkgState.Complete) {
|
|
145
|
+
this.dkgSessionBytes = this.dkgSession.toBytes();
|
|
146
|
+
this.dkgSession = undefined;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
return nextRoundDeserializedMessages;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
exports.Dkg = Dkg;
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dkg.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/dkg.ts"],"names":[],"mappings":"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","sourcesContent":["import { KeygenSession, Keyshare, Message } from '@silencelaboratories/dkls-wasm-ll-node';\nimport { DeserializedBroadcastMessage, DeserializedMessages, DkgState } from './types';\nimport { decode } from 'cbor';\n\nexport class Dkg {\n  protected dkgSession: KeygenSession | undefined;\n  protected dkgSessionBytes: Uint8Array;\n  protected dkgKeyShare: Keyshare;\n  protected n: number;\n  protected t: number;\n  protected chainCodeCommitment: Uint8Array | undefined;\n  protected partyIdx: number;\n  protected dkgState: DkgState = DkgState.Uninitialized;\n\n  constructor(n: number, t: number, partyIdx: number) {\n    this.n = n;\n    this.t = t;\n    this.partyIdx = partyIdx;\n    this.chainCodeCommitment = undefined;\n  }\n\n  private _restoreSession() {\n    if (!this.dkgSession) {\n      this.dkgSession = KeygenSession.fromBytes(this.dkgSessionBytes);\n    }\n  }\n\n  private _deserializeState() {\n    if (!this.dkgSession) {\n      throw Error('Session not intialized');\n    }\n    const round = decode(this.dkgSession.toBytes()).round;\n    switch (round) {\n      case 'WaitMsg1':\n        this.dkgState = DkgState.Round1;\n        break;\n      case 'WaitMsg2':\n        this.dkgState = DkgState.Round2;\n        break;\n      case 'WaitMsg3':\n        this.dkgState = DkgState.Round3;\n        break;\n      case 'WaitMsg4':\n        this.dkgState = DkgState.Round4;\n        break;\n      case 'Ended':\n        this.dkgState = DkgState.Complete;\n        break;\n      default:\n        this.dkgState = DkgState.InvalidState;\n        throw `Invalid State: ${round}`;\n    }\n  }\n\n  async initDkg(): Promise<DeserializedBroadcastMessage> {\n    if (this.t > this.n || this.partyIdx >= this.n) {\n      throw 'Invalid parameters for DKG';\n    }\n    if (this.dkgState != DkgState.Uninitialized) {\n      throw 'DKG session already initialized';\n    }\n    if (typeof window !== 'undefined') {\n      const initDkls = require('@silencelaboratories/dkls-wasm-ll-web');\n      await initDkls();\n    }\n    this.dkgSession = new KeygenSession(this.n, this.t, this.partyIdx);\n    try {\n      const payload = this.dkgSession.createFirstMessage().payload;\n      this._deserializeState();\n      return {\n        payload: payload,\n        from: this.partyIdx,\n      };\n    } catch (e) {\n      throw `Error while creating the first message from party ${this.partyIdx}: ${e}`;\n    }\n  }\n\n  getKeyShare(): Buffer {\n    const keyShareBuff = Buffer.from(this.dkgKeyShare.toBytes());\n    this.dkgKeyShare.free();\n    return keyShareBuff;\n  }\n\n  handleIncomingMessages(messagesForIthRound: DeserializedMessages): DeserializedMessages {\n    let nextRoundMessages: Message[] = [];\n    let nextRoundDeserializedMessages: DeserializedMessages = { broadcastMessages: [], p2pMessages: [] };\n    this._restoreSession();\n    if (!this.dkgSession) {\n      throw Error('Session not initialized');\n    }\n    try {\n      if (this.dkgState == DkgState.Round3) {\n        const commitmentsUnsorted = messagesForIthRound.p2pMessages\n          .map((m) => {\n            return { from: m.from, commitment: m.commitment };\n          })\n          .concat([{ from: this.partyIdx, commitment: this.chainCodeCommitment }]);\n        const commitmentsSorted = commitmentsUnsorted\n          .sort((a, b) => {\n            return a.from - b.from;\n          })\n          .map((c) => c.commitment);\n        nextRoundMessages = this.dkgSession.handleMessages(\n          messagesForIthRound.broadcastMessages\n            .map((m) => new Message(m.payload, m.from, undefined))\n            .concat(messagesForIthRound.p2pMessages.map((m) => new Message(m.payload, m.from, m.to))),\n          commitmentsSorted\n        );\n      } else {\n        nextRoundMessages = this.dkgSession.handleMessages(\n          messagesForIthRound.broadcastMessages\n            .map((m) => new Message(m.payload, m.from, undefined))\n            .concat(messagesForIthRound.p2pMessages.map((m) => new Message(m.payload, m.from, m.to))),\n          undefined\n        );\n      }\n      if (this.dkgState == DkgState.Round4) {\n        this.dkgKeyShare = this.dkgSession.keyshare();\n        this.dkgState = DkgState.Complete;\n        return { broadcastMessages: [], p2pMessages: [] };\n      } else {\n        // Update ronud data.\n        this._deserializeState();\n      }\n      if (this.dkgState == DkgState.Round2) {\n        this.chainCodeCommitment = this.dkgSession.calculateChainCodeCommitment();\n      }\n      nextRoundDeserializedMessages = {\n        p2pMessages: nextRoundMessages\n          .filter((m) => m.to_id !== undefined)\n          .map((m) => {\n            const p2pReturn = {\n              payload: m.payload,\n              from: m.from_id,\n              to: m.to_id!,\n              commitment: this.chainCodeCommitment,\n            };\n            return p2pReturn;\n          }),\n        broadcastMessages: nextRoundMessages\n          .filter((m) => m.to_id === undefined)\n          .map((m) => {\n            const broadcastReturn = {\n              payload: m.payload,\n              from: m.from_id,\n            };\n            return broadcastReturn;\n          }),\n      };\n    } catch (e) {\n      throw `Error while creating messages from party ${this.partyIdx}, round ${this.dkgState}: ${e}`;\n    } finally {\n      nextRoundMessages.forEach((m) => m.free());\n      // Session is freed when keyshare is called.\n      if (this.dkgState !== DkgState.Complete) {\n        this.dkgSessionBytes = this.dkgSession.toBytes();\n        this.dkgSession = undefined;\n      }\n    }\n    return nextRoundDeserializedMessages;\n  }\n}\n"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { SignSession, Keyshare } from '@silencelaboratories/dkls-wasm-ll-node';
|
|
3
|
+
import { DeserializedBroadcastMessage, DeserializedMessages, DklsSignature, DsgState } from './types';
|
|
4
|
+
export declare class Dsg {
|
|
5
|
+
protected dsgSession: SignSession | undefined;
|
|
6
|
+
protected dsgSessionBytes: Uint8Array;
|
|
7
|
+
private _signature;
|
|
8
|
+
protected keyShare: Keyshare;
|
|
9
|
+
protected messageHash: Buffer;
|
|
10
|
+
protected derivationPath: string;
|
|
11
|
+
protected partyIdx: number;
|
|
12
|
+
protected dsgState: DsgState;
|
|
13
|
+
constructor(keyShare: Buffer, partyIdx: number, derivationPath: string, messageHash: Buffer);
|
|
14
|
+
private _restoreSession;
|
|
15
|
+
private _deserializeState;
|
|
16
|
+
init(): Promise<DeserializedBroadcastMessage>;
|
|
17
|
+
get signature(): DklsSignature;
|
|
18
|
+
/**
|
|
19
|
+
* Ends the DSG session by freeing any heap allocations from wasm. Note that the session is freed if a signature is produced.
|
|
20
|
+
*/
|
|
21
|
+
endSession(): void;
|
|
22
|
+
/**
|
|
23
|
+
* Proccesses incoming messages to this party in the DKLs DSG protocol and
|
|
24
|
+
* produces messages from this party to other parties for the next round.
|
|
25
|
+
* @param messagesForIthRound - messages to process the current round
|
|
26
|
+
* @returns {DeserializedMessages} - messages to send to other parties for the next round
|
|
27
|
+
*/
|
|
28
|
+
handleIncomingMessages(messagesForIthRound: DeserializedMessages): DeserializedMessages;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=dsg.d.ts.map
|