@bitgo-beta/sdk-lib-mpc 8.2.1-alpha.15 → 8.2.1-alpha.151
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 +553 -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 +12 -3
- 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 +29 -38
- 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 +25 -4
- package/dist/src/openssl/index.js +6 -2
- package/dist/src/openssl/openssl.d.ts +1 -2
- package/dist/src/openssl/openssl.d.ts.map +1 -1
- package/dist/src/openssl/openssl.js +4 -12
- package/dist/src/safePrime.d.ts +3 -0
- package/dist/src/safePrime.d.ts.map +1 -0
- package/dist/src/safePrime.js +20 -0
- 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 +19 -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 +8 -3
- package/dist/src/tss/ecdsa/paillierproof.js +6 -6
- package/dist/src/tss/ecdsa/rangeproof.d.ts +1 -2
- package/dist/src/tss/ecdsa/rangeproof.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/rangeproof.js +105 -111
- package/dist/src/tss/ecdsa/types.d.ts +16 -0
- package/dist/src/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/types.js +19 -20
- 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 +224 -0
- package/dist/src/tss/ecdsa-dkls/dkg.d.ts +34 -0
- package/dist/src/tss/ecdsa-dkls/dkg.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/dkg.js +266 -0
- package/dist/src/tss/ecdsa-dkls/dsg.d.ts +48 -0
- package/dist/src/tss/ecdsa-dkls/dsg.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/dsg.js +257 -0
- package/dist/src/tss/ecdsa-dkls/index.d.ts +6 -0
- package/dist/src/tss/ecdsa-dkls/index.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/index.js +32 -0
- package/dist/src/tss/ecdsa-dkls/types.d.ts +119 -0
- package/dist/src/tss/ecdsa-dkls/types.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/types.js +155 -0
- package/dist/src/tss/ecdsa-dkls/util.d.ts +28 -0
- package/dist/src/tss/ecdsa-dkls/util.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/util.js +267 -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 +7 -2
- 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 +35 -13
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +27 -7
- package/dist/src/curves/baseCurve.d.ts.map +0 -1
- package/dist/src/curves/baseCurve.js +0 -6
- package/dist/src/openssl/opensslbytes.d.ts +0 -4
- package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
- package/dist/src/openssl/opensslbytes.js +0 -20
|
@@ -0,0 +1,257 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.Dsg = void 0;
|
|
27
|
+
const types_1 = require("./types");
|
|
28
|
+
const cbor_x_1 = require("cbor-x");
|
|
29
|
+
class Dsg {
|
|
30
|
+
constructor(keyShare, partyIdx, derivationPath, messageHash, dklsWasm) {
|
|
31
|
+
this.dsgState = types_1.DsgState.Uninitialized;
|
|
32
|
+
this.partyIdx = partyIdx;
|
|
33
|
+
this.keyShareBytes = keyShare;
|
|
34
|
+
this.derivationPath = derivationPath;
|
|
35
|
+
this.messageHash = messageHash;
|
|
36
|
+
this.dklsWasm = dklsWasm !== null && dklsWasm !== void 0 ? dklsWasm : null;
|
|
37
|
+
}
|
|
38
|
+
_restoreSession() {
|
|
39
|
+
if (!this.dsgSession) {
|
|
40
|
+
this.dsgSession = this.getDklsWasm().SignSession.fromBytes(this.dsgSessionBytes);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
_deserializeState() {
|
|
44
|
+
if (!this.dsgSession) {
|
|
45
|
+
throw Error('Session not intialized');
|
|
46
|
+
}
|
|
47
|
+
const round = (0, cbor_x_1.decode)(this.dsgSession.toBytes()).round;
|
|
48
|
+
switch (round) {
|
|
49
|
+
case 'WaitMsg1':
|
|
50
|
+
this.dsgState = types_1.DsgState.Round1;
|
|
51
|
+
break;
|
|
52
|
+
case 'WaitMsg2':
|
|
53
|
+
this.dsgState = types_1.DsgState.Round2;
|
|
54
|
+
break;
|
|
55
|
+
case 'WaitMsg3':
|
|
56
|
+
this.dsgState = types_1.DsgState.Round3;
|
|
57
|
+
break;
|
|
58
|
+
case 'Ended':
|
|
59
|
+
this.dsgState = types_1.DsgState.Complete;
|
|
60
|
+
break;
|
|
61
|
+
default:
|
|
62
|
+
this.dsgState = types_1.DsgState.InvalidState;
|
|
63
|
+
throw Error(`Invalid State: ${round}`);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
async loadDklsWasm() {
|
|
67
|
+
if (!this.dklsWasm) {
|
|
68
|
+
this.dklsWasm = await Promise.resolve().then(() => __importStar(require('@silencelaboratories/dkls-wasm-ll-node')));
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
getDklsWasm() {
|
|
72
|
+
if (!this.dklsWasm) {
|
|
73
|
+
throw Error('DKLS wasm not loaded');
|
|
74
|
+
}
|
|
75
|
+
return this.dklsWasm;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Returns the current DSG session as a base64 string.
|
|
79
|
+
* @returns {string} - base64 string of the current DSG session
|
|
80
|
+
*/
|
|
81
|
+
getSession() {
|
|
82
|
+
return Buffer.from(this.dsgSessionBytes).toString('base64');
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Sets the DSG session from a base64 string.
|
|
86
|
+
* @param {string} session - base64 string of the DSG session
|
|
87
|
+
*/
|
|
88
|
+
async setSession(session) {
|
|
89
|
+
this.dsgSession = undefined;
|
|
90
|
+
if (!this.dklsWasm) {
|
|
91
|
+
await this.loadDklsWasm();
|
|
92
|
+
}
|
|
93
|
+
const sessionBytes = new Uint8Array(Buffer.from(session, 'base64'));
|
|
94
|
+
const round = (0, cbor_x_1.decode)(sessionBytes).round;
|
|
95
|
+
switch (true) {
|
|
96
|
+
case round === 'WaitMsg1':
|
|
97
|
+
this.dsgState = types_1.DsgState.Round1;
|
|
98
|
+
break;
|
|
99
|
+
case round === 'WaitMsg2':
|
|
100
|
+
this.dsgState = types_1.DsgState.Round2;
|
|
101
|
+
break;
|
|
102
|
+
case round === 'WaitMsg3':
|
|
103
|
+
this.dsgState = types_1.DsgState.Round3;
|
|
104
|
+
break;
|
|
105
|
+
case 'WaitMsg4' in round:
|
|
106
|
+
this.dsgState = types_1.DsgState.Round4;
|
|
107
|
+
break;
|
|
108
|
+
default:
|
|
109
|
+
throw Error(`Invalid State: ${round}`);
|
|
110
|
+
}
|
|
111
|
+
this.dsgSessionBytes = sessionBytes;
|
|
112
|
+
}
|
|
113
|
+
async init() {
|
|
114
|
+
var _a;
|
|
115
|
+
if (this.dsgState !== types_1.DsgState.Uninitialized) {
|
|
116
|
+
throw Error('DSG session already initialized');
|
|
117
|
+
}
|
|
118
|
+
if (!this.dklsWasm) {
|
|
119
|
+
await this.loadDklsWasm();
|
|
120
|
+
}
|
|
121
|
+
if (typeof window !== 'undefined' &&
|
|
122
|
+
/* checks for electron processes */
|
|
123
|
+
!window.process &&
|
|
124
|
+
!((_a = window.process) === null || _a === void 0 ? void 0 : _a['type'])) {
|
|
125
|
+
/* This is only needed for browsers/web because it uses fetch to resolve the wasm asset for the web */
|
|
126
|
+
const initDkls = await Promise.resolve().then(() => __importStar(require('@silencelaboratories/dkls-wasm-ll-web')));
|
|
127
|
+
await initDkls.default();
|
|
128
|
+
}
|
|
129
|
+
const { Keyshare, SignSession } = this.getDklsWasm();
|
|
130
|
+
const keyShare = Keyshare.fromBytes(this.keyShareBytes);
|
|
131
|
+
if (keyShare.partyId !== this.partyIdx) {
|
|
132
|
+
throw Error(`Party index: ${this.partyIdx} does not match key share partyId: ${keyShare.partyId} `);
|
|
133
|
+
}
|
|
134
|
+
this.dsgSession = new SignSession(keyShare, this.derivationPath);
|
|
135
|
+
try {
|
|
136
|
+
const payload = this.dsgSession.createFirstMessage().payload;
|
|
137
|
+
this._deserializeState();
|
|
138
|
+
this.dsgSessionBytes = this.dsgSession.toBytes();
|
|
139
|
+
this.dsgSession = undefined;
|
|
140
|
+
return {
|
|
141
|
+
payload: payload,
|
|
142
|
+
from: this.partyIdx,
|
|
143
|
+
};
|
|
144
|
+
}
|
|
145
|
+
catch (e) {
|
|
146
|
+
throw Error(`Error while creating the first message from party ${this.partyIdx}: ${e}`);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
get signature() {
|
|
150
|
+
if (!this._signature) {
|
|
151
|
+
throw Error('Can not request signature. Signature not produced yet.');
|
|
152
|
+
}
|
|
153
|
+
return this._signature;
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* Ends the DSG session by freeing any heap allocations from wasm. Note that the session is freed if a signature is produced.
|
|
157
|
+
*/
|
|
158
|
+
endSession() {
|
|
159
|
+
if (this._signature) {
|
|
160
|
+
new Error('Session already ended because combined signature was produced.');
|
|
161
|
+
}
|
|
162
|
+
if (this.dsgSession) {
|
|
163
|
+
this.dsgSession.free();
|
|
164
|
+
}
|
|
165
|
+
this.dsgState = types_1.DsgState.Uninitialized;
|
|
166
|
+
}
|
|
167
|
+
/**
|
|
168
|
+
* Proccesses incoming messages to this party in the DKLs DSG protocol and
|
|
169
|
+
* produces messages from this party to other parties for the next round.
|
|
170
|
+
* @param messagesForIthRound - messages to process the current round
|
|
171
|
+
* @returns {DeserializedMessages} - messages to send to other parties for the next round
|
|
172
|
+
*/
|
|
173
|
+
handleIncomingMessages(messagesForIthRound) {
|
|
174
|
+
let nextRoundMessages = [];
|
|
175
|
+
let nextRoundDeserializedMessages = { broadcastMessages: [], p2pMessages: [] };
|
|
176
|
+
this._restoreSession();
|
|
177
|
+
if (!this.dsgSession) {
|
|
178
|
+
throw Error('Session not initialized');
|
|
179
|
+
}
|
|
180
|
+
const { Message } = this.getDklsWasm();
|
|
181
|
+
try {
|
|
182
|
+
if (this.dsgState === types_1.DsgState.Round4) {
|
|
183
|
+
this.dsgState = types_1.DsgState.Complete;
|
|
184
|
+
const combineResult = this.dsgSession.combine(messagesForIthRound.broadcastMessages.map((m) => new Message(m.payload, m.from, undefined)));
|
|
185
|
+
this._signature = {
|
|
186
|
+
R: combineResult[0],
|
|
187
|
+
S: combineResult[1],
|
|
188
|
+
};
|
|
189
|
+
return { broadcastMessages: [], p2pMessages: [] };
|
|
190
|
+
}
|
|
191
|
+
else {
|
|
192
|
+
nextRoundMessages = this.dsgSession.handleMessages(messagesForIthRound.broadcastMessages
|
|
193
|
+
.map((m) => new Message(m.payload, m.from, undefined))
|
|
194
|
+
.concat(messagesForIthRound.p2pMessages.map((m) => new Message(m.payload, m.from, m.to))));
|
|
195
|
+
}
|
|
196
|
+
if (this.dsgState === types_1.DsgState.Round3) {
|
|
197
|
+
nextRoundMessages = [this.dsgSession.lastMessage(this.messageHash)];
|
|
198
|
+
this.dsgState = types_1.DsgState.Round4;
|
|
199
|
+
return {
|
|
200
|
+
broadcastMessages: [
|
|
201
|
+
{
|
|
202
|
+
payload: nextRoundMessages[0].payload,
|
|
203
|
+
from: nextRoundMessages[0].from_id,
|
|
204
|
+
signatureR: (0, cbor_x_1.decode)(this.dsgSession.toBytes()).round.WaitMsg4.r,
|
|
205
|
+
},
|
|
206
|
+
],
|
|
207
|
+
p2pMessages: [],
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
else {
|
|
211
|
+
// Update round data.
|
|
212
|
+
this._deserializeState();
|
|
213
|
+
}
|
|
214
|
+
nextRoundDeserializedMessages = {
|
|
215
|
+
p2pMessages: nextRoundMessages
|
|
216
|
+
.filter((m) => m.to_id !== undefined)
|
|
217
|
+
.map((m) => {
|
|
218
|
+
if (m.to_id === undefined) {
|
|
219
|
+
throw Error('Invalid P2P message, missing to_id.');
|
|
220
|
+
}
|
|
221
|
+
const p2pReturn = {
|
|
222
|
+
payload: m.payload,
|
|
223
|
+
from: m.from_id,
|
|
224
|
+
to: m.to_id,
|
|
225
|
+
};
|
|
226
|
+
return p2pReturn;
|
|
227
|
+
}),
|
|
228
|
+
broadcastMessages: nextRoundMessages
|
|
229
|
+
.filter((m) => m.to_id === undefined)
|
|
230
|
+
.map((m) => {
|
|
231
|
+
const broadcastReturn = {
|
|
232
|
+
payload: m.payload,
|
|
233
|
+
from: m.from_id,
|
|
234
|
+
};
|
|
235
|
+
return broadcastReturn;
|
|
236
|
+
}),
|
|
237
|
+
};
|
|
238
|
+
}
|
|
239
|
+
catch (e) {
|
|
240
|
+
if (e.message.startsWith('Abort the protocol and ban')) {
|
|
241
|
+
throw Error('Signing aborted. Please stop all transaction signing from this wallet and contact support@bitgo.com.');
|
|
242
|
+
}
|
|
243
|
+
throw Error(`Error while creating messages from party ${this.partyIdx}, round ${this.dsgState}: ${e}`);
|
|
244
|
+
}
|
|
245
|
+
finally {
|
|
246
|
+
nextRoundMessages.forEach((m) => m.free());
|
|
247
|
+
// Session is freed when combine is called.
|
|
248
|
+
if (this.dsgState !== types_1.DsgState.Complete) {
|
|
249
|
+
this.dsgSessionBytes = this.dsgSession.toBytes();
|
|
250
|
+
this.dsgSession = undefined;
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
return nextRoundDeserializedMessages;
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
exports.Dsg = Dsg;
|
|
257
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dsg.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/dsg.ts"],"names":[],"mappings":"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","sourcesContent":["import { Message, SignSession } from '@silencelaboratories/dkls-wasm-ll-node';\nimport { DeserializedBroadcastMessage, DeserializedDklsSignature, DeserializedMessages, DsgState } from './types';\nimport { decode } from 'cbor-x';\n\ntype NodeWasmer = typeof import('@silencelaboratories/dkls-wasm-ll-node');\ntype WebWasmer = typeof import('@silencelaboratories/dkls-wasm-ll-web');\ntype BundlerWasmer = typeof import('@silencelaboratories/dkls-wasm-ll-bundler');\n\ntype DklsWasm = NodeWasmer | WebWasmer | BundlerWasmer;\n\nexport class Dsg {\n  protected dsgSession: SignSession | undefined;\n  protected dsgSessionBytes: Uint8Array;\n  private _signature: DeserializedDklsSignature | undefined;\n  protected keyShareBytes: Buffer;\n  protected messageHash: Buffer;\n  protected derivationPath: string;\n  protected partyIdx: number;\n  protected dsgState: DsgState = DsgState.Uninitialized;\n  protected dklsWasm: DklsWasm | null;\n\n  constructor(\n    keyShare: Buffer,\n    partyIdx: number,\n    derivationPath: string,\n    messageHash: Buffer,\n    dklsWasm?: BundlerWasmer\n  ) {\n    this.partyIdx = partyIdx;\n    this.keyShareBytes = keyShare;\n    this.derivationPath = derivationPath;\n    this.messageHash = messageHash;\n    this.dklsWasm = dklsWasm ?? null;\n  }\n\n  private _restoreSession() {\n    if (!this.dsgSession) {\n      this.dsgSession = this.getDklsWasm().SignSession.fromBytes(this.dsgSessionBytes);\n    }\n  }\n\n  private _deserializeState() {\n    if (!this.dsgSession) {\n      throw Error('Session not intialized');\n    }\n    const round = decode(this.dsgSession.toBytes()).round;\n    switch (round) {\n      case 'WaitMsg1':\n        this.dsgState = DsgState.Round1;\n        break;\n      case 'WaitMsg2':\n        this.dsgState = DsgState.Round2;\n        break;\n      case 'WaitMsg3':\n        this.dsgState = DsgState.Round3;\n        break;\n      case 'Ended':\n        this.dsgState = DsgState.Complete;\n        break;\n      default:\n        this.dsgState = DsgState.InvalidState;\n        throw Error(`Invalid State: ${round}`);\n    }\n  }\n\n  private async loadDklsWasm(): Promise<void> {\n    if (!this.dklsWasm) {\n      this.dklsWasm = await import('@silencelaboratories/dkls-wasm-ll-node');\n    }\n  }\n\n  private getDklsWasm() {\n    if (!this.dklsWasm) {\n      throw Error('DKLS wasm not loaded');\n    }\n\n    return this.dklsWasm;\n  }\n\n  /**\n   * Returns the current DSG session as a base64 string.\n   * @returns {string} - base64 string of the current DSG session\n   */\n  getSession(): string {\n    return Buffer.from(this.dsgSessionBytes).toString('base64');\n  }\n\n  /**\n   * Sets the DSG session from a base64 string.\n   * @param {string} session - base64 string of the DSG session\n   */\n  async setSession(session: string): Promise<void> {\n    this.dsgSession = undefined;\n    if (!this.dklsWasm) {\n      await this.loadDklsWasm();\n    }\n    const sessionBytes = new Uint8Array(Buffer.from(session, 'base64'));\n    const round = decode(sessionBytes).round;\n    switch (true) {\n      case round === 'WaitMsg1':\n        this.dsgState = DsgState.Round1;\n        break;\n      case round === 'WaitMsg2':\n        this.dsgState = DsgState.Round2;\n        break;\n      case round === 'WaitMsg3':\n        this.dsgState = DsgState.Round3;\n        break;\n      case 'WaitMsg4' in round:\n        this.dsgState = DsgState.Round4;\n        break;\n      default:\n        throw Error(`Invalid State: ${round}`);\n    }\n    this.dsgSessionBytes = sessionBytes;\n  }\n\n  async init(): Promise<DeserializedBroadcastMessage> {\n    if (this.dsgState !== DsgState.Uninitialized) {\n      throw Error('DSG session already initialized');\n    }\n    if (!this.dklsWasm) {\n      await this.loadDklsWasm();\n    }\n    if (\n      typeof window !== 'undefined' &&\n      /* checks for electron processes */\n      !window.process &&\n      !window.process?.['type']\n    ) {\n      /* This is only needed for browsers/web because it uses fetch to resolve the wasm asset for the web */\n      const initDkls = await import('@silencelaboratories/dkls-wasm-ll-web');\n      await initDkls.default();\n    }\n    const { Keyshare, SignSession } = this.getDklsWasm();\n    const keyShare = Keyshare.fromBytes(this.keyShareBytes);\n    if (keyShare.partyId !== this.partyIdx) {\n      throw Error(`Party index: ${this.partyIdx} does not match key share partyId: ${keyShare.partyId} `);\n    }\n    this.dsgSession = new SignSession(keyShare, this.derivationPath);\n    try {\n      const payload = this.dsgSession.createFirstMessage().payload;\n      this._deserializeState();\n      this.dsgSessionBytes = this.dsgSession.toBytes();\n      this.dsgSession = undefined;\n      return {\n        payload: payload,\n        from: this.partyIdx,\n      };\n    } catch (e) {\n      throw Error(`Error while creating the first message from party ${this.partyIdx}: ${e}`);\n    }\n  }\n\n  get signature(): DeserializedDklsSignature {\n    if (!this._signature) {\n      throw Error('Can not request signature. Signature not produced yet.');\n    }\n    return this._signature;\n  }\n\n  /**\n   * Ends the DSG session by freeing any heap allocations from wasm. Note that the session is freed if a signature is produced.\n   */\n  endSession(): void {\n    if (this._signature) {\n      new Error('Session already ended because combined signature was produced.');\n    }\n    if (this.dsgSession) {\n      this.dsgSession.free();\n    }\n    this.dsgState = DsgState.Uninitialized;\n  }\n\n  /**\n   * Proccesses incoming messages to this party in the DKLs DSG protocol and\n   * produces messages from this party to other parties for the next round.\n   * @param messagesForIthRound - messages to process the current round\n   * @returns {DeserializedMessages} - messages to send to other parties for the next round\n   */\n  handleIncomingMessages(messagesForIthRound: DeserializedMessages): DeserializedMessages {\n    let nextRoundMessages: Message[] = [];\n    let nextRoundDeserializedMessages: DeserializedMessages = { broadcastMessages: [], p2pMessages: [] };\n    this._restoreSession();\n    if (!this.dsgSession) {\n      throw Error('Session not initialized');\n    }\n    const { Message } = this.getDklsWasm();\n    try {\n      if (this.dsgState === DsgState.Round4) {\n        this.dsgState = DsgState.Complete;\n        const combineResult = this.dsgSession.combine(\n          messagesForIthRound.broadcastMessages.map((m) => new Message(m.payload, m.from, undefined))\n        );\n        this._signature = {\n          R: combineResult[0],\n          S: combineResult[1],\n        };\n        return { broadcastMessages: [], p2pMessages: [] };\n      } else {\n        nextRoundMessages = this.dsgSession.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        );\n      }\n      if (this.dsgState === DsgState.Round3) {\n        nextRoundMessages = [this.dsgSession.lastMessage(this.messageHash)];\n        this.dsgState = DsgState.Round4;\n        return {\n          broadcastMessages: [\n            {\n              payload: nextRoundMessages[0].payload,\n              from: nextRoundMessages[0].from_id,\n              signatureR: decode(this.dsgSession.toBytes()).round.WaitMsg4.r,\n            },\n          ],\n          p2pMessages: [],\n        };\n      } else {\n        // Update round data.\n        this._deserializeState();\n      }\n      nextRoundDeserializedMessages = {\n        p2pMessages: nextRoundMessages\n          .filter((m) => m.to_id !== undefined)\n          .map((m) => {\n            if (m.to_id === undefined) {\n              throw Error('Invalid P2P message, missing to_id.');\n            }\n            const p2pReturn = {\n              payload: m.payload,\n              from: m.from_id,\n              to: m.to_id,\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      if (e.message.startsWith('Abort the protocol and ban')) {\n        throw Error(\n          'Signing aborted. Please stop all transaction signing from this wallet and contact support@bitgo.com.'\n        );\n      }\n      throw Error(`Error while creating messages from party ${this.partyIdx}, round ${this.dsgState}: ${e}`);\n    } finally {\n      nextRoundMessages.forEach((m) => m.free());\n      // Session is freed when combine is called.\n      if (this.dsgState !== DsgState.Complete) {\n        this.dsgSessionBytes = this.dsgSession.toBytes();\n        this.dsgSession = undefined;\n      }\n    }\n    return nextRoundDeserializedMessages;\n  }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,OAAO,CAAC;AACjC,OAAO,KAAK,OAAO,MAAM,OAAO,CAAC;AACjC,OAAO,KAAK,SAAS,MAAM,SAAS,CAAC;AACrC,OAAO,KAAK,SAAS,MAAM,cAAc,CAAC;AAC1C,OAAO,KAAK,SAAS,MAAM,QAAQ,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.DklsUtils = exports.DklsComms = exports.DklsTypes = exports.DklsDsg = exports.DklsDkg = void 0;
|
|
27
|
+
exports.DklsDkg = __importStar(require("./dkg"));
|
|
28
|
+
exports.DklsDsg = __importStar(require("./dsg"));
|
|
29
|
+
exports.DklsTypes = __importStar(require("./types"));
|
|
30
|
+
exports.DklsComms = __importStar(require("./commsLayer"));
|
|
31
|
+
exports.DklsUtils = __importStar(require("./util"));
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHNzL2VjZHNhLWRrbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxpREFBaUM7QUFDakMsaURBQWlDO0FBQ2pDLHFEQUFxQztBQUNyQywwREFBMEM7QUFDMUMsb0RBQW9DIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogYXMgRGtsc0RrZyBmcm9tICcuL2RrZyc7XG5leHBvcnQgKiBhcyBEa2xzRHNnIGZyb20gJy4vZHNnJztcbmV4cG9ydCAqIGFzIERrbHNUeXBlcyBmcm9tICcuL3R5cGVzJztcbmV4cG9ydCAqIGFzIERrbHNDb21tcyBmcm9tICcuL2NvbW1zTGF5ZXInO1xuZXhwb3J0ICogYXMgRGtsc1V0aWxzIGZyb20gJy4vdXRpbCc7XG4iXX0=
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import * as t from 'io-ts';
|
|
3
|
+
import { XShare } from '../ecdsa/types';
|
|
4
|
+
interface BroadcastMessage<T> {
|
|
5
|
+
payload: T;
|
|
6
|
+
from: number;
|
|
7
|
+
signatureR?: T;
|
|
8
|
+
}
|
|
9
|
+
interface P2PMessage<T, G> {
|
|
10
|
+
payload: T;
|
|
11
|
+
from: number;
|
|
12
|
+
commitment?: G;
|
|
13
|
+
to: number;
|
|
14
|
+
}
|
|
15
|
+
export declare enum DkgState {
|
|
16
|
+
Uninitialized = 0,
|
|
17
|
+
Round1 = 1,
|
|
18
|
+
Round2 = 2,
|
|
19
|
+
Round3 = 3,
|
|
20
|
+
Round4 = 4,
|
|
21
|
+
Complete = 5,
|
|
22
|
+
InvalidState = 6
|
|
23
|
+
}
|
|
24
|
+
export declare enum DsgState {
|
|
25
|
+
Uninitialized = 0,
|
|
26
|
+
Round1 = 1,
|
|
27
|
+
Round2 = 2,
|
|
28
|
+
Round3 = 3,
|
|
29
|
+
Round4 = 4,
|
|
30
|
+
Complete = 5,
|
|
31
|
+
InvalidState = 6
|
|
32
|
+
}
|
|
33
|
+
export declare type AuthEncMessage = {
|
|
34
|
+
encryptedMessage: string;
|
|
35
|
+
signature: string;
|
|
36
|
+
};
|
|
37
|
+
export declare type AuthMessage = {
|
|
38
|
+
message: string;
|
|
39
|
+
signature: string;
|
|
40
|
+
};
|
|
41
|
+
export declare type PartyGpgKey = {
|
|
42
|
+
partyId: number;
|
|
43
|
+
gpgKey: string;
|
|
44
|
+
};
|
|
45
|
+
export declare type DklsSignature<T> = {
|
|
46
|
+
R: T;
|
|
47
|
+
S: T;
|
|
48
|
+
};
|
|
49
|
+
export declare type RetrofitData = {
|
|
50
|
+
xShare: Partial<XShare>;
|
|
51
|
+
xiList?: number[][];
|
|
52
|
+
};
|
|
53
|
+
export declare const ReducedKeyShareType: t.TypeC<{
|
|
54
|
+
bigSList: t.ArrayC<t.ArrayC<t.NumberC>>;
|
|
55
|
+
xList: t.ArrayC<t.ArrayC<t.NumberC>>;
|
|
56
|
+
rootChainCode: t.ArrayC<t.NumberC>;
|
|
57
|
+
prv: t.ArrayC<t.NumberC>;
|
|
58
|
+
pub: t.ArrayC<t.NumberC>;
|
|
59
|
+
}>;
|
|
60
|
+
export declare type ReducedKeyShare = t.TypeOf<typeof ReducedKeyShareType>;
|
|
61
|
+
export declare type SerializedBroadcastMessage = BroadcastMessage<string>;
|
|
62
|
+
export declare type DeserializedBroadcastMessage = BroadcastMessage<Uint8Array>;
|
|
63
|
+
export declare type SerializedP2PMessage = P2PMessage<string, string>;
|
|
64
|
+
export declare type DeserializedP2PMessage = P2PMessage<Uint8Array, Uint8Array>;
|
|
65
|
+
export declare type SerializedDklsSignature = DklsSignature<string>;
|
|
66
|
+
export declare type DeserializedDklsSignature = DklsSignature<Uint8Array>;
|
|
67
|
+
export declare type AuthEncP2PMessage = P2PMessage<AuthEncMessage, string>;
|
|
68
|
+
export declare type AuthBroadcastMessage = BroadcastMessage<AuthMessage>;
|
|
69
|
+
export declare type SerializedMessages = {
|
|
70
|
+
p2pMessages: SerializedP2PMessage[];
|
|
71
|
+
broadcastMessages: SerializedBroadcastMessage[];
|
|
72
|
+
};
|
|
73
|
+
export declare type AuthEncMessages = {
|
|
74
|
+
p2pMessages: AuthEncP2PMessage[];
|
|
75
|
+
broadcastMessages: AuthBroadcastMessage[];
|
|
76
|
+
};
|
|
77
|
+
export declare type DeserializedMessages = {
|
|
78
|
+
p2pMessages: DeserializedP2PMessage[];
|
|
79
|
+
broadcastMessages: DeserializedBroadcastMessage[];
|
|
80
|
+
};
|
|
81
|
+
/**
|
|
82
|
+
* Serializes messages payloads to base64 strings.
|
|
83
|
+
* @param messages
|
|
84
|
+
*/
|
|
85
|
+
export declare function serializeMessages(messages: DeserializedMessages): SerializedMessages;
|
|
86
|
+
/**
|
|
87
|
+
* Deserialize messages payloads to Uint8Array.
|
|
88
|
+
* @param messages
|
|
89
|
+
*/
|
|
90
|
+
export declare function deserializeMessages(messages: SerializedMessages): DeserializedMessages;
|
|
91
|
+
/**
|
|
92
|
+
* Deserializes a P2P message.
|
|
93
|
+
* @param message
|
|
94
|
+
*/
|
|
95
|
+
export declare function deserializeP2PMessage(message: SerializedP2PMessage): DeserializedP2PMessage;
|
|
96
|
+
/**
|
|
97
|
+
* Deserializes a Broadcast message.
|
|
98
|
+
* @param message
|
|
99
|
+
*/
|
|
100
|
+
export declare function deserializeBroadcastMessage(message: SerializedBroadcastMessage): DeserializedBroadcastMessage;
|
|
101
|
+
/**
|
|
102
|
+
* Serializes a P2P message.
|
|
103
|
+
* @param message
|
|
104
|
+
*/
|
|
105
|
+
export declare function serializeP2PMessage(message: DeserializedP2PMessage): SerializedP2PMessage;
|
|
106
|
+
/**
|
|
107
|
+
* Serializes a Broadcast message.
|
|
108
|
+
* @param message
|
|
109
|
+
*/
|
|
110
|
+
export declare function serializeBroadcastMessage(message: DeserializedBroadcastMessage): SerializedBroadcastMessage;
|
|
111
|
+
/**
|
|
112
|
+
* Gets commonkeyChain from DKLS keyShare
|
|
113
|
+
* @param {Buffer} keyShare - DKLS keyShare
|
|
114
|
+
* @returns {string} commonKeychain in hex format
|
|
115
|
+
*/
|
|
116
|
+
export declare function getCommonKeychain(keyShare: Buffer): string;
|
|
117
|
+
export declare function getDecodedReducedKeyShare(reducedKeyShare: Buffer | Uint8Array): ReducedKeyShare;
|
|
118
|
+
export {};
|
|
119
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/types.ts"],"names":[],"mappings":";AAEA,OAAO,KAAK,CAAC,MAAM,OAAO,CAAC;AAC3B,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAIxC,UAAU,gBAAgB,CAAC,CAAC;IAC1B,OAAO,EAAE,CAAC,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,CAAC,CAAC;CAChB;AAGD,UAAU,UAAU,CAAC,CAAC,EAAE,CAAC;IACvB,OAAO,EAAE,CAAC,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,CAAC,CAAC;IACf,EAAE,EAAE,MAAM,CAAC;CACZ;AAED,oBAAY,QAAQ;IAClB,aAAa,IAAI;IACjB,MAAM,IAAA;IACN,MAAM,IAAA;IACN,MAAM,IAAA;IACN,MAAM,IAAA;IACN,QAAQ,IAAA;IACR,YAAY,IAAA;CACb;AAED,oBAAY,QAAQ;IAClB,aAAa,IAAA;IACb,MAAM,IAAA;IACN,MAAM,IAAA;IACN,MAAM,IAAA;IACN,MAAM,IAAA;IACN,QAAQ,IAAA;IACR,YAAY,IAAA;CACb;AAED,oBAAY,cAAc,GAAG;IAC3B,gBAAgB,EAAE,MAAM,CAAC;IACzB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AACF,oBAAY,WAAW,GAAG;IACxB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AACF,oBAAY,WAAW,GAAG;IACxB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACF,oBAAY,aAAa,CAAC,CAAC,IAAI;IAC7B,CAAC,EAAE,CAAC,CAAC;IACL,CAAC,EAAE,CAAC,CAAC;CACN,CAAC;AACF,oBAAY,YAAY,GAAG;IACzB,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;IACxB,MAAM,CAAC,EAAE,MAAM,EAAE,EAAE,CAAC;CACrB,CAAC;AAEF,eAAO,MAAM,mBAAmB;;;;;;EAM9B,CAAC;AAEH,oBAAY,eAAe,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,mBAAmB,CAAC,CAAC;AAEnE,oBAAY,0BAA0B,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;AAClE,oBAAY,4BAA4B,GAAG,gBAAgB,CAAC,UAAU,CAAC,CAAC;AACxE,oBAAY,oBAAoB,GAAG,UAAU,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC9D,oBAAY,sBAAsB,GAAG,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;AACxE,oBAAY,uBAAuB,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;AAC5D,oBAAY,yBAAyB,GAAG,aAAa,CAAC,UAAU,CAAC,CAAC;AAClE,oBAAY,iBAAiB,GAAG,UAAU,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC;AACnE,oBAAY,oBAAoB,GAAG,gBAAgB,CAAC,WAAW,CAAC,CAAC;AACjE,oBAAY,kBAAkB,GAAG;IAC/B,WAAW,EAAE,oBAAoB,EAAE,CAAC;IACpC,iBAAiB,EAAE,0BAA0B,EAAE,CAAC;CACjD,CAAC;AACF,oBAAY,eAAe,GAAG;IAC5B,WAAW,EAAE,iBAAiB,EAAE,CAAC;IACjC,iBAAiB,EAAE,oBAAoB,EAAE,CAAC;CAC3C,CAAC;AACF,oBAAY,oBAAoB,GAAG;IACjC,WAAW,EAAE,sBAAsB,EAAE,CAAC;IACtC,iBAAiB,EAAE,4BAA4B,EAAE,CAAC;CACnD,CAAC;AAEF;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,oBAAoB,GAAG,kBAAkB,CAKpF;AAED;;;GAGG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,kBAAkB,GAAG,oBAAoB,CAKtF;AAED;;;GAGG;AACH,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,oBAAoB,GAAG,sBAAsB,CAO3F;AAED;;;GAGG;AACH,wBAAgB,2BAA2B,CAAC,OAAO,EAAE,0BAA0B,GAAG,4BAA4B,CAM7G;AAED;;;GAGG;AACH,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,sBAAsB,GAAG,oBAAoB,CAOzF;AAED;;;GAGG;AACH,wBAAgB,yBAAyB,CAAC,OAAO,EAAE,4BAA4B,GAAG,0BAA0B,CAM3G;AAED;;;;GAIG;AACH,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAO1D;AAED,wBAAgB,yBAAyB,CAAC,eAAe,EAAE,MAAM,GAAG,UAAU,GAAG,eAAe,CAM/F"}
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.getDecodedReducedKeyShare = exports.getCommonKeychain = exports.serializeBroadcastMessage = exports.serializeP2PMessage = exports.deserializeBroadcastMessage = exports.deserializeP2PMessage = exports.deserializeMessages = exports.serializeMessages = exports.ReducedKeyShareType = exports.DsgState = exports.DkgState = void 0;
|
|
30
|
+
const assert_1 = __importDefault(require("assert"));
|
|
31
|
+
const cbor_x_1 = require("cbor-x");
|
|
32
|
+
const t = __importStar(require("io-ts"));
|
|
33
|
+
const Either_1 = require("fp-ts/Either");
|
|
34
|
+
var DkgState;
|
|
35
|
+
(function (DkgState) {
|
|
36
|
+
DkgState[DkgState["Uninitialized"] = 0] = "Uninitialized";
|
|
37
|
+
DkgState[DkgState["Round1"] = 1] = "Round1";
|
|
38
|
+
DkgState[DkgState["Round2"] = 2] = "Round2";
|
|
39
|
+
DkgState[DkgState["Round3"] = 3] = "Round3";
|
|
40
|
+
DkgState[DkgState["Round4"] = 4] = "Round4";
|
|
41
|
+
DkgState[DkgState["Complete"] = 5] = "Complete";
|
|
42
|
+
DkgState[DkgState["InvalidState"] = 6] = "InvalidState";
|
|
43
|
+
})(DkgState = exports.DkgState || (exports.DkgState = {}));
|
|
44
|
+
var DsgState;
|
|
45
|
+
(function (DsgState) {
|
|
46
|
+
DsgState[DsgState["Uninitialized"] = 0] = "Uninitialized";
|
|
47
|
+
DsgState[DsgState["Round1"] = 1] = "Round1";
|
|
48
|
+
DsgState[DsgState["Round2"] = 2] = "Round2";
|
|
49
|
+
DsgState[DsgState["Round3"] = 3] = "Round3";
|
|
50
|
+
DsgState[DsgState["Round4"] = 4] = "Round4";
|
|
51
|
+
DsgState[DsgState["Complete"] = 5] = "Complete";
|
|
52
|
+
DsgState[DsgState["InvalidState"] = 6] = "InvalidState";
|
|
53
|
+
})(DsgState = exports.DsgState || (exports.DsgState = {}));
|
|
54
|
+
exports.ReducedKeyShareType = t.type({
|
|
55
|
+
bigSList: t.array(t.array(t.number)),
|
|
56
|
+
xList: t.array(t.array(t.number)),
|
|
57
|
+
rootChainCode: t.array(t.number),
|
|
58
|
+
prv: t.array(t.number),
|
|
59
|
+
pub: t.array(t.number),
|
|
60
|
+
});
|
|
61
|
+
/**
|
|
62
|
+
* Serializes messages payloads to base64 strings.
|
|
63
|
+
* @param messages
|
|
64
|
+
*/
|
|
65
|
+
function serializeMessages(messages) {
|
|
66
|
+
return {
|
|
67
|
+
p2pMessages: messages.p2pMessages.map(serializeP2PMessage),
|
|
68
|
+
broadcastMessages: messages.broadcastMessages.map(serializeBroadcastMessage),
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
exports.serializeMessages = serializeMessages;
|
|
72
|
+
/**
|
|
73
|
+
* Deserialize messages payloads to Uint8Array.
|
|
74
|
+
* @param messages
|
|
75
|
+
*/
|
|
76
|
+
function deserializeMessages(messages) {
|
|
77
|
+
return {
|
|
78
|
+
p2pMessages: messages.p2pMessages.map(deserializeP2PMessage),
|
|
79
|
+
broadcastMessages: messages.broadcastMessages.map(deserializeBroadcastMessage),
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
exports.deserializeMessages = deserializeMessages;
|
|
83
|
+
/**
|
|
84
|
+
* Deserializes a P2P message.
|
|
85
|
+
* @param message
|
|
86
|
+
*/
|
|
87
|
+
function deserializeP2PMessage(message) {
|
|
88
|
+
return {
|
|
89
|
+
to: message.to,
|
|
90
|
+
from: message.from,
|
|
91
|
+
payload: new Uint8Array(Buffer.from(message.payload, 'base64')),
|
|
92
|
+
commitment: message.commitment ? new Uint8Array(Buffer.from(message.commitment, 'hex')) : undefined,
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
exports.deserializeP2PMessage = deserializeP2PMessage;
|
|
96
|
+
/**
|
|
97
|
+
* Deserializes a Broadcast message.
|
|
98
|
+
* @param message
|
|
99
|
+
*/
|
|
100
|
+
function deserializeBroadcastMessage(message) {
|
|
101
|
+
return {
|
|
102
|
+
from: message.from,
|
|
103
|
+
payload: new Uint8Array(Buffer.from(message.payload, 'base64')),
|
|
104
|
+
signatureR: message.signatureR ? new Uint8Array(Buffer.from(message.signatureR, 'base64')) : undefined,
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
exports.deserializeBroadcastMessage = deserializeBroadcastMessage;
|
|
108
|
+
/**
|
|
109
|
+
* Serializes a P2P message.
|
|
110
|
+
* @param message
|
|
111
|
+
*/
|
|
112
|
+
function serializeP2PMessage(message) {
|
|
113
|
+
return {
|
|
114
|
+
to: message.to,
|
|
115
|
+
from: message.from,
|
|
116
|
+
payload: Buffer.from(message.payload).toString('base64'),
|
|
117
|
+
commitment: message.commitment ? Buffer.from(message.commitment).toString('hex') : undefined,
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
exports.serializeP2PMessage = serializeP2PMessage;
|
|
121
|
+
/**
|
|
122
|
+
* Serializes a Broadcast message.
|
|
123
|
+
* @param message
|
|
124
|
+
*/
|
|
125
|
+
function serializeBroadcastMessage(message) {
|
|
126
|
+
return {
|
|
127
|
+
from: message.from,
|
|
128
|
+
payload: Buffer.from(message.payload).toString('base64'),
|
|
129
|
+
signatureR: message.signatureR ? Buffer.from(message.signatureR).toString('base64') : undefined,
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
exports.serializeBroadcastMessage = serializeBroadcastMessage;
|
|
133
|
+
/**
|
|
134
|
+
* Gets commonkeyChain from DKLS keyShare
|
|
135
|
+
* @param {Buffer} keyShare - DKLS keyShare
|
|
136
|
+
* @returns {string} commonKeychain in hex format
|
|
137
|
+
*/
|
|
138
|
+
function getCommonKeychain(keyShare) {
|
|
139
|
+
const parsedKeyShare = (0, cbor_x_1.decode)(keyShare);
|
|
140
|
+
(0, assert_1.default)(parsedKeyShare.public_key, 'public_key not found in keyShare');
|
|
141
|
+
(0, assert_1.default)(parsedKeyShare.root_chain_code, 'root_chain_code not found in public_key');
|
|
142
|
+
const publicKey = Buffer.from(parsedKeyShare.public_key).toString('hex');
|
|
143
|
+
const rootChainCode = Buffer.from(parsedKeyShare.root_chain_code).toString('hex');
|
|
144
|
+
return publicKey + rootChainCode;
|
|
145
|
+
}
|
|
146
|
+
exports.getCommonKeychain = getCommonKeychain;
|
|
147
|
+
function getDecodedReducedKeyShare(reducedKeyShare) {
|
|
148
|
+
const decoded = exports.ReducedKeyShareType.decode((0, cbor_x_1.decode)(reducedKeyShare));
|
|
149
|
+
if ((0, Either_1.isLeft)(decoded)) {
|
|
150
|
+
throw new Error(`Unable to parse reducedKeyShare: ${decoded.left}`);
|
|
151
|
+
}
|
|
152
|
+
return decoded.right;
|
|
153
|
+
}
|
|
154
|
+
exports.getDecodedReducedKeyShare = getDecodedReducedKeyShare;
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/types.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,oDAA4B;AAC5B,mCAAgC;AAChC,yCAA2B;AAE3B,yCAAsC;AAiBtC,IAAY,QAQX;AARD,WAAY,QAAQ;IAClB,yDAAiB,CAAA;IACjB,2CAAM,CAAA;IACN,2CAAM,CAAA;IACN,2CAAM,CAAA;IACN,2CAAM,CAAA;IACN,+CAAQ,CAAA;IACR,uDAAY,CAAA;AACd,CAAC,EARW,QAAQ,GAAR,gBAAQ,KAAR,gBAAQ,QAQnB;AAED,IAAY,QAQX;AARD,WAAY,QAAQ;IAClB,yDAAa,CAAA;IACb,2CAAM,CAAA;IACN,2CAAM,CAAA;IACN,2CAAM,CAAA;IACN,2CAAM,CAAA;IACN,+CAAQ,CAAA;IACR,uDAAY,CAAA;AACd,CAAC,EARW,QAAQ,GAAR,gBAAQ,KAAR,gBAAQ,QAQnB;AAuBY,QAAA,mBAAmB,GAAG,CAAC,CAAC,IAAI,CAAC;IACxC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IACpC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IACjC,aAAa,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC;IAChC,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC;IACtB,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC;CACvB,CAAC,CAAC;AAyBH;;;GAGG;AACH,SAAgB,iBAAiB,CAAC,QAA8B;IAC9D,OAAO;QACL,WAAW,EAAE,QAAQ,CAAC,WAAW,CAAC,GAAG,CAAC,mBAAmB,CAAC;QAC1D,iBAAiB,EAAE,QAAQ,CAAC,iBAAiB,CAAC,GAAG,CAAC,yBAAyB,CAAC;KAC7E,CAAC;AACJ,CAAC;AALD,8CAKC;AAED;;;GAGG;AACH,SAAgB,mBAAmB,CAAC,QAA4B;IAC9D,OAAO;QACL,WAAW,EAAE,QAAQ,CAAC,WAAW,CAAC,GAAG,CAAC,qBAAqB,CAAC;QAC5D,iBAAiB,EAAE,QAAQ,CAAC,iBAAiB,CAAC,GAAG,CAAC,2BAA2B,CAAC;KAC/E,CAAC;AACJ,CAAC;AALD,kDAKC;AAED;;;GAGG;AACH,SAAgB,qBAAqB,CAAC,OAA6B;IACjE,OAAO;QACL,EAAE,EAAE,OAAO,CAAC,EAAE;QACd,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,OAAO,EAAE,IAAI,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAC/D,UAAU,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;KACpG,CAAC;AACJ,CAAC;AAPD,sDAOC;AAED;;;GAGG;AACH,SAAgB,2BAA2B,CAAC,OAAmC;IAC7E,OAAO;QACL,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,OAAO,EAAE,IAAI,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAC/D,UAAU,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;KACvG,CAAC;AACJ,CAAC;AAND,kEAMC;AAED;;;GAGG;AACH,SAAgB,mBAAmB,CAAC,OAA+B;IACjE,OAAO;QACL,EAAE,EAAE,OAAO,CAAC,EAAE;QACd,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;QACxD,UAAU,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS;KAC7F,CAAC;AACJ,CAAC;AAPD,kDAOC;AAED;;;GAGG;AACH,SAAgB,yBAAyB,CAAC,OAAqC;IAC7E,OAAO;QACL,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;QACxD,UAAU,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS;KAChG,CAAC;AACJ,CAAC;AAND,8DAMC;AAED;;;;GAIG;AACH,SAAgB,iBAAiB,CAAC,QAAgB;IAChD,MAAM,cAAc,GAAG,IAAA,eAAM,EAAC,QAAQ,CAAC,CAAC;IACxC,IAAA,gBAAM,EAAC,cAAc,CAAC,UAAU,EAAE,kCAAkC,CAAC,CAAC;IACtE,IAAA,gBAAM,EAAC,cAAc,CAAC,eAAe,EAAE,yCAAyC,CAAC,CAAC;IAClF,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzE,MAAM,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClF,OAAO,SAAS,GAAG,aAAa,CAAC;AACnC,CAAC;AAPD,8CAOC;AAED,SAAgB,yBAAyB,CAAC,eAAoC;IAC5E,MAAM,OAAO,GAAG,2BAAmB,CAAC,MAAM,CAAC,IAAA,eAAM,EAAC,eAAe,CAAC,CAAC,CAAC;IACpE,IAAI,IAAA,eAAM,EAAC,OAAO,CAAC,EAAE;QACnB,MAAM,IAAI,KAAK,CAAC,oCAAoC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;KACrE;IACD,OAAO,OAAO,CAAC,KAAK,CAAC;AACvB,CAAC;AAND,8DAMC","sourcesContent":["import assert from 'assert';\nimport { decode } from 'cbor-x';\nimport * as t from 'io-ts';\nimport { XShare } from '../ecdsa/types';\nimport { isLeft } from 'fp-ts/Either';\n\n// Broadcast message meant to be sent to multiple parties\ninterface BroadcastMessage<T> {\n  payload: T;\n  from: number;\n  signatureR?: T;\n}\n\n// P2P message meant to be sent to a specific party\ninterface P2PMessage<T, G> {\n  payload: T;\n  from: number;\n  commitment?: G;\n  to: number;\n}\n\nexport enum DkgState {\n  Uninitialized = 0,\n  Round1,\n  Round2,\n  Round3,\n  Round4,\n  Complete,\n  InvalidState,\n}\n\nexport enum DsgState {\n  Uninitialized,\n  Round1,\n  Round2,\n  Round3,\n  Round4,\n  Complete,\n  InvalidState,\n}\n\nexport type AuthEncMessage = {\n  encryptedMessage: string;\n  signature: string;\n};\nexport type AuthMessage = {\n  message: string;\n  signature: string;\n};\nexport type PartyGpgKey = {\n  partyId: number;\n  gpgKey: string;\n};\nexport type DklsSignature<T> = {\n  R: T;\n  S: T;\n};\nexport type RetrofitData = {\n  xShare: Partial<XShare>;\n  xiList?: number[][];\n};\n\nexport const ReducedKeyShareType = t.type({\n  bigSList: t.array(t.array(t.number)),\n  xList: t.array(t.array(t.number)),\n  rootChainCode: t.array(t.number),\n  prv: t.array(t.number),\n  pub: t.array(t.number),\n});\n\nexport type ReducedKeyShare = t.TypeOf<typeof ReducedKeyShareType>;\n\nexport type SerializedBroadcastMessage = BroadcastMessage<string>;\nexport type DeserializedBroadcastMessage = BroadcastMessage<Uint8Array>;\nexport type SerializedP2PMessage = P2PMessage<string, string>;\nexport type DeserializedP2PMessage = P2PMessage<Uint8Array, Uint8Array>;\nexport type SerializedDklsSignature = DklsSignature<string>;\nexport type DeserializedDklsSignature = DklsSignature<Uint8Array>;\nexport type AuthEncP2PMessage = P2PMessage<AuthEncMessage, string>;\nexport type AuthBroadcastMessage = BroadcastMessage<AuthMessage>;\nexport type SerializedMessages = {\n  p2pMessages: SerializedP2PMessage[];\n  broadcastMessages: SerializedBroadcastMessage[];\n};\nexport type AuthEncMessages = {\n  p2pMessages: AuthEncP2PMessage[];\n  broadcastMessages: AuthBroadcastMessage[];\n};\nexport type DeserializedMessages = {\n  p2pMessages: DeserializedP2PMessage[];\n  broadcastMessages: DeserializedBroadcastMessage[];\n};\n\n/**\n * Serializes messages payloads to base64 strings.\n * @param messages\n */\nexport function serializeMessages(messages: DeserializedMessages): SerializedMessages {\n  return {\n    p2pMessages: messages.p2pMessages.map(serializeP2PMessage),\n    broadcastMessages: messages.broadcastMessages.map(serializeBroadcastMessage),\n  };\n}\n\n/**\n * Deserialize messages payloads to Uint8Array.\n * @param messages\n */\nexport function deserializeMessages(messages: SerializedMessages): DeserializedMessages {\n  return {\n    p2pMessages: messages.p2pMessages.map(deserializeP2PMessage),\n    broadcastMessages: messages.broadcastMessages.map(deserializeBroadcastMessage),\n  };\n}\n\n/**\n * Deserializes a P2P message.\n * @param message\n */\nexport function deserializeP2PMessage(message: SerializedP2PMessage): DeserializedP2PMessage {\n  return {\n    to: message.to,\n    from: message.from,\n    payload: new Uint8Array(Buffer.from(message.payload, 'base64')),\n    commitment: message.commitment ? new Uint8Array(Buffer.from(message.commitment, 'hex')) : undefined,\n  };\n}\n\n/**\n * Deserializes a Broadcast message.\n * @param message\n */\nexport function deserializeBroadcastMessage(message: SerializedBroadcastMessage): DeserializedBroadcastMessage {\n  return {\n    from: message.from,\n    payload: new Uint8Array(Buffer.from(message.payload, 'base64')),\n    signatureR: message.signatureR ? new Uint8Array(Buffer.from(message.signatureR, 'base64')) : undefined,\n  };\n}\n\n/**\n * Serializes a P2P message.\n * @param message\n */\nexport function serializeP2PMessage(message: DeserializedP2PMessage): SerializedP2PMessage {\n  return {\n    to: message.to,\n    from: message.from,\n    payload: Buffer.from(message.payload).toString('base64'),\n    commitment: message.commitment ? Buffer.from(message.commitment).toString('hex') : undefined,\n  };\n}\n\n/**\n * Serializes a Broadcast message.\n * @param message\n */\nexport function serializeBroadcastMessage(message: DeserializedBroadcastMessage): SerializedBroadcastMessage {\n  return {\n    from: message.from,\n    payload: Buffer.from(message.payload).toString('base64'),\n    signatureR: message.signatureR ? Buffer.from(message.signatureR).toString('base64') : undefined,\n  };\n}\n\n/**\n * Gets commonkeyChain from DKLS keyShare\n * @param {Buffer} keyShare - DKLS keyShare\n * @returns {string} commonKeychain in hex format\n */\nexport function getCommonKeychain(keyShare: Buffer): string {\n  const parsedKeyShare = decode(keyShare);\n  assert(parsedKeyShare.public_key, 'public_key not found in keyShare');\n  assert(parsedKeyShare.root_chain_code, 'root_chain_code not found in public_key');\n  const publicKey = Buffer.from(parsedKeyShare.public_key).toString('hex');\n  const rootChainCode = Buffer.from(parsedKeyShare.root_chain_code).toString('hex');\n  return publicKey + rootChainCode;\n}\n\nexport function getDecodedReducedKeyShare(reducedKeyShare: Buffer | Uint8Array): ReducedKeyShare {\n  const decoded = ReducedKeyShareType.decode(decode(reducedKeyShare));\n  if (isLeft(decoded)) {\n    throw new Error(`Unable to parse reducedKeyShare: ${decoded.left}`);\n  }\n  return decoded.right;\n}\n"]}
|