@bitgo-beta/sdk-lib-mpc 8.2.1-alpha.45 → 8.2.1-alpha.450

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.
Files changed (93) hide show
  1. package/dist/src/curves/ed25519.d.ts +0 -1
  2. package/dist/src/curves/ed25519.d.ts.map +1 -1
  3. package/dist/src/curves/ed25519.js +12 -12
  4. package/dist/src/curves/ed25519Bip32HdTree.js +14 -14
  5. package/dist/src/curves/index.js +6 -2
  6. package/dist/src/curves/secp256k1.d.ts +0 -1
  7. package/dist/src/curves/secp256k1.d.ts.map +1 -1
  8. package/dist/src/curves/secp256k1.js +22 -38
  9. package/dist/src/curves/secp256k1Bip32HdTree.js +10 -10
  10. package/dist/src/curves/types.d.ts +2 -3
  11. package/dist/src/curves/types.d.ts.map +1 -1
  12. package/dist/src/curves/util.d.ts +2 -0
  13. package/dist/src/curves/util.d.ts.map +1 -1
  14. package/dist/src/curves/util.js +34 -3
  15. package/dist/src/hashCommitment.d.ts +0 -1
  16. package/dist/src/hashCommitment.d.ts.map +1 -1
  17. package/dist/src/hashCommitment.js +7 -8
  18. package/dist/src/index.d.ts +1 -1
  19. package/dist/src/index.d.ts.map +1 -1
  20. package/dist/src/index.js +24 -10
  21. package/dist/src/openssl/index.js +6 -2
  22. package/dist/src/openssl/openssl.d.ts +1 -2
  23. package/dist/src/openssl/openssl.d.ts.map +1 -1
  24. package/dist/src/openssl/openssl.js +4 -12
  25. package/dist/src/safePrime.d.ts +3 -0
  26. package/dist/src/safePrime.d.ts.map +1 -0
  27. package/dist/src/safePrime.js +19 -0
  28. package/dist/src/schnorrProof.d.ts +0 -1
  29. package/dist/src/schnorrProof.d.ts.map +1 -1
  30. package/dist/src/schnorrProof.js +8 -9
  31. package/dist/src/shamir/index.js +6 -2
  32. package/dist/src/shamir/shamir.js +2 -2
  33. package/dist/src/shamir/types.d.ts +1 -1
  34. package/dist/src/shamir/types.d.ts.map +1 -1
  35. package/dist/src/tss/ecdsa/index.js +23 -9
  36. package/dist/src/tss/ecdsa/paillierproof.js +10 -10
  37. package/dist/src/tss/ecdsa/rangeproof.d.ts +1 -2
  38. package/dist/src/tss/ecdsa/rangeproof.d.ts.map +1 -1
  39. package/dist/src/tss/ecdsa/rangeproof.js +108 -118
  40. package/dist/src/tss/ecdsa/types.d.ts +28 -17
  41. package/dist/src/tss/ecdsa/types.d.ts.map +1 -1
  42. package/dist/src/tss/ecdsa/types.js +29 -31
  43. package/dist/src/tss/ecdsa/zkVProof.d.ts +0 -1
  44. package/dist/src/tss/ecdsa/zkVProof.d.ts.map +1 -1
  45. package/dist/src/tss/ecdsa/zkVProof.js +9 -10
  46. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts +69 -0
  47. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts.map +1 -0
  48. package/dist/src/tss/ecdsa-dkls/commsLayer.js +268 -0
  49. package/dist/src/tss/ecdsa-dkls/dkg.d.ts +62 -0
  50. package/dist/src/tss/ecdsa-dkls/dkg.d.ts.map +1 -0
  51. package/dist/src/tss/ecdsa-dkls/dkg.js +334 -0
  52. package/dist/src/tss/ecdsa-dkls/dsg.d.ts +47 -0
  53. package/dist/src/tss/ecdsa-dkls/dsg.d.ts.map +1 -0
  54. package/dist/src/tss/ecdsa-dkls/dsg.js +271 -0
  55. package/dist/src/tss/ecdsa-dkls/index.d.ts +6 -0
  56. package/dist/src/tss/ecdsa-dkls/index.d.ts.map +1 -0
  57. package/dist/src/tss/ecdsa-dkls/index.js +42 -0
  58. package/dist/src/tss/ecdsa-dkls/types.d.ts +128 -0
  59. package/dist/src/tss/ecdsa-dkls/types.d.ts.map +1 -0
  60. package/dist/src/tss/ecdsa-dkls/types.js +175 -0
  61. package/dist/src/tss/ecdsa-dkls/util.d.ts +26 -0
  62. package/dist/src/tss/ecdsa-dkls/util.d.ts.map +1 -0
  63. package/dist/src/tss/ecdsa-dkls/util.js +276 -0
  64. package/dist/src/tss/eddsa-mps/commsLayer.d.ts +30 -0
  65. package/dist/src/tss/eddsa-mps/commsLayer.d.ts.map +1 -0
  66. package/dist/src/tss/eddsa-mps/commsLayer.js +96 -0
  67. package/dist/src/tss/eddsa-mps/dkg.d.ts +93 -0
  68. package/dist/src/tss/eddsa-mps/dkg.d.ts.map +1 -0
  69. package/dist/src/tss/eddsa-mps/dkg.js +217 -0
  70. package/dist/src/tss/eddsa-mps/index.d.ts +5 -0
  71. package/dist/src/tss/eddsa-mps/index.d.ts.map +1 -0
  72. package/dist/src/tss/eddsa-mps/index.js +41 -0
  73. package/dist/src/tss/eddsa-mps/types.d.ts +44 -0
  74. package/dist/src/tss/eddsa-mps/types.d.ts.map +1 -0
  75. package/dist/src/tss/eddsa-mps/types.js +85 -0
  76. package/dist/src/tss/eddsa-mps/util.d.ts +7 -0
  77. package/dist/src/tss/eddsa-mps/util.d.ts.map +1 -0
  78. package/dist/src/tss/eddsa-mps/util.js +13 -0
  79. package/dist/src/tss/index.d.ts +2 -0
  80. package/dist/src/tss/index.d.ts.map +1 -1
  81. package/dist/src/tss/index.js +8 -2
  82. package/dist/src/types.d.ts +0 -1
  83. package/dist/src/types.d.ts.map +1 -1
  84. package/dist/src/util.d.ts +0 -1
  85. package/dist/src/util.d.ts.map +1 -1
  86. package/dist/src/util.js +21 -22
  87. package/dist/tsconfig.tsbuildinfo +1 -1
  88. package/package.json +28 -5
  89. package/.eslintignore +0 -5
  90. package/CHANGELOG.md +0 -180
  91. package/dist/src/openssl/opensslbytes.d.ts +0 -4
  92. package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
  93. package/dist/src/openssl/opensslbytes.js +0 -20
@@ -0,0 +1,334 @@
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 () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.Dkg = void 0;
37
+ const cbor_x_1 = require("cbor-x");
38
+ const crypto_1 = require("crypto");
39
+ const curves_1 = require("../../curves");
40
+ const util_1 = require("../../util");
41
+ const types_1 = require("./types");
42
+ class Dkg {
43
+ constructor(n, t, partyIdx, seed, retrofitData, dklsWasm) {
44
+ this.dkgState = types_1.DkgState.Uninitialized;
45
+ this.n = n;
46
+ this.t = t;
47
+ this.partyIdx = partyIdx;
48
+ this.chainCodeCommitment = undefined;
49
+ this.retrofitData = retrofitData;
50
+ this.seed = seed;
51
+ this.dklsWasm = dklsWasm ?? null;
52
+ }
53
+ async loadDklsWasm() {
54
+ if (!this.dklsWasm) {
55
+ this.dklsWasm = await Promise.resolve().then(() => __importStar(require('@silencelaboratories/dkls-wasm-ll-node')));
56
+ }
57
+ }
58
+ getDklsWasm() {
59
+ if (!this.dklsWasm) {
60
+ throw Error('DKLS wasm not loaded');
61
+ }
62
+ return this.dklsWasm;
63
+ }
64
+ _restoreSession() {
65
+ if (!this.dkgSession) {
66
+ this.dkgSession = this.getDklsWasm().KeygenSession.fromBytes(this.dkgSessionBytes);
67
+ }
68
+ }
69
+ _createDKLsRetrofitKeyShare() {
70
+ if (this.retrofitData) {
71
+ if (!this.retrofitData.xShare.y || !this.retrofitData.xShare.chaincode || !this.retrofitData.xShare.x) {
72
+ throw Error('xShare must have a public key, private share value, and a chaincode.');
73
+ }
74
+ const xiList = [];
75
+ for (let i = 0; i < this.n; i++) {
76
+ xiList.push(Array.from((0, util_1.bigIntToBufferBE)(BigInt(i + 1), 32)));
77
+ }
78
+ const secp256k1 = new curves_1.Secp256k1Curve();
79
+ const dklsKeyShare = {
80
+ total_parties: this.n,
81
+ threshold: this.t,
82
+ rank_list: new Array(this.n).fill(0),
83
+ party_id: this.partyIdx,
84
+ public_key: Array.from(Buffer.from(this.retrofitData.xShare.y, 'hex')),
85
+ root_chain_code: Array.from(Buffer.from(this.retrofitData.xShare.chaincode, 'hex')),
86
+ final_session_id: Array.from((0, crypto_1.createHash)('sha256')
87
+ .update(Buffer.from(this.retrofitData.xShare.y, 'hex'))
88
+ .update(Buffer.from(this.retrofitData.xShare.chaincode, 'hex'))
89
+ .digest()),
90
+ seed_ot_receivers: new Array(this.n - 1).fill(Array(32832).fill(0)),
91
+ seed_ot_senders: new Array(this.n - 1).fill(Array(32768).fill(0)),
92
+ sent_seed_list: [Array(32).fill(0)],
93
+ rec_seed_list: [Array(32).fill(0)],
94
+ s_i: Array.from(Buffer.from(this.retrofitData.xShare.x, 'hex')),
95
+ // big_s_list is now created internally during the protocol so isn't needed here, however a valid KeyShare object needs to have it.
96
+ // a dummy public key is used to fill big_s_list.
97
+ big_s_list: new Array(this.n).fill(Array.from((0, util_1.bigIntToBufferBE)(secp256k1.basePointMult(BigInt('0x' + this.retrofitData.xShare.x))))),
98
+ x_i_list: this.retrofitData.xiList ? this.retrofitData.xiList : xiList,
99
+ };
100
+ this.dklsKeyShareRetrofitObject = this.getDklsWasm().Keyshare.fromBytes((0, cbor_x_1.encode)(dklsKeyShare));
101
+ }
102
+ }
103
+ _deserializeState() {
104
+ if (!this.dkgSession) {
105
+ throw Error('Session not intialized');
106
+ }
107
+ const round = (0, cbor_x_1.decode)(this.dkgSession.toBytes()).round;
108
+ switch (round) {
109
+ case 'WaitMsg1':
110
+ this.dkgState = types_1.DkgState.Round1;
111
+ break;
112
+ case 'WaitMsg2':
113
+ this.dkgState = types_1.DkgState.Round2;
114
+ break;
115
+ case 'WaitMsg3':
116
+ this.dkgState = types_1.DkgState.Round3;
117
+ break;
118
+ case 'WaitMsg4':
119
+ // keyShareBuff present means keyshare() already ran and freed the session; bytes are frozen at WaitMsg4.
120
+ this.dkgState = this.keyShareBuff ? types_1.DkgState.Complete : types_1.DkgState.Round4;
121
+ break;
122
+ case 'Ended':
123
+ this.dkgState = types_1.DkgState.Complete;
124
+ break;
125
+ default:
126
+ this.dkgState = types_1.DkgState.InvalidState;
127
+ throw Error(`Invalid State: ${round}`);
128
+ }
129
+ }
130
+ async initDkg() {
131
+ if (!this.dklsWasm) {
132
+ await this.loadDklsWasm();
133
+ }
134
+ if (this.t > this.n || this.partyIdx >= this.n) {
135
+ throw Error('Invalid parameters for DKG');
136
+ }
137
+ if (this.dkgState != types_1.DkgState.Uninitialized) {
138
+ throw Error('DKG session already initialized');
139
+ }
140
+ if (typeof window !== 'undefined' &&
141
+ /* checks for electron processes */
142
+ !window.process &&
143
+ !window.process?.['type']) {
144
+ /* This is only needed for browsers/web because it uses fetch to resolve the wasm asset for the web */
145
+ const initDkls = await Promise.resolve().then(() => __importStar(require('@silencelaboratories/dkls-wasm-ll-web')));
146
+ await initDkls.default();
147
+ }
148
+ this._createDKLsRetrofitKeyShare();
149
+ if (this.seed && this.seed.length !== 32) {
150
+ throw Error(`Seed should be 32 bytes, got ${this.seed.length}.`);
151
+ }
152
+ const { KeygenSession } = this.getDklsWasm();
153
+ if (this.dklsKeyShareRetrofitObject) {
154
+ this.dkgSession = this.seed
155
+ ? KeygenSession.initKeyRotation(this.dklsKeyShareRetrofitObject, new Uint8Array(this.seed))
156
+ : KeygenSession.initKeyRotation(this.dklsKeyShareRetrofitObject);
157
+ }
158
+ else {
159
+ this.dkgSession = this.seed
160
+ ? new KeygenSession(this.n, this.t, this.partyIdx, new Uint8Array(this.seed))
161
+ : new KeygenSession(this.n, this.t, this.partyIdx);
162
+ }
163
+ try {
164
+ const payload = this.dkgSession.createFirstMessage().payload;
165
+ this.dkgSessionBytes = this.dkgSession.toBytes();
166
+ this._deserializeState();
167
+ return {
168
+ payload: payload,
169
+ from: this.partyIdx,
170
+ };
171
+ }
172
+ catch (e) {
173
+ throw Error(`Error while creating the first message from party ${this.partyIdx}: ${e}`);
174
+ }
175
+ }
176
+ getKeyShare() {
177
+ if (!this.keyShareBuff) {
178
+ throw Error('Can not get key share, DKG is not complete yet.');
179
+ }
180
+ return this.keyShareBuff;
181
+ }
182
+ /**
183
+ * Returns a CBOR-encoded ReducedKeyShare buffer containing the party's private
184
+ * scalar (s_i) in the `prv` field. This buffer is private key material.
185
+ * The caller encrypts it and stores it as `reducedEncryptedPrv` on the key card QR code.
186
+ */
187
+ getReducedKeyShare() {
188
+ if (!this.keyShareBuff) {
189
+ throw Error('Can not get key share, DKG is not complete yet.');
190
+ }
191
+ const decodedKeyshare = (0, cbor_x_1.decode)(this.keyShareBuff);
192
+ const reducedKeyShare = {
193
+ bigSList: decodedKeyshare.big_s_list,
194
+ xList: decodedKeyshare.x_i_list,
195
+ rootChainCode: decodedKeyshare.root_chain_code,
196
+ prv: decodedKeyshare.s_i,
197
+ pub: decodedKeyshare.public_key,
198
+ };
199
+ const encodedKeyShare = (0, cbor_x_1.encode)(reducedKeyShare);
200
+ return encodedKeyShare;
201
+ }
202
+ handleIncomingMessages(messagesForIthRound) {
203
+ let nextRoundMessages = [];
204
+ let nextRoundDeserializedMessages = { broadcastMessages: [], p2pMessages: [] };
205
+ this._restoreSession();
206
+ if (!this.dkgSession) {
207
+ throw Error('Session not initialized');
208
+ }
209
+ const { Message } = this.getDklsWasm();
210
+ try {
211
+ if (this.dkgState === types_1.DkgState.Round3) {
212
+ const commitmentsUnsorted = messagesForIthRound.p2pMessages
213
+ .map((m) => {
214
+ return { from: m.from, commitment: m.commitment };
215
+ })
216
+ .concat([{ from: this.partyIdx, commitment: this.chainCodeCommitment }]);
217
+ const commitmentsSorted = commitmentsUnsorted
218
+ .sort((a, b) => {
219
+ return a.from - b.from;
220
+ })
221
+ .map((c) => c.commitment);
222
+ nextRoundMessages = this.dkgSession.handleMessages(messagesForIthRound.broadcastMessages
223
+ .map((m) => new Message(m.payload, m.from, undefined))
224
+ .concat(messagesForIthRound.p2pMessages.map((m) => new Message(m.payload, m.from, m.to))), commitmentsSorted);
225
+ }
226
+ else {
227
+ nextRoundMessages = this.dkgSession.handleMessages(messagesForIthRound.broadcastMessages
228
+ .map((m) => new Message(m.payload, m.from, undefined))
229
+ .concat(messagesForIthRound.p2pMessages.map((m) => new Message(m.payload, m.from, m.to))), undefined);
230
+ }
231
+ if (this.dkgState === types_1.DkgState.Round4) {
232
+ this.dkgKeyShare = this.dkgSession.keyshare();
233
+ this.keyShareBuff = Buffer.from(this.dkgKeyShare.toBytes());
234
+ this.dkgKeyShare.free();
235
+ if (this.dklsKeyShareRetrofitObject) {
236
+ this.dklsKeyShareRetrofitObject.free();
237
+ }
238
+ this.dkgState = types_1.DkgState.Complete;
239
+ return { broadcastMessages: [], p2pMessages: [] };
240
+ }
241
+ else {
242
+ // Update round data.
243
+ this._deserializeState();
244
+ }
245
+ if (this.dkgState === types_1.DkgState.Round2) {
246
+ this.chainCodeCommitment = this.dkgSession.calculateChainCodeCommitment();
247
+ }
248
+ nextRoundDeserializedMessages = {
249
+ p2pMessages: nextRoundMessages
250
+ .filter((m) => m.to_id !== undefined)
251
+ .map((m) => {
252
+ const p2pReturn = {
253
+ payload: m.payload,
254
+ from: m.from_id,
255
+ to: m.to_id,
256
+ commitment: this.chainCodeCommitment,
257
+ };
258
+ return p2pReturn;
259
+ }),
260
+ broadcastMessages: nextRoundMessages
261
+ .filter((m) => m.to_id === undefined)
262
+ .map((m) => {
263
+ const broadcastReturn = {
264
+ payload: m.payload,
265
+ from: m.from_id,
266
+ };
267
+ return broadcastReturn;
268
+ }),
269
+ };
270
+ }
271
+ catch (e) {
272
+ throw Error(`Error while creating messages from party ${this.partyIdx}, round ${this.dkgState}: ${e}`);
273
+ }
274
+ finally {
275
+ nextRoundMessages.forEach((m) => m.free());
276
+ // Session is freed when keyshare is called.
277
+ if (this.dkgState !== types_1.DkgState.Complete) {
278
+ this.dkgSessionBytes = this.dkgSession.toBytes();
279
+ this.dkgSession = undefined;
280
+ }
281
+ }
282
+ return nextRoundDeserializedMessages;
283
+ }
284
+ /**
285
+ * Get the current session data that can be used to restore the session later
286
+ * @returns The current session data
287
+ */
288
+ getSessionData() {
289
+ const sessionData = {
290
+ dkgSessionBytes: this.dkgSessionBytes,
291
+ dkgState: this.dkgState,
292
+ };
293
+ if (this.chainCodeCommitment) {
294
+ sessionData.chainCodeCommitment = this.chainCodeCommitment;
295
+ }
296
+ if (this.keyShareBuff) {
297
+ sessionData.keyShareBuff = this.keyShareBuff;
298
+ }
299
+ return sessionData;
300
+ }
301
+ /**
302
+ * Restore a DKG session from previous session data
303
+ * Note: This should not be used for Round 1 as that's the initialization phase
304
+ * @param n Number of parties
305
+ * @param t Threshold
306
+ * @param partyIdx Party index
307
+ * @param sessionData Previous session data
308
+ * @param seed Optional seed
309
+ * @param retrofitData Optional retrofit data
310
+ * @param dklsWasm Optional DKLS wasm instance
311
+ * @returns A new DKG instance with the restored session
312
+ */
313
+ static async restoreSession(n, t, partyIdx, sessionData, seed, retrofitData, dklsWasm) {
314
+ const dkg = new Dkg(n, t, partyIdx, seed, retrofitData, dklsWasm);
315
+ if (!dkg.dklsWasm) {
316
+ await dkg.loadDklsWasm();
317
+ }
318
+ dkg.dkgSessionBytes = sessionData.dkgSessionBytes;
319
+ if (sessionData.chainCodeCommitment) {
320
+ dkg.chainCodeCommitment = sessionData.chainCodeCommitment;
321
+ }
322
+ if (sessionData.keyShareBuff) {
323
+ dkg.keyShareBuff = sessionData.keyShareBuff;
324
+ }
325
+ dkg._restoreSession();
326
+ // Re-derive state from WASM bytes rather than trusting the caller-supplied dkgState.
327
+ // This prevents a tampered or corrupted dkgState from causing handleIncomingMessages()
328
+ // to take the wrong branch (e.g. skipping chain code commitment or calling keyshare() prematurely).
329
+ dkg._deserializeState();
330
+ return dkg;
331
+ }
332
+ }
333
+ exports.Dkg = Dkg;
334
+ //# 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 type { KeygenSession, Keyshare, Message } from '@silencelaboratories/dkls-wasm-ll-node';\nimport { decode, encode } from 'cbor-x';\nimport { createHash } from 'crypto';\nimport { Secp256k1Curve } from '../../curves';\nimport { bigIntToBufferBE } from '../../util';\nimport { DeserializedBroadcastMessage, DeserializedMessages, DkgState, ReducedKeyShare, RetrofitData } from './types';\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 interface DkgSessionData {\n  dkgSessionBytes: Uint8Array;\n  dkgState: DkgState;\n  chainCodeCommitment?: Uint8Array;\n  keyShareBuff?: Buffer;\n}\n\nexport class Dkg {\n  protected dkgSession: KeygenSession | undefined;\n  protected dkgSessionBytes: Uint8Array;\n  protected dkgKeyShare: Keyshare;\n  protected keyShareBuff: Buffer;\n  protected n: number;\n  protected t: number;\n  protected seed: Buffer | undefined;\n  protected chainCodeCommitment: Uint8Array | undefined;\n  protected partyIdx: number;\n  protected dkgState: DkgState = DkgState.Uninitialized;\n  protected dklsKeyShareRetrofitObject: Keyshare | undefined;\n  protected retrofitData: RetrofitData | undefined;\n  protected dklsWasm: DklsWasm | null;\n\n  constructor(\n    n: number,\n    t: number,\n    partyIdx: number,\n    seed?: Buffer,\n    retrofitData?: RetrofitData,\n    dklsWasm?: BundlerWasmer\n  ) {\n    this.n = n;\n    this.t = t;\n    this.partyIdx = partyIdx;\n    this.chainCodeCommitment = undefined;\n    this.retrofitData = retrofitData;\n    this.seed = seed;\n    this.dklsWasm = dklsWasm ?? null;\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  private _restoreSession() {\n    if (!this.dkgSession) {\n      this.dkgSession = this.getDklsWasm().KeygenSession.fromBytes(this.dkgSessionBytes);\n    }\n  }\n\n  private _createDKLsRetrofitKeyShare() {\n    if (this.retrofitData) {\n      if (!this.retrofitData.xShare.y || !this.retrofitData.xShare.chaincode || !this.retrofitData.xShare.x) {\n        throw Error('xShare must have a public key, private share value, and a chaincode.');\n      }\n      const xiList: Array<Array<number>> = [];\n      for (let i = 0; i < this.n; i++) {\n        xiList.push(Array.from(bigIntToBufferBE(BigInt(i + 1), 32)));\n      }\n      const secp256k1 = new Secp256k1Curve();\n      const dklsKeyShare = {\n        total_parties: this.n,\n        threshold: this.t,\n        rank_list: new Array(this.n).fill(0),\n        party_id: this.partyIdx,\n        public_key: Array.from(Buffer.from(this.retrofitData.xShare.y, 'hex')),\n        root_chain_code: Array.from(Buffer.from(this.retrofitData.xShare.chaincode, 'hex')),\n        final_session_id: Array.from(\n          createHash('sha256')\n            .update(Buffer.from(this.retrofitData.xShare.y, 'hex'))\n            .update(Buffer.from(this.retrofitData.xShare.chaincode, 'hex'))\n            .digest()\n        ),\n        seed_ot_receivers: new Array(this.n - 1).fill(Array(32832).fill(0)),\n        seed_ot_senders: new Array(this.n - 1).fill(Array(32768).fill(0)),\n        sent_seed_list: [Array(32).fill(0)],\n        rec_seed_list: [Array(32).fill(0)],\n        s_i: Array.from(Buffer.from(this.retrofitData.xShare.x, 'hex')),\n        // big_s_list is now created internally during the protocol so isn't needed here, however a valid KeyShare object needs to have it.\n        // a dummy public key is used to fill big_s_list.\n        big_s_list: new Array(this.n).fill(\n          Array.from(bigIntToBufferBE(secp256k1.basePointMult(BigInt('0x' + this.retrofitData.xShare.x))))\n        ),\n        x_i_list: this.retrofitData.xiList ? this.retrofitData.xiList : xiList,\n      };\n      this.dklsKeyShareRetrofitObject = this.getDklsWasm().Keyshare.fromBytes(encode(dklsKeyShare));\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        // keyShareBuff present means keyshare() already ran and freed the session; bytes are frozen at WaitMsg4.\n        this.dkgState = this.keyShareBuff ? DkgState.Complete : DkgState.Round4;\n        break;\n      case 'Ended':\n        this.dkgState = DkgState.Complete;\n        break;\n      default:\n        this.dkgState = DkgState.InvalidState;\n        throw Error(`Invalid State: ${round}`);\n    }\n  }\n\n  async initDkg(): Promise<DeserializedBroadcastMessage> {\n    if (!this.dklsWasm) {\n      await this.loadDklsWasm();\n    }\n    if (this.t > this.n || this.partyIdx >= this.n) {\n      throw Error('Invalid parameters for DKG');\n    }\n    if (this.dkgState != DkgState.Uninitialized) {\n      throw Error('DKG session already initialized');\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    this._createDKLsRetrofitKeyShare();\n    if (this.seed && this.seed.length !== 32) {\n      throw Error(`Seed should be 32 bytes, got ${this.seed.length}.`);\n    }\n    const { KeygenSession } = this.getDklsWasm();\n    if (this.dklsKeyShareRetrofitObject) {\n      this.dkgSession = this.seed\n        ? KeygenSession.initKeyRotation(this.dklsKeyShareRetrofitObject, new Uint8Array(this.seed))\n        : KeygenSession.initKeyRotation(this.dklsKeyShareRetrofitObject);\n    } else {\n      this.dkgSession = this.seed\n        ? new KeygenSession(this.n, this.t, this.partyIdx, new Uint8Array(this.seed))\n        : new KeygenSession(this.n, this.t, this.partyIdx);\n    }\n    try {\n      const payload = this.dkgSession.createFirstMessage().payload;\n      this.dkgSessionBytes = this.dkgSession.toBytes();\n      this._deserializeState();\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  getKeyShare(): Buffer {\n    if (!this.keyShareBuff) {\n      throw Error('Can not get key share, DKG is not complete yet.');\n    }\n    return this.keyShareBuff;\n  }\n\n  /**\n   * Returns a CBOR-encoded ReducedKeyShare buffer containing the party's private\n   * scalar (s_i) in the `prv` field. This buffer is private key material.\n   * The caller encrypts it and stores it as `reducedEncryptedPrv` on the key card QR code.\n   */\n  getReducedKeyShare(): Buffer {\n    if (!this.keyShareBuff) {\n      throw Error('Can not get key share, DKG is not complete yet.');\n    }\n    const decodedKeyshare = decode(this.keyShareBuff);\n    const reducedKeyShare: ReducedKeyShare = {\n      bigSList: decodedKeyshare.big_s_list,\n      xList: decodedKeyshare.x_i_list,\n      rootChainCode: decodedKeyshare.root_chain_code,\n      prv: decodedKeyshare.s_i,\n      pub: decodedKeyshare.public_key,\n    };\n    const encodedKeyShare = encode(reducedKeyShare);\n    return encodedKeyShare;\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    const { Message } = this.getDklsWasm();\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.keyShareBuff = Buffer.from(this.dkgKeyShare.toBytes());\n        this.dkgKeyShare.free();\n        if (this.dklsKeyShareRetrofitObject) {\n          this.dklsKeyShareRetrofitObject.free();\n        }\n        this.dkgState = DkgState.Complete;\n        return { broadcastMessages: [], p2pMessages: [] };\n      } else {\n        // Update round 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(`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  /**\n   * Get the current session data that can be used to restore the session later\n   * @returns The current session data\n   */\n  getSessionData(): DkgSessionData {\n    const sessionData: DkgSessionData = {\n      dkgSessionBytes: this.dkgSessionBytes,\n      dkgState: this.dkgState,\n    };\n\n    if (this.chainCodeCommitment) {\n      sessionData.chainCodeCommitment = this.chainCodeCommitment;\n    }\n\n    if (this.keyShareBuff) {\n      sessionData.keyShareBuff = this.keyShareBuff;\n    }\n\n    return sessionData;\n  }\n\n  /**\n   * Restore a DKG session from previous session data\n   * Note: This should not be used for Round 1 as that's the initialization phase\n   * @param n Number of parties\n   * @param t Threshold\n   * @param partyIdx Party index\n   * @param sessionData Previous session data\n   * @param seed Optional seed\n   * @param retrofitData Optional retrofit data\n   * @param dklsWasm Optional DKLS wasm instance\n   * @returns A new DKG instance with the restored session\n   */\n  static async restoreSession(\n    n: number,\n    t: number,\n    partyIdx: number,\n    sessionData: DkgSessionData,\n    seed?: Buffer,\n    retrofitData?: RetrofitData,\n    dklsWasm?: BundlerWasmer\n  ): Promise<Dkg> {\n    const dkg = new Dkg(n, t, partyIdx, seed, retrofitData, dklsWasm);\n\n    if (!dkg.dklsWasm) {\n      await dkg.loadDklsWasm();\n    }\n\n    dkg.dkgSessionBytes = sessionData.dkgSessionBytes;\n\n    if (sessionData.chainCodeCommitment) {\n      dkg.chainCodeCommitment = sessionData.chainCodeCommitment;\n    }\n\n    if (sessionData.keyShareBuff) {\n      dkg.keyShareBuff = sessionData.keyShareBuff;\n    }\n\n    dkg._restoreSession();\n    // Re-derive state from WASM bytes rather than trusting the caller-supplied dkgState.\n    // This prevents a tampered or corrupted dkgState from causing handleIncomingMessages()\n    // to take the wrong branch (e.g. skipping chain code commitment or calling keyshare() prematurely).\n    dkg._deserializeState();\n    return dkg;\n  }\n}\n"]}
@@ -0,0 +1,47 @@
1
+ import { SignSessionOTVariant } from '@silencelaboratories/dkls-wasm-ll-node';
2
+ import { DeserializedBroadcastMessage, DeserializedDklsSignature, DeserializedMessages, DsgState } from './types';
3
+ type NodeWasmer = typeof import('@silencelaboratories/dkls-wasm-ll-node');
4
+ type WebWasmer = typeof import('@silencelaboratories/dkls-wasm-ll-web');
5
+ type BundlerWasmer = typeof import('@silencelaboratories/dkls-wasm-ll-bundler');
6
+ type DklsWasm = NodeWasmer | WebWasmer | BundlerWasmer;
7
+ export declare class Dsg {
8
+ protected dsgSession: SignSessionOTVariant | undefined;
9
+ protected dsgSessionBytes: Uint8Array;
10
+ private _signature;
11
+ protected keyShareBytes: Buffer;
12
+ protected messageHash: Buffer;
13
+ protected derivationPath: string;
14
+ protected partyIdx: number;
15
+ protected dsgState: DsgState;
16
+ protected dklsWasm: DklsWasm | null;
17
+ constructor(keyShare: Buffer, partyIdx: number, derivationPath: string, messageHash: Buffer, dklsWasm?: BundlerWasmer);
18
+ private _restoreSession;
19
+ private _deserializeState;
20
+ private loadDklsWasm;
21
+ private getDklsWasm;
22
+ /**
23
+ * Returns the current DSG session as a base64 string.
24
+ * @returns {string} - base64 string of the current DSG session
25
+ */
26
+ getSession(): string;
27
+ /**
28
+ * Sets the DSG session from a base64 string.
29
+ * @param {string} session - base64 string of the DSG session
30
+ */
31
+ setSession(session: string): Promise<void>;
32
+ init(): Promise<DeserializedBroadcastMessage>;
33
+ get signature(): DeserializedDklsSignature;
34
+ /**
35
+ * Ends the DSG session by freeing any heap allocations from wasm. Note that the session is freed if a signature is produced.
36
+ */
37
+ endSession(): void;
38
+ /**
39
+ * Proccesses incoming messages to this party in the DKLs DSG protocol and
40
+ * produces messages from this party to other parties for the next round.
41
+ * @param messagesForIthRound - messages to process the current round
42
+ * @returns {DeserializedMessages} - messages to send to other parties for the next round
43
+ */
44
+ handleIncomingMessages(messagesForIthRound: DeserializedMessages): DeserializedMessages;
45
+ }
46
+ export {};
47
+ //# sourceMappingURL=dsg.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dsg.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/dsg.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AACvF,OAAO,EAAE,4BAA4B,EAAE,yBAAyB,EAAE,oBAAoB,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAGlH,KAAK,UAAU,GAAG,cAAc,wCAAwC,CAAC,CAAC;AAC1E,KAAK,SAAS,GAAG,cAAc,uCAAuC,CAAC,CAAC;AACxE,KAAK,aAAa,GAAG,cAAc,2CAA2C,CAAC,CAAC;AAEhF,KAAK,QAAQ,GAAG,UAAU,GAAG,SAAS,GAAG,aAAa,CAAC;AAEvD,qBAAa,GAAG;IACd,SAAS,CAAC,UAAU,EAAE,oBAAoB,GAAG,SAAS,CAAC;IACvD,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC;IACtC,OAAO,CAAC,UAAU,CAAwC;IAC1D,SAAS,CAAC,aAAa,EAAE,MAAM,CAAC;IAChC,SAAS,CAAC,WAAW,EAAE,MAAM,CAAC;IAC9B,SAAS,CAAC,cAAc,EAAE,MAAM,CAAC;IACjC,SAAS,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC3B,SAAS,CAAC,QAAQ,EAAE,QAAQ,CAA0B;IACtD,SAAS,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI,CAAC;gBAGlC,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,MAAM,EAChB,cAAc,EAAE,MAAM,EACtB,WAAW,EAAE,MAAM,EACnB,QAAQ,CAAC,EAAE,aAAa;IAS1B,OAAO,CAAC,eAAe;IAMvB,OAAO,CAAC,iBAAiB;YAqBX,YAAY;IAM1B,OAAO,CAAC,WAAW;IAQnB;;;OAGG;IACH,UAAU,IAAI,MAAM;IAIpB;;;OAGG;IACG,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IA0B1C,IAAI,IAAI,OAAO,CAAC,4BAA4B,CAAC;IAwCnD,IAAI,SAAS,IAAI,yBAAyB,CAKzC;IAED;;OAEG;IACH,UAAU,IAAI,IAAI;IAUlB;;;;;OAKG;IACH,sBAAsB,CAAC,mBAAmB,EAAE,oBAAoB,GAAG,oBAAoB;CAoFxF"}