@bitgo-beta/account-lib 2.24.1-alpha.49 → 2.24.1-alpha.490

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 (74) hide show
  1. package/README.md +1 -1
  2. package/dist/resources/dot/index.js +6 -2
  3. package/dist/resources/dot/westend.d.ts +1 -1
  4. package/dist/resources/dot/westend.d.ts.map +1 -1
  5. package/dist/resources/dot/westend.js +2 -2
  6. package/dist/resources/dot/westend.ts +1 -1
  7. package/dist/src/index.d.ts +112 -4
  8. package/dist/src/index.d.ts.map +1 -1
  9. package/dist/src/index.js +263 -17
  10. package/dist/src/keyPair/index.js +24 -11
  11. package/dist/src/utils/index.d.ts +1 -0
  12. package/dist/src/utils/index.d.ts.map +1 -1
  13. package/dist/src/utils/index.js +27 -10
  14. package/dist/src/utils/messages/index.d.ts +10 -0
  15. package/dist/src/utils/messages/index.d.ts.map +1 -0
  16. package/dist/src/utils/messages/index.js +30 -0
  17. package/dist/test/resources/ed25519Deriver.d.ts +15 -0
  18. package/dist/test/resources/ed25519Deriver.d.ts.map +1 -0
  19. package/dist/test/resources/ed25519Deriver.js +18 -0
  20. package/dist/test/resources/testTransaction.d.ts +11 -0
  21. package/dist/test/resources/testTransaction.d.ts.map +1 -0
  22. package/dist/test/resources/testTransaction.js +19 -0
  23. package/dist/test/resources/testTransactionBuilder.d.ts +26 -0
  24. package/dist/test/resources/testTransactionBuilder.d.ts.map +1 -0
  25. package/dist/test/resources/testTransactionBuilder.js +47 -0
  26. package/dist/test/unit/coin/baseCoin/transactionBuilder.d.ts +2 -0
  27. package/dist/test/unit/coin/baseCoin/transactionBuilder.d.ts.map +1 -0
  28. package/dist/test/unit/coin/baseCoin/transactionBuilder.js +135 -0
  29. package/dist/test/unit/fixtures.d.ts +16 -0
  30. package/dist/test/unit/fixtures.d.ts.map +1 -0
  31. package/dist/test/unit/fixtures.js +43 -0
  32. package/dist/test/unit/index.d.ts +2 -0
  33. package/dist/test/unit/index.d.ts.map +1 -0
  34. package/dist/test/unit/index.js +13 -0
  35. package/dist/test/unit/keyPair/index.d.ts +2 -0
  36. package/dist/test/unit/keyPair/index.d.ts.map +1 -0
  37. package/dist/test/unit/keyPair/index.js +132 -0
  38. package/dist/test/unit/messageFactory.d.ts +2 -0
  39. package/dist/test/unit/messageFactory.d.ts.map +1 -0
  40. package/dist/test/unit/messageFactory.js +78 -0
  41. package/dist/test/unit/mpc/tss/ecdsa/ecdsa.d.ts +2 -0
  42. package/dist/test/unit/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -0
  43. package/dist/test/unit/mpc/tss/ecdsa/ecdsa.js +333 -0
  44. package/dist/test/unit/mpc/tss/eddsa/eddsa.d.ts +5 -0
  45. package/dist/test/unit/mpc/tss/eddsa/eddsa.d.ts.map +1 -0
  46. package/dist/test/unit/mpc/tss/eddsa/eddsa.js +322 -0
  47. package/dist/test/unit/mpc/tss/fixtures/ecdsa.d.ts +130 -0
  48. package/dist/test/unit/mpc/tss/fixtures/ecdsa.d.ts.map +1 -0
  49. package/dist/test/unit/mpc/tss/fixtures/ecdsa.js +283 -0
  50. package/dist/test/unit/utils/crypto.d.ts +2 -0
  51. package/dist/test/unit/utils/crypto.d.ts.map +1 -0
  52. package/dist/test/unit/utils/crypto.js +60 -0
  53. package/dist/test/unit/utils/ed25519KeyDeriver.d.ts +2 -0
  54. package/dist/test/unit/utils/ed25519KeyDeriver.d.ts.map +1 -0
  55. package/dist/test/unit/utils/ed25519KeyDeriver.js +23 -0
  56. package/dist/test/unit/utils/index.d.ts +2 -0
  57. package/dist/test/unit/utils/index.d.ts.map +1 -0
  58. package/dist/test/unit/utils/index.js +61 -0
  59. package/dist/test/unit/utils/messages/index.d.ts +2 -0
  60. package/dist/test/unit/utils/messages/index.d.ts.map +1 -0
  61. package/dist/test/unit/utils/messages/index.js +51 -0
  62. package/dist/test/unit/verifyMessage.d.ts +2 -0
  63. package/dist/test/unit/verifyMessage.d.ts.map +1 -0
  64. package/dist/test/unit/verifyMessage.js +96 -0
  65. package/dist/tsconfig.tsbuildinfo +1 -43553
  66. package/package.json +78 -32
  67. package/.mocharc.js +0 -10
  68. package/CHANGELOG.md +0 -389
  69. package/DEVELOPER.md +0 -93
  70. package/resources/README.md +0 -17
  71. package/resources/cspr/contract/keys-manager.wasm +0 -0
  72. package/resources/dot/index.ts +0 -2
  73. package/resources/dot/mainnet.ts +0 -2
  74. package/resources/dot/westend.ts +0 -2
@@ -0,0 +1,333 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ /**
40
+ * @prettier
41
+ */
42
+ const assert_1 = __importDefault(require("assert"));
43
+ const crypto_1 = require("crypto");
44
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
45
+ const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
46
+ const sinon = __importStar(require("sinon"));
47
+ const keccak_1 = __importDefault(require("keccak"));
48
+ const ecdsa_1 = require("../fixtures/ecdsa");
49
+ // Need to import and then monkey-patch to make stubbing work with ESM
50
+ const paillierBigintModule = require('paillier-bigint');
51
+ const paillierBigint = paillierBigintModule;
52
+ const schnorrModule = require('@bitgo-beta/sdk-lib-mpc');
53
+ const Schnorr = schnorrModule.Schnorr;
54
+ describe('TSS ECDSA TESTS', function () {
55
+ const MPC = new sdk_core_1.Ecdsa();
56
+ const base = BigInt('0x010000000000000000000000000000000000000000000000000000000000000000'); // 2^256
57
+ let keyShares;
58
+ let commonPublicKey;
59
+ const seed = Buffer.from('c4d1583a0b7b88626b56f0c83ee6df4d95d99cca73893ffb57c5e4411fa1b2b9c87456080e8d3f03462f065688abc28be2d4af3164d593c50b55269b435ea48d', 'hex');
60
+ let A, B, C;
61
+ before(async () => {
62
+ // Direct monkey patching of the module for ESM compatibility
63
+ const originalGenerateRandomKeys = paillierBigint.generateRandomKeys;
64
+ const paillierMock = sinon.stub();
65
+ paillierMock
66
+ .onCall(0)
67
+ .resolves(ecdsa_1.paillerKeys[0])
68
+ .onCall(1)
69
+ .resolves(ecdsa_1.paillerKeys[1])
70
+ .onCall(2)
71
+ .resolves(ecdsa_1.paillerKeys[2])
72
+ .onCall(3)
73
+ .resolves(ecdsa_1.paillerKeys[0])
74
+ .onCall(4)
75
+ .resolves(ecdsa_1.paillerKeys[1])
76
+ .onCall(5)
77
+ .resolves(ecdsa_1.paillerKeys[2]);
78
+ // Replace the function directly on the module
79
+ paillierBigint.generateRandomKeys = paillierMock;
80
+ // Save references to restore later
81
+ paillierMock.originalFn = originalGenerateRandomKeys;
82
+ // Apply the same monkey-patching approach for Schnorr
83
+ const originalCreateSchnorrProof = Schnorr.createSchnorrProof;
84
+ const schnorrProofMock = sinon.stub();
85
+ schnorrProofMock
86
+ .onCall(0)
87
+ .returns(ecdsa_1.schnorrProofs[0])
88
+ .onCall(1)
89
+ .returns(ecdsa_1.schnorrProofs[1])
90
+ .onCall(2)
91
+ .returns(ecdsa_1.schnorrProofs[2])
92
+ .onCall(3)
93
+ .returns(ecdsa_1.schnorrProofs[3])
94
+ .onCall(4)
95
+ .returns(ecdsa_1.schnorrProofs[4])
96
+ .onCall(5)
97
+ .returns(ecdsa_1.schnorrProofs[5]);
98
+ // Replace the function directly on the module
99
+ Schnorr.createSchnorrProof = schnorrProofMock;
100
+ // Save references to restore later
101
+ schnorrProofMock.originalFn = originalCreateSchnorrProof;
102
+ [A, B, C] = await Promise.all([MPC.keyShare(1, 2, 3), MPC.keyShare(2, 2, 3), MPC.keyShare(3, 2, 3)]);
103
+ // Needs to run this serially for testing deterministic key generation
104
+ // to get specific paillier keys to be assigned
105
+ const D = await MPC.keyShare(1, 2, 3, seed);
106
+ const E = await MPC.keyShare(2, 2, 3, seed);
107
+ const F = await MPC.keyShare(3, 2, 3, seed);
108
+ const aKeyCombine = MPC.keyCombine(A.pShare, [B.nShares[1], C.nShares[1]]);
109
+ const bKeyCombine = MPC.keyCombine(B.pShare, [A.nShares[2], C.nShares[2]]);
110
+ const cKeyCombine = MPC.keyCombine(C.pShare, [A.nShares[3], B.nShares[3]]);
111
+ // Shares with specific seeds
112
+ const dKeyCombine = MPC.keyCombine(D.pShare, [E.nShares[1], F.nShares[1]]);
113
+ const eKeyCombine = MPC.keyCombine(E.pShare, [D.nShares[2], F.nShares[2]]);
114
+ const fKeyCombine = MPC.keyCombine(F.pShare, [D.nShares[3], E.nShares[3]]);
115
+ // Shares for derived keys.
116
+ const path = 'm/0/1';
117
+ const aKeyDerive = MPC.keyDerive(A.pShare, [B.nShares[1], C.nShares[1]], path);
118
+ const gKeyCombine = {
119
+ xShare: aKeyDerive.xShare,
120
+ yShares: aKeyCombine.yShares,
121
+ };
122
+ const hKeyCombine = MPC.keyCombine(B.pShare, [aKeyDerive.nShares[2], C.nShares[2]]);
123
+ keyShares = [
124
+ aKeyCombine,
125
+ bKeyCombine,
126
+ cKeyCombine,
127
+ dKeyCombine,
128
+ eKeyCombine,
129
+ fKeyCombine,
130
+ gKeyCombine,
131
+ hKeyCombine,
132
+ ];
133
+ commonPublicKey = aKeyCombine.xShare.y;
134
+ // Adding an explicit assertion to check if the stub was used
135
+ paillierMock.callCount.should.equal(6, 'paillierMock should be called 6 times');
136
+ schnorrProofMock.callCount.should.equal(8, 'schnorrProofMock should be called 6 times');
137
+ // Restore original functions
138
+ paillierBigint.generateRandomKeys = paillierMock.originalFn;
139
+ Schnorr.createSchnorrProof = schnorrProofMock.originalFn;
140
+ });
141
+ describe('Ecdsa Key Generation Test', function () {
142
+ it('should generate keys with correct threshold and share number', async function () {
143
+ for (let index = 0; index < 3; index++) {
144
+ const participantOne = (index % 3) + 1;
145
+ const participantTwo = ((index + 1) % 3) + 1;
146
+ const participantThree = ((index + 2) % 3) + 1;
147
+ keyShares[index].xShare.i.should.equal(participantOne);
148
+ keyShares[index].xShare.y.should.equal(commonPublicKey);
149
+ keyShares[index].xShare.m.should.not.be.Null;
150
+ keyShares[index].xShare.l.should.not.be.Null;
151
+ keyShares[index].xShare.n.should.not.be.Null;
152
+ const chaincode = BigInt('0x' + keyShares[index].xShare.chaincode);
153
+ const isChainCodeValid = chaincode > BigInt(0) && chaincode <= base;
154
+ isChainCodeValid.should.equal(true);
155
+ keyShares[index].yShares[participantTwo].i.should.equal(participantOne);
156
+ keyShares[index].yShares[participantThree].i.should.equal(participantOne);
157
+ keyShares[index].yShares[participantTwo].j.should.equal(participantTwo);
158
+ keyShares[index].yShares[participantThree].j.should.equal(participantThree);
159
+ keyShares[index].yShares[participantTwo].n.should.not.be.Null;
160
+ keyShares[index].yShares[participantThree].n.should.not.be.Null;
161
+ const publicKeyPrefix = keyShares[index].xShare.y.slice(0, 2);
162
+ const isRightPrefix = publicKeyPrefix === '03' || publicKeyPrefix === '02';
163
+ isRightPrefix.should.equal(true);
164
+ }
165
+ });
166
+ it('should generate keyshares with specific seed', async function () {
167
+ // Keys should be deterministic when using seed
168
+ const [, , , D, E, F] = keyShares;
169
+ assert_1.default.deepEqual(D, ecdsa_1.mockDKeyShare);
170
+ assert_1.default.deepEqual(E, ecdsa_1.mockEKeyShare);
171
+ assert_1.default.deepEqual(F, ecdsa_1.mockFKeyShare);
172
+ });
173
+ it('should fail if seed is length less than 64 bytes', async function () {
174
+ await MPC.keyShare(1, 2, 3, (0, crypto_1.randomBytes)(16)).should.be.rejectedWith('Seed must have a length of at least 64 bytes');
175
+ await MPC.keyShare(1, 2, 3, (0, crypto_1.randomBytes)(32)).should.be.rejectedWith('Seed must have a length of at least 64 bytes');
176
+ });
177
+ it('should pass if seed length is greater than 64', async function () {
178
+ const paillierMock = sinon.stub(paillierBigint, 'generateRandomKeys').onCall(0).resolves(ecdsa_1.paillerKeys[0]);
179
+ const seed72Bytes = Buffer.from('4f7e914dc9ec696398675d1544aab61cb7a67662ffcbdb4079ec5d682be565d87c1b2de75c943dec14c96586984860268779498e6732473aed9ed9c2538f50bea0af926bdccc0134', 'hex');
180
+ (await MPC.keyShare(1, 2, 3, seed72Bytes)).pShare.u.length.should.equal(64);
181
+ paillierMock.restore();
182
+ });
183
+ it('should calculate correct chaincode while combining', async function () {
184
+ const keyCombine = MPC.keyCombine(ecdsa_1.mockPShare, ecdsa_1.mockNShares);
185
+ keyCombine.xShare.chaincode.should.equal('fffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc32');
186
+ });
187
+ it('should fail to generate keys with invalid threshold and share number', async function () {
188
+ const invalidConfigs = [
189
+ { index: 1, threshold: 5, numShares: 3 },
190
+ { index: -1, threshold: 2, numShares: 3 },
191
+ { index: 1, threshold: 2, numShares: 1 },
192
+ ];
193
+ for (let index = 0; index < invalidConfigs.length; index++) {
194
+ try {
195
+ await MPC.keyShare(invalidConfigs[index].index, invalidConfigs[index].threshold, invalidConfigs[index].numShares);
196
+ }
197
+ catch (e) {
198
+ e.should.equal('Invalid KeyShare Config');
199
+ }
200
+ }
201
+ });
202
+ it('should derive unhardened child keys', async function () {
203
+ // parent key
204
+ const aKeyCombine = keyShares[0];
205
+ const commonKeychain = aKeyCombine.xShare.y + aKeyCombine.xShare.chaincode;
206
+ for (let index = 0; index < 10; index++) {
207
+ const path = `m/0/0/${index}`;
208
+ const subkey = MPC.keyDerive(A.pShare, [B.nShares[1], C.nShares[1]], path);
209
+ const derive1 = MPC.deriveUnhardened(commonKeychain, path);
210
+ const derive2 = MPC.deriveUnhardened(commonKeychain, path);
211
+ derive1.should.equal(derive2, 'derivation should be deterministic');
212
+ (subkey.xShare.y + subkey.xShare.chaincode).should.equal(derive1, 'subkey common keychain should match derived keychain');
213
+ }
214
+ });
215
+ });
216
+ describe('ECDSA Signing', async function () {
217
+ let config;
218
+ before(() => {
219
+ const [A, B, C, D, E, F, G, H] = keyShares;
220
+ config = [
221
+ { signerOne: A, signerTwo: B },
222
+ { signerOne: A, signerTwo: C },
223
+ { signerOne: B, signerTwo: A },
224
+ { signerOne: B, signerTwo: C },
225
+ { signerOne: C, signerTwo: A },
226
+ { signerOne: C, signerTwo: B },
227
+ // Checks signing with specific seed
228
+ { signerOne: D, signerTwo: E },
229
+ { signerOne: E, signerTwo: F },
230
+ { signerOne: F, signerTwo: D },
231
+ // Checks with specific hashing algorithm
232
+ { signerOne: A, signerTwo: B, hash: 'keccak256' },
233
+ // checks with no hashing
234
+ { signerOne: A, signerTwo: B, shouldHash: false },
235
+ // Checks with derived subkey
236
+ { signerOne: G, signerTwo: H },
237
+ ];
238
+ });
239
+ for (let index = 0; index < 9; index++) {
240
+ it(`should properly sign the message case ${index}`, async function () {
241
+ // Step One
242
+ // signerOne, signerTwo have decided to sign the message
243
+ const signerOne = config[index].signerOne;
244
+ const signerOneIndex = signerOne.xShare.i;
245
+ const signerTwo = config[index].signerTwo;
246
+ const signerTwoIndex = signerTwo.xShare.i;
247
+ const [signerOneToTwoPaillierChallenge, signerTwoToOnePaillierChallenge] = await Promise.all([
248
+ sdk_lib_mpc_1.EcdsaPaillierProof.generateP((0, sdk_core_1.hexToBigInt)(signerOne.yShares[signerTwoIndex].n)),
249
+ sdk_lib_mpc_1.EcdsaPaillierProof.generateP((0, sdk_core_1.hexToBigInt)(signerTwo.yShares[signerOneIndex].n)),
250
+ ]);
251
+ // Step Two
252
+ // First signer generates their range proof challenge.
253
+ const signerOneXShare = MPC.appendChallenge(signerOne.xShare, sdk_lib_mpc_1.EcdsaTypes.serializeNtilde(ecdsa_1.ntildes[index]), sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({ p: signerOneToTwoPaillierChallenge }));
254
+ // Step Three
255
+ // Second signer generates their range proof challenge.
256
+ const signerTwoXShare = MPC.appendChallenge(signerTwo.xShare, sdk_lib_mpc_1.EcdsaTypes.serializeNtilde(ecdsa_1.ntildes[index + 1]), sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({ p: signerTwoToOnePaillierChallenge }));
257
+ const signerTwoChallenge = { ntilde: signerTwoXShare.ntilde, h1: signerTwoXShare.h1, h2: signerTwoXShare.h2 };
258
+ // Step Four
259
+ // First signer receives the challenge from the second signer and appends it to their YShare
260
+ const signerTwoYShare = MPC.appendChallenge(signerOne.yShares[signerTwoIndex], signerTwoChallenge, sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({ p: signerTwoToOnePaillierChallenge }));
261
+ // Step Five
262
+ // Sign Shares are created by one of the participants (signerOne)
263
+ // with its private XShare and YShare corresponding to the other participant (signerTwo)
264
+ // This step produces a private WShare which signerOne saves and KShare which signerOne sends to signerTwo
265
+ const signShares = await MPC.signShare(signerOneXShare, signerTwoYShare);
266
+ // Step Six
267
+ // signerTwo receives the KShare from signerOne and uses it produce private
268
+ // BShare (Beta Share) which signerTwo saves and AShare (Alpha Share)
269
+ // which is sent to signerOne
270
+ const signConvertS21 = await MPC.signConvertStep1({
271
+ xShare: signerTwoXShare,
272
+ yShare: signerTwo.yShares[signerOneIndex], // YShare corresponding to the other participant signerOne
273
+ kShare: signShares.kShare,
274
+ });
275
+ // Step Seven
276
+ // signerOne receives the AShare from signerTwo and signerOne using the private WShare from step two
277
+ // uses it produce private GShare (Gamma Share) and MUShare (Mu Share) which
278
+ // is sent to signerTwo to produce its Gamma Share
279
+ const signConvertS12 = await MPC.signConvertStep2({
280
+ aShare: signConvertS21.aShare,
281
+ wShare: signShares.wShare,
282
+ });
283
+ // Step Eight
284
+ // signerTwo receives the MUShare from signerOne and signerOne using the private BShare from step three
285
+ // uses it produce private GShare (Gamma Share)
286
+ const signConvertS21_2 = await MPC.signConvertStep3({
287
+ muShare: signConvertS12.muShare,
288
+ bShare: signConvertS21.bShare,
289
+ });
290
+ // Step Nine
291
+ // signerOne and signerTwo both have successfully generated GShares and they use
292
+ // the sign combine function to generate their private omicron shares and
293
+ // delta shares which they share to each other
294
+ const [signCombineOne, signCombineTwo] = [
295
+ MPC.signCombine({
296
+ gShare: signConvertS12.gShare,
297
+ signIndex: {
298
+ i: signConvertS12.muShare.i,
299
+ j: signConvertS12.muShare.j,
300
+ },
301
+ }),
302
+ MPC.signCombine({
303
+ gShare: signConvertS21_2.gShare,
304
+ signIndex: {
305
+ i: signConvertS21_2.signIndex.i,
306
+ j: signConvertS21_2.signIndex.j,
307
+ },
308
+ }),
309
+ ];
310
+ const MESSAGE = Buffer.from('TOO MANY SECRETS');
311
+ // Step Ten
312
+ // signerOne and signerTwo shares the delta share from each other
313
+ // and finally signs the message using their private OShare
314
+ // and delta share received from the other signer
315
+ const hashGenerator = (hashType) => {
316
+ return hashType === 'keccak256' ? (0, keccak_1.default)('keccak256') : undefined;
317
+ };
318
+ const [signA, signB] = [
319
+ MPC.sign(MESSAGE, signCombineOne.oShare, signCombineTwo.dShare, hashGenerator(config[index].hash), config[index].shouldHash),
320
+ MPC.sign(MESSAGE, signCombineTwo.oShare, signCombineOne.dShare, hashGenerator(config[index].hash), config[index].shouldHash),
321
+ ];
322
+ // Step Eleven
323
+ // Construct the final signature
324
+ const signature = MPC.constructSignature([signA, signB]);
325
+ // Step Twelve
326
+ // Verify signature
327
+ const isValid = MPC.verify(MESSAGE, signature, hashGenerator(config[index].hash), config[index].shouldHash);
328
+ isValid.should.equal(true);
329
+ });
330
+ }
331
+ });
332
+ });
333
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecdsa.js","sourceRoot":"","sources":["../../../../../../test/unit/mpc/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport assert from 'assert';\nimport { Hash, randomBytes } from 'crypto';\nimport { Ecdsa, ECDSA, hexToBigInt } from '@bitgo-beta/sdk-core';\nimport { EcdsaPaillierProof, EcdsaTypes, SchnorrProof } from '@bitgo-beta/sdk-lib-mpc';\nimport * as sinon from 'sinon';\nimport createKeccakHash from 'keccak';\nimport {\n  schnorrProofs,\n  ntildes,\n  paillerKeys,\n  mockNShares,\n  mockPShare,\n  mockDKeyShare,\n  mockEKeyShare,\n  mockFKeyShare,\n} from '../fixtures/ecdsa';\n\n// Need to import and then monkey-patch to make stubbing work with ESM\nconst paillierBigintModule = require('paillier-bigint');\nconst paillierBigint = paillierBigintModule;\nconst schnorrModule = require('@bitgo-beta/sdk-lib-mpc');\nconst Schnorr = schnorrModule.Schnorr;\n\ndescribe('TSS ECDSA TESTS', function () {\n  const MPC = new Ecdsa();\n  const base = BigInt('0x010000000000000000000000000000000000000000000000000000000000000000'); // 2^256\n  let keyShares: ECDSA.KeyCombined[];\n  let commonPublicKey: string;\n  const seed = Buffer.from(\n    'c4d1583a0b7b88626b56f0c83ee6df4d95d99cca73893ffb57c5e4411fa1b2b9c87456080e8d3f03462f065688abc28be2d4af3164d593c50b55269b435ea48d',\n    'hex',\n  );\n  let A: ECDSA.KeyShare, B: ECDSA.KeyShare, C: ECDSA.KeyShare;\n  before(async () => {\n    // Direct monkey patching of the module for ESM compatibility\n    const originalGenerateRandomKeys = paillierBigint.generateRandomKeys;\n\n    const paillierMock = sinon.stub();\n    paillierMock\n      .onCall(0)\n      .resolves(paillerKeys[0])\n      .onCall(1)\n      .resolves(paillerKeys[1])\n      .onCall(2)\n      .resolves(paillerKeys[2])\n      .onCall(3)\n      .resolves(paillerKeys[0])\n      .onCall(4)\n      .resolves(paillerKeys[1])\n      .onCall(5)\n      .resolves(paillerKeys[2]);\n\n    // Replace the function directly on the module\n    paillierBigint.generateRandomKeys = paillierMock;\n\n    // Save references to restore later\n    (paillierMock as any).originalFn = originalGenerateRandomKeys;\n\n    // Apply the same monkey-patching approach for Schnorr\n    const originalCreateSchnorrProof = Schnorr.createSchnorrProof;\n\n    const schnorrProofMock = sinon.stub();\n    schnorrProofMock\n      .onCall(0)\n      .returns(schnorrProofs[0] as unknown as SchnorrProof)\n      .onCall(1)\n      .returns(schnorrProofs[1] as unknown as SchnorrProof)\n      .onCall(2)\n      .returns(schnorrProofs[2] as unknown as SchnorrProof)\n      .onCall(3)\n      .returns(schnorrProofs[3] as unknown as SchnorrProof)\n      .onCall(4)\n      .returns(schnorrProofs[4] as unknown as SchnorrProof)\n      .onCall(5)\n      .returns(schnorrProofs[5] as unknown as SchnorrProof);\n\n    // Replace the function directly on the module\n    Schnorr.createSchnorrProof = schnorrProofMock;\n\n    // Save references to restore later\n    (schnorrProofMock as any).originalFn = originalCreateSchnorrProof;\n\n    [A, B, C] = await Promise.all([MPC.keyShare(1, 2, 3), MPC.keyShare(2, 2, 3), MPC.keyShare(3, 2, 3)]);\n\n    // Needs to run this serially for testing deterministic key generation\n    // to get specific paillier keys to be assigned\n    const D = await MPC.keyShare(1, 2, 3, seed);\n    const E = await MPC.keyShare(2, 2, 3, seed);\n    const F = await MPC.keyShare(3, 2, 3, seed);\n\n    const aKeyCombine = MPC.keyCombine(A.pShare, [B.nShares[1], C.nShares[1]]);\n    const bKeyCombine = MPC.keyCombine(B.pShare, [A.nShares[2], C.nShares[2]]);\n    const cKeyCombine = MPC.keyCombine(C.pShare, [A.nShares[3], B.nShares[3]]);\n\n    // Shares with specific seeds\n    const dKeyCombine = MPC.keyCombine(D.pShare, [E.nShares[1], F.nShares[1]]);\n    const eKeyCombine = MPC.keyCombine(E.pShare, [D.nShares[2], F.nShares[2]]);\n    const fKeyCombine = MPC.keyCombine(F.pShare, [D.nShares[3], E.nShares[3]]);\n\n    // Shares for derived keys.\n    const path = 'm/0/1';\n    const aKeyDerive = MPC.keyDerive(A.pShare, [B.nShares[1], C.nShares[1]], path);\n    const gKeyCombine: ECDSA.KeyCombined = {\n      xShare: aKeyDerive.xShare,\n      yShares: aKeyCombine.yShares,\n    };\n    const hKeyCombine = MPC.keyCombine(B.pShare, [aKeyDerive.nShares[2], C.nShares[2]]);\n    keyShares = [\n      aKeyCombine,\n      bKeyCombine,\n      cKeyCombine,\n      dKeyCombine,\n      eKeyCombine,\n      fKeyCombine,\n      gKeyCombine,\n      hKeyCombine,\n    ];\n    commonPublicKey = aKeyCombine.xShare.y;\n    // Adding an explicit assertion to check if the stub was used\n    paillierMock.callCount.should.equal(6, 'paillierMock should be called 6 times');\n    schnorrProofMock.callCount.should.equal(8, 'schnorrProofMock should be called 6 times');\n\n    // Restore original functions\n    paillierBigint.generateRandomKeys = (paillierMock as any).originalFn;\n    Schnorr.createSchnorrProof = (schnorrProofMock as any).originalFn;\n  });\n\n  describe('Ecdsa Key Generation Test', function () {\n    it('should generate keys with correct threshold and share number', async function () {\n      for (let index = 0; index < 3; index++) {\n        const participantOne = (index % 3) + 1;\n        const participantTwo = ((index + 1) % 3) + 1;\n        const participantThree = ((index + 2) % 3) + 1;\n        keyShares[index].xShare.i.should.equal(participantOne);\n        keyShares[index].xShare.y.should.equal(commonPublicKey);\n        keyShares[index].xShare.m.should.not.be.Null;\n        keyShares[index].xShare.l.should.not.be.Null;\n        keyShares[index].xShare.n.should.not.be.Null;\n\n        const chaincode = BigInt('0x' + keyShares[index].xShare.chaincode);\n        const isChainCodeValid = chaincode > BigInt(0) && chaincode <= base;\n        isChainCodeValid.should.equal(true);\n\n        keyShares[index].yShares[participantTwo].i.should.equal(participantOne);\n        keyShares[index].yShares[participantThree].i.should.equal(participantOne);\n        keyShares[index].yShares[participantTwo].j.should.equal(participantTwo);\n        keyShares[index].yShares[participantThree].j.should.equal(participantThree);\n        keyShares[index].yShares[participantTwo].n.should.not.be.Null;\n        keyShares[index].yShares[participantThree].n.should.not.be.Null;\n\n        const publicKeyPrefix = keyShares[index].xShare.y.slice(0, 2);\n        const isRightPrefix = publicKeyPrefix === '03' || publicKeyPrefix === '02';\n        isRightPrefix.should.equal(true);\n      }\n    });\n\n    it('should generate keyshares with specific seed', async function () {\n      // Keys should be deterministic when using seed\n      const [, , , D, E, F] = keyShares;\n      assert.deepEqual(D, mockDKeyShare);\n      assert.deepEqual(E, mockEKeyShare);\n      assert.deepEqual(F, mockFKeyShare);\n    });\n\n    it('should fail if seed is length less than 64 bytes', async function () {\n      await MPC.keyShare(1, 2, 3, randomBytes(16)).should.be.rejectedWith(\n        'Seed must have a length of at least 64 bytes',\n      );\n      await MPC.keyShare(1, 2, 3, randomBytes(32)).should.be.rejectedWith(\n        'Seed must have a length of at least 64 bytes',\n      );\n    });\n\n    it('should pass if seed length is greater than 64', async function () {\n      const paillierMock = sinon.stub(paillierBigint, 'generateRandomKeys').onCall(0).resolves(paillerKeys[0]);\n      const seed72Bytes = Buffer.from(\n        '4f7e914dc9ec696398675d1544aab61cb7a67662ffcbdb4079ec5d682be565d87c1b2de75c943dec14c96586984860268779498e6732473aed9ed9c2538f50bea0af926bdccc0134',\n        'hex',\n      );\n      (await MPC.keyShare(1, 2, 3, seed72Bytes)).pShare.u.length.should.equal(64);\n      paillierMock.restore();\n    });\n\n    it('should calculate correct chaincode while combining', async function () {\n      const keyCombine = MPC.keyCombine(mockPShare, mockNShares);\n      keyCombine.xShare.chaincode.should.equal('fffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc32');\n    });\n\n    it('should fail to generate keys with invalid threshold and share number', async function () {\n      const invalidConfigs = [\n        { index: 1, threshold: 5, numShares: 3 },\n        { index: -1, threshold: 2, numShares: 3 },\n        { index: 1, threshold: 2, numShares: 1 },\n      ];\n      for (let index = 0; index < invalidConfigs.length; index++) {\n        try {\n          await MPC.keyShare(\n            invalidConfigs[index].index,\n            invalidConfigs[index].threshold,\n            invalidConfigs[index].numShares,\n          );\n        } catch (e) {\n          e.should.equal('Invalid KeyShare Config');\n        }\n      }\n    });\n\n    it('should derive unhardened child keys', async function () {\n      // parent key\n      const aKeyCombine = keyShares[0];\n      const commonKeychain = aKeyCombine.xShare.y + aKeyCombine.xShare.chaincode;\n\n      for (let index = 0; index < 10; index++) {\n        const path = `m/0/0/${index}`;\n\n        const subkey = MPC.keyDerive(A.pShare, [B.nShares[1], C.nShares[1]], path);\n\n        const derive1: string = MPC.deriveUnhardened(commonKeychain, path);\n        const derive2: string = MPC.deriveUnhardened(commonKeychain, path);\n\n        derive1.should.equal(derive2, 'derivation should be deterministic');\n\n        (subkey.xShare.y + subkey.xShare.chaincode).should.equal(\n          derive1,\n          'subkey common keychain should match derived keychain',\n        );\n      }\n    });\n  });\n\n  describe('ECDSA Signing', async function () {\n    let config: { signerOne: ECDSA.KeyCombined; signerTwo: ECDSA.KeyCombined; hash?: string; shouldHash?: boolean }[];\n\n    before(() => {\n      const [A, B, C, D, E, F, G, H] = keyShares;\n\n      config = [\n        { signerOne: A, signerTwo: B },\n        { signerOne: A, signerTwo: C },\n        { signerOne: B, signerTwo: A },\n        { signerOne: B, signerTwo: C },\n        { signerOne: C, signerTwo: A },\n        { signerOne: C, signerTwo: B },\n\n        // Checks signing with specific seed\n        { signerOne: D, signerTwo: E },\n        { signerOne: E, signerTwo: F },\n        { signerOne: F, signerTwo: D },\n\n        // Checks with specific hashing algorithm\n        { signerOne: A, signerTwo: B, hash: 'keccak256' },\n\n        // checks with no hashing\n        { signerOne: A, signerTwo: B, shouldHash: false },\n\n        // Checks with derived subkey\n        { signerOne: G, signerTwo: H },\n      ];\n    });\n\n    for (let index = 0; index < 9; index++) {\n      it(`should properly sign the message case ${index}`, async function () {\n        // Step One\n        // signerOne, signerTwo have decided to sign the message\n        const signerOne = config[index].signerOne;\n        const signerOneIndex = signerOne.xShare.i;\n        const signerTwo = config[index].signerTwo;\n        const signerTwoIndex = signerTwo.xShare.i;\n\n        const [signerOneToTwoPaillierChallenge, signerTwoToOnePaillierChallenge] = await Promise.all([\n          EcdsaPaillierProof.generateP(hexToBigInt(signerOne.yShares[signerTwoIndex].n)),\n          EcdsaPaillierProof.generateP(hexToBigInt(signerTwo.yShares[signerOneIndex].n)),\n        ]);\n        // Step Two\n        // First signer generates their range proof challenge.\n        const signerOneXShare: ECDSA.XShareWithChallenges = MPC.appendChallenge(\n          signerOne.xShare,\n          EcdsaTypes.serializeNtilde(ntildes[index]),\n          EcdsaTypes.serializePaillierChallenge({ p: signerOneToTwoPaillierChallenge }),\n        );\n\n        // Step Three\n        //  Second signer generates their range proof challenge.\n        const signerTwoXShare: ECDSA.XShareWithChallenges = MPC.appendChallenge(\n          signerTwo.xShare,\n          EcdsaTypes.serializeNtilde(ntildes[index + 1]),\n          EcdsaTypes.serializePaillierChallenge({ p: signerTwoToOnePaillierChallenge }),\n        );\n        const signerTwoChallenge = { ntilde: signerTwoXShare.ntilde, h1: signerTwoXShare.h1, h2: signerTwoXShare.h2 };\n\n        // Step Four\n        // First signer receives the challenge from the second signer and appends it to their YShare\n        const signerTwoYShare: ECDSA.YShareWithChallenges = MPC.appendChallenge(\n          signerOne.yShares[signerTwoIndex],\n          signerTwoChallenge,\n          EcdsaTypes.serializePaillierChallenge({ p: signerTwoToOnePaillierChallenge }),\n        );\n\n        // Step Five\n        // Sign Shares are created by one of the participants (signerOne)\n        // with its private XShare and YShare corresponding to the other participant (signerTwo)\n        // This step produces a private WShare which signerOne saves and KShare which signerOne sends to signerTwo\n        const signShares = await MPC.signShare(signerOneXShare, signerTwoYShare);\n\n        // Step Six\n        // signerTwo receives the KShare from signerOne and uses it produce private\n        // BShare (Beta Share) which signerTwo saves and AShare (Alpha Share)\n        // which is sent to signerOne\n\n        const signConvertS21 = await MPC.signConvertStep1({\n          xShare: signerTwoXShare,\n          yShare: signerTwo.yShares[signerOneIndex], // YShare corresponding to the other participant signerOne\n          kShare: signShares.kShare,\n        });\n\n        // Step Seven\n        // signerOne receives the AShare from signerTwo and signerOne using the private WShare from step two\n        // uses it produce private GShare (Gamma Share) and MUShare (Mu Share) which\n        // is sent to signerTwo to produce its Gamma Share\n        const signConvertS12 = await MPC.signConvertStep2({\n          aShare: signConvertS21.aShare,\n          wShare: signShares.wShare,\n        });\n\n        // Step Eight\n        // signerTwo receives the MUShare from signerOne and signerOne using the private BShare from step three\n        // uses it produce private GShare (Gamma Share)\n        const signConvertS21_2 = await MPC.signConvertStep3({\n          muShare: signConvertS12.muShare,\n          bShare: signConvertS21.bShare,\n        });\n\n        // Step Nine\n        // signerOne and signerTwo both have successfully generated GShares and they use\n        // the sign combine function to generate their private omicron shares and\n        // delta shares which they share to each other\n\n        const [signCombineOne, signCombineTwo] = [\n          MPC.signCombine({\n            gShare: signConvertS12.gShare,\n            signIndex: {\n              i: signConvertS12.muShare.i,\n              j: signConvertS12.muShare.j,\n            },\n          }),\n          MPC.signCombine({\n            gShare: signConvertS21_2.gShare,\n            signIndex: {\n              i: signConvertS21_2.signIndex.i,\n              j: signConvertS21_2.signIndex.j,\n            },\n          }),\n        ];\n\n        const MESSAGE = Buffer.from('TOO MANY SECRETS');\n\n        // Step Ten\n        // signerOne and signerTwo shares the delta share from each other\n        // and finally signs the message using their private OShare\n        // and delta share received from the other signer\n\n        const hashGenerator = (hashType?: string): Hash | undefined => {\n          return hashType === 'keccak256' ? (createKeccakHash('keccak256') as Hash) : undefined;\n        };\n        const [signA, signB] = [\n          MPC.sign(\n            MESSAGE,\n            signCombineOne.oShare,\n            signCombineTwo.dShare,\n            hashGenerator(config[index].hash),\n            config[index].shouldHash,\n          ),\n          MPC.sign(\n            MESSAGE,\n            signCombineTwo.oShare,\n            signCombineOne.dShare,\n            hashGenerator(config[index].hash),\n            config[index].shouldHash,\n          ),\n        ];\n\n        // Step Eleven\n        // Construct the final signature\n\n        const signature = MPC.constructSignature([signA, signB]);\n\n        // Step Twelve\n        // Verify signature\n\n        const isValid = MPC.verify(MESSAGE, signature, hashGenerator(config[index].hash), config[index].shouldHash);\n        isValid.should.equal(true);\n      });\n    }\n  });\n});\n"]}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * @prettier
3
+ */
4
+ import 'should';
5
+ //# sourceMappingURL=eddsa.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"eddsa.d.ts","sourceRoot":"","sources":["../../../../../../test/unit/mpc/tss/eddsa/eddsa.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,QAAQ,CAAC"}