@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.
- package/README.md +1 -1
- package/dist/resources/dot/index.js +6 -2
- package/dist/resources/dot/westend.d.ts +1 -1
- package/dist/resources/dot/westend.d.ts.map +1 -1
- package/dist/resources/dot/westend.js +2 -2
- package/dist/resources/dot/westend.ts +1 -1
- package/dist/src/index.d.ts +112 -4
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +263 -17
- package/dist/src/keyPair/index.js +24 -11
- package/dist/src/utils/index.d.ts +1 -0
- package/dist/src/utils/index.d.ts.map +1 -1
- package/dist/src/utils/index.js +27 -10
- package/dist/src/utils/messages/index.d.ts +10 -0
- package/dist/src/utils/messages/index.d.ts.map +1 -0
- package/dist/src/utils/messages/index.js +30 -0
- package/dist/test/resources/ed25519Deriver.d.ts +15 -0
- package/dist/test/resources/ed25519Deriver.d.ts.map +1 -0
- package/dist/test/resources/ed25519Deriver.js +18 -0
- package/dist/test/resources/testTransaction.d.ts +11 -0
- package/dist/test/resources/testTransaction.d.ts.map +1 -0
- package/dist/test/resources/testTransaction.js +19 -0
- package/dist/test/resources/testTransactionBuilder.d.ts +26 -0
- package/dist/test/resources/testTransactionBuilder.d.ts.map +1 -0
- package/dist/test/resources/testTransactionBuilder.js +47 -0
- package/dist/test/unit/coin/baseCoin/transactionBuilder.d.ts +2 -0
- package/dist/test/unit/coin/baseCoin/transactionBuilder.d.ts.map +1 -0
- package/dist/test/unit/coin/baseCoin/transactionBuilder.js +135 -0
- package/dist/test/unit/fixtures.d.ts +16 -0
- package/dist/test/unit/fixtures.d.ts.map +1 -0
- package/dist/test/unit/fixtures.js +43 -0
- package/dist/test/unit/index.d.ts +2 -0
- package/dist/test/unit/index.d.ts.map +1 -0
- package/dist/test/unit/index.js +13 -0
- package/dist/test/unit/keyPair/index.d.ts +2 -0
- package/dist/test/unit/keyPair/index.d.ts.map +1 -0
- package/dist/test/unit/keyPair/index.js +132 -0
- package/dist/test/unit/messageFactory.d.ts +2 -0
- package/dist/test/unit/messageFactory.d.ts.map +1 -0
- package/dist/test/unit/messageFactory.js +78 -0
- package/dist/test/unit/mpc/tss/ecdsa/ecdsa.d.ts +2 -0
- package/dist/test/unit/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -0
- package/dist/test/unit/mpc/tss/ecdsa/ecdsa.js +333 -0
- package/dist/test/unit/mpc/tss/eddsa/eddsa.d.ts +5 -0
- package/dist/test/unit/mpc/tss/eddsa/eddsa.d.ts.map +1 -0
- package/dist/test/unit/mpc/tss/eddsa/eddsa.js +322 -0
- package/dist/test/unit/mpc/tss/fixtures/ecdsa.d.ts +130 -0
- package/dist/test/unit/mpc/tss/fixtures/ecdsa.d.ts.map +1 -0
- package/dist/test/unit/mpc/tss/fixtures/ecdsa.js +283 -0
- package/dist/test/unit/utils/crypto.d.ts +2 -0
- package/dist/test/unit/utils/crypto.d.ts.map +1 -0
- package/dist/test/unit/utils/crypto.js +60 -0
- package/dist/test/unit/utils/ed25519KeyDeriver.d.ts +2 -0
- package/dist/test/unit/utils/ed25519KeyDeriver.d.ts.map +1 -0
- package/dist/test/unit/utils/ed25519KeyDeriver.js +23 -0
- package/dist/test/unit/utils/index.d.ts +2 -0
- package/dist/test/unit/utils/index.d.ts.map +1 -0
- package/dist/test/unit/utils/index.js +61 -0
- package/dist/test/unit/utils/messages/index.d.ts +2 -0
- package/dist/test/unit/utils/messages/index.d.ts.map +1 -0
- package/dist/test/unit/utils/messages/index.js +51 -0
- package/dist/test/unit/verifyMessage.d.ts +2 -0
- package/dist/test/unit/verifyMessage.d.ts.map +1 -0
- package/dist/test/unit/verifyMessage.js +96 -0
- package/dist/tsconfig.tsbuildinfo +1 -43553
- package/package.json +78 -32
- package/.mocharc.js +0 -10
- package/CHANGELOG.md +0 -389
- package/DEVELOPER.md +0 -93
- package/resources/README.md +0 -17
- package/resources/cspr/contract/keys-manager.wasm +0 -0
- package/resources/dot/index.ts +0 -2
- package/resources/dot/mainnet.ts +0 -2
- package/resources/dot/westend.ts +0 -2
|
@@ -0,0 +1,322 @@
|
|
|
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
|
+
require("should");
|
|
43
|
+
const assert_1 = __importDefault(require("assert"));
|
|
44
|
+
const bs58 = __importStar(require("bs58"));
|
|
45
|
+
const crypto_1 = require("crypto");
|
|
46
|
+
const sol = __importStar(require("@solana/web3.js"));
|
|
47
|
+
const src_1 = require("../../../../../src");
|
|
48
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
49
|
+
describe('TSS EDDSA key generation and signing', function () {
|
|
50
|
+
let MPC;
|
|
51
|
+
let hdTree;
|
|
52
|
+
before('initialize modules', async function () {
|
|
53
|
+
hdTree = await sdk_core_1.Ed25519BIP32.initialize();
|
|
54
|
+
MPC = await sdk_core_1.Eddsa.initialize(hdTree);
|
|
55
|
+
});
|
|
56
|
+
it('should fail to generate keys with invalid config', function () {
|
|
57
|
+
assert_1.default.throws(() => MPC.keyShare(0, 2, 3), /Invalid KeyShare config/);
|
|
58
|
+
assert_1.default.throws(() => MPC.keyShare(5, 2, 3), /Invalid KeyShare config/);
|
|
59
|
+
});
|
|
60
|
+
it('should sign and verify signature for low number public key', function () {
|
|
61
|
+
// We use little endian encoding. This means that the following value is a number that is shorter than 32 Bytes when
|
|
62
|
+
// leading zeroes are cut off. This is exactly what happened when we passed it to the sodium library for verifying
|
|
63
|
+
// the signature against the public key.
|
|
64
|
+
const y = '991b12a1b41b966a3382db32fe9b7fa9f80433940d0b17a1759f1e45ada83f00';
|
|
65
|
+
const R = 'b14386bb518b675357a4c79d2439166a5fc5a3a0e1c579c7b829eff1e7a7d967';
|
|
66
|
+
const signableHex = '01000307991b12a1b41b966a3382db32fe9b7fa9f80433940d0b17a1759f1e45ada83f0041536a20902b6d253b111fe5abe87757c123c28cc5fe4eb0da11b5857f3f38e65290384154058de76870e94672fc02e5f96f23e99307f08c56073ebea94cbc57d4d6429b650666264cbcdfe6070749d586d32781608958931e9b8d01636c4f320000000000000000000000000000000000000000000000000000000000000000b43af3bab20c3f39ef3c148c85640614a41043eeb306de5996380f10ec105a8e06ddf6e1d765a193d9cbe146ceeb79ac1cb485ed5f5b37913a8cf5857eff00a91073eab4660e8e3a957c7820d52df6338a8c7b60103bf903cb5f82118430922b02040200030c020000005819b217000000000604010502000a0cf40100000000000009';
|
|
67
|
+
const userToBitgoGShare = {
|
|
68
|
+
i: 1,
|
|
69
|
+
y,
|
|
70
|
+
R,
|
|
71
|
+
gamma: 'fcfd96d4ee4f3399b728b3c820a8eed4a6fa496828e84af2756197993b5df30b',
|
|
72
|
+
};
|
|
73
|
+
const bitgoToUserGShare = {
|
|
74
|
+
i: 3,
|
|
75
|
+
y,
|
|
76
|
+
R,
|
|
77
|
+
gamma: '89d5e45641dc93539a32a6651eaae2448db4d44f6d3040a1390beb14d0225c00',
|
|
78
|
+
};
|
|
79
|
+
const signature = MPC.signCombine([userToBitgoGShare, bitgoToUserGShare]);
|
|
80
|
+
const signablePayloadBuffer = Buffer.from(signableHex, 'hex');
|
|
81
|
+
const verificationResult = MPC.verify(signablePayloadBuffer, signature);
|
|
82
|
+
verificationResult.should.be.true();
|
|
83
|
+
});
|
|
84
|
+
it('should generate keys and sign message', function () {
|
|
85
|
+
const A = MPC.keyShare(1, 2, 3);
|
|
86
|
+
const B = MPC.keyShare(2, 2, 3);
|
|
87
|
+
const C = MPC.keyShare(3, 2, 3);
|
|
88
|
+
const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);
|
|
89
|
+
const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);
|
|
90
|
+
const C_combine = MPC.keyCombine(C.uShare, [A.yShares[3], B.yShares[3]]);
|
|
91
|
+
const message = 'MPC on a Friday night';
|
|
92
|
+
const message_buffer = Buffer.from(message);
|
|
93
|
+
const incorrect_message = 'MPC on a Monday night';
|
|
94
|
+
const incorrect_message_buffer = Buffer.from(incorrect_message);
|
|
95
|
+
// signing with A and B
|
|
96
|
+
let A_sign_share = MPC.signShare(message_buffer, A_combine.pShare, [A_combine.jShares[2]]);
|
|
97
|
+
let B_sign_share = MPC.signShare(message_buffer, B_combine.pShare, [B_combine.jShares[1]]);
|
|
98
|
+
let A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [B_sign_share.rShares[1]], [C.yShares[1]]);
|
|
99
|
+
let B_sign = MPC.sign(message_buffer, B_sign_share.xShare, [A_sign_share.rShares[2]], [C.yShares[2]]);
|
|
100
|
+
let signature = MPC.signCombine([A_sign, B_sign]);
|
|
101
|
+
let result = MPC.verify(message_buffer, signature);
|
|
102
|
+
result.should.equal(true);
|
|
103
|
+
let resultTwo = MPC.verify(incorrect_message_buffer, signature);
|
|
104
|
+
resultTwo.should.equal(false);
|
|
105
|
+
// signing with A and C
|
|
106
|
+
A_sign_share = MPC.signShare(message_buffer, A_combine.pShare, [A_combine.jShares[3]]);
|
|
107
|
+
let C_sign_share = MPC.signShare(message_buffer, C_combine.pShare, [C_combine.jShares[1]]);
|
|
108
|
+
A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [C_sign_share.rShares[1]], [B.yShares[1]]);
|
|
109
|
+
let C_sign = MPC.sign(message_buffer, C_sign_share.xShare, [A_sign_share.rShares[3]], [B.yShares[3]]);
|
|
110
|
+
signature = MPC.signCombine([A_sign, C_sign]);
|
|
111
|
+
result = MPC.verify(message_buffer, signature);
|
|
112
|
+
result.should.equal(true);
|
|
113
|
+
resultTwo = MPC.verify(incorrect_message_buffer, signature);
|
|
114
|
+
resultTwo.should.equal(false);
|
|
115
|
+
// signing with B and C
|
|
116
|
+
B_sign_share = MPC.signShare(message_buffer, B_combine.pShare, [B_combine.jShares[3]]);
|
|
117
|
+
C_sign_share = MPC.signShare(message_buffer, C_combine.pShare, [C_combine.jShares[2]]);
|
|
118
|
+
B_sign = MPC.sign(message_buffer, B_sign_share.xShare, [C_sign_share.rShares[2]], [A.yShares[2]]);
|
|
119
|
+
C_sign = MPC.sign(message_buffer, C_sign_share.xShare, [B_sign_share.rShares[3]], [A.yShares[3]]);
|
|
120
|
+
signature = MPC.signCombine([B_sign, C_sign]);
|
|
121
|
+
result = MPC.verify(message_buffer, signature);
|
|
122
|
+
result.should.equal(true);
|
|
123
|
+
resultTwo = MPC.verify(incorrect_message_buffer, signature);
|
|
124
|
+
resultTwo.should.equal(false);
|
|
125
|
+
});
|
|
126
|
+
it('should verify BIP32 subkey signature', function () {
|
|
127
|
+
const path = 'm/0/1/2';
|
|
128
|
+
const A = MPC.keyShare(1, 2, 3);
|
|
129
|
+
const B = MPC.keyShare(2, 2, 3);
|
|
130
|
+
const C = MPC.keyShare(3, 2, 3);
|
|
131
|
+
// Combine shares to common base address.
|
|
132
|
+
const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);
|
|
133
|
+
const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);
|
|
134
|
+
// Party A derives subkey P share and new Y shares.
|
|
135
|
+
const A_subkey = MPC.keyDerive(A.uShare, [B.yShares[1], C.yShares[1]], path);
|
|
136
|
+
// Party B calculates new P share using party A's subkey Y shares.
|
|
137
|
+
const B_subkey = MPC.keyCombine(B.uShare, [A_subkey.yShares[2], C.yShares[2]]);
|
|
138
|
+
// Derive the public subkeychain separately using the common keychain.
|
|
139
|
+
const subkey = hdTree.publicDerive({
|
|
140
|
+
pk: (0, sdk_core_1.bigIntFromBufferLE)(Buffer.from(A_combine.pShare.y, 'hex')),
|
|
141
|
+
chaincode: (0, sdk_core_1.bigIntFromBufferBE)(Buffer.from(A_combine.pShare.chaincode, 'hex')),
|
|
142
|
+
}, path);
|
|
143
|
+
const y = (0, sdk_core_1.bigIntToBufferLE)(subkey.pk, 32).toString('hex');
|
|
144
|
+
const chaincode = (0, sdk_core_1.bigIntToBufferBE)(subkey.chaincode, 32).toString('hex');
|
|
145
|
+
// Verify the keychain in the subkey P shares equals the separately derived public subkeychain.
|
|
146
|
+
A_subkey.pShare.y.should.equal(y);
|
|
147
|
+
A_subkey.pShare.chaincode.should.equal(chaincode);
|
|
148
|
+
B_subkey.pShare.y.should.equal(y);
|
|
149
|
+
B_subkey.pShare.chaincode.should.equal(chaincode);
|
|
150
|
+
const message = 'MPC on a Friday night';
|
|
151
|
+
const message_buffer = Buffer.from(message);
|
|
152
|
+
// Signing with A and B using subkey P shares.
|
|
153
|
+
const A_sign_share = MPC.signShare(message_buffer, A_subkey.pShare, [A_combine.jShares[2]]);
|
|
154
|
+
const B_sign_share = MPC.signShare(message_buffer, B_subkey.pShare, [B_combine.jShares[1]]);
|
|
155
|
+
const A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [B_sign_share.rShares[1]], [C.yShares[1]]);
|
|
156
|
+
const B_sign = MPC.sign(message_buffer, B_sign_share.xShare, [A_sign_share.rShares[2]], [C.yShares[2]]);
|
|
157
|
+
const signature = MPC.signCombine([A_sign, B_sign]);
|
|
158
|
+
const result = MPC.verify(message_buffer, signature);
|
|
159
|
+
result.should.equal(true);
|
|
160
|
+
// Verify the public key in the signature equals the separately derived public subkey.
|
|
161
|
+
signature.y.should.equal(y);
|
|
162
|
+
});
|
|
163
|
+
it('should derive unhardened child keys', function () {
|
|
164
|
+
const A = MPC.keyShare(1, 2, 3);
|
|
165
|
+
const B = MPC.keyShare(2, 2, 3);
|
|
166
|
+
const C = MPC.keyShare(3, 2, 3);
|
|
167
|
+
const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);
|
|
168
|
+
const commonKeychain = A_combine.pShare.y + A_combine.pShare.chaincode;
|
|
169
|
+
for (let index = 0; index < 10; index++) {
|
|
170
|
+
const path = `m/0/0/${index}`;
|
|
171
|
+
const derive1 = MPC.deriveUnhardened(commonKeychain, path);
|
|
172
|
+
const subkey = MPC.keyDerive(A.uShare, [B.yShares[1], C.yShares[1]], path);
|
|
173
|
+
const derive2 = MPC.deriveUnhardened(commonKeychain, path);
|
|
174
|
+
const derivedPk = derive1.slice(0, 64);
|
|
175
|
+
(subkey.pShare.y + subkey.pShare.chaincode).should.equal(derive1);
|
|
176
|
+
derive1.should.equal(derive2, 'derivation should be deterministic');
|
|
177
|
+
const solAddress = bs58.encode(Buffer.from(derivedPk, 'hex'));
|
|
178
|
+
src_1.Sol.Utils.isValidPublicKey(solAddress).should.be.true();
|
|
179
|
+
const solPk = new sol.PublicKey(solAddress);
|
|
180
|
+
solPk.toBuffer().toString('hex').should.equal(derivedPk);
|
|
181
|
+
}
|
|
182
|
+
const rootPath = 'm/0';
|
|
183
|
+
const rootKeychain = MPC.deriveUnhardened(commonKeychain, rootPath);
|
|
184
|
+
const rootPublicKey = Buffer.from(rootKeychain, 'hex').slice(0, 32).toString('hex');
|
|
185
|
+
const solPk = new sol.PublicKey(bs58.encode(Buffer.from(rootPublicKey, 'hex')));
|
|
186
|
+
solPk.toBuffer().toString('hex').should.equal(rootPublicKey);
|
|
187
|
+
});
|
|
188
|
+
it('should derive unhardened valid dot child keys', function () {
|
|
189
|
+
const A = MPC.keyShare(1, 2, 3);
|
|
190
|
+
const B = MPC.keyShare(2, 2, 3);
|
|
191
|
+
const C = MPC.keyShare(3, 2, 3);
|
|
192
|
+
const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);
|
|
193
|
+
const commonKeychain = A_combine.pShare.y + A_combine.pShare.chaincode;
|
|
194
|
+
for (let index = 0; index < 10; index++) {
|
|
195
|
+
const path = `m/0/0/${index}`;
|
|
196
|
+
const derive1 = MPC.deriveUnhardened(commonKeychain, path);
|
|
197
|
+
const derive2 = MPC.deriveUnhardened(commonKeychain, path);
|
|
198
|
+
const derivedPk = Buffer.from(derive1, 'hex').slice(0, 32).toString('hex');
|
|
199
|
+
derive1.should.equal(derive2, 'derivation should be deterministic');
|
|
200
|
+
const pubKeyPair = new src_1.Dot.KeyPair({ pub: derivedPk });
|
|
201
|
+
pubKeyPair.getKeys().pub.should.equal(derivedPk);
|
|
202
|
+
}
|
|
203
|
+
const rootPath = 'm/';
|
|
204
|
+
const rootKeychain = MPC.deriveUnhardened(commonKeychain, rootPath);
|
|
205
|
+
const rootPublicKey = Buffer.from(rootKeychain, 'hex').slice(0, 32).toString('hex');
|
|
206
|
+
const pubKeyPair = new src_1.Dot.KeyPair({ pub: rootPublicKey });
|
|
207
|
+
pubKeyPair.getKeys().pub.should.equal(rootPublicKey);
|
|
208
|
+
});
|
|
209
|
+
it('should fail signing without meeting threshold', function () {
|
|
210
|
+
const A = MPC.keyShare(1, 2, 3);
|
|
211
|
+
const B = MPC.keyShare(2, 2, 3);
|
|
212
|
+
const C = MPC.keyShare(3, 2, 3);
|
|
213
|
+
const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);
|
|
214
|
+
const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);
|
|
215
|
+
const message = 'MPC on a Friday night';
|
|
216
|
+
const message_buffer = Buffer.from(message, 'utf-8');
|
|
217
|
+
const A_sign_share = MPC.signShare(message_buffer, A_combine.pShare, [A_combine.jShares[2]]);
|
|
218
|
+
const B_sign_share = MPC.signShare(message_buffer, B_combine.pShare, [B_combine.jShares[1]]);
|
|
219
|
+
const A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [B_sign_share.rShares[1]]);
|
|
220
|
+
const signature = MPC.signCombine([A_sign]);
|
|
221
|
+
MPC.verify(message_buffer, signature).should.equal(false);
|
|
222
|
+
});
|
|
223
|
+
describe('with specific seed', function () {
|
|
224
|
+
it('should generate keys and sign message', function () {
|
|
225
|
+
const seed = (0, crypto_1.randomBytes)(64);
|
|
226
|
+
const A = MPC.keyShare(1, 2, 3, seed);
|
|
227
|
+
const B = MPC.keyShare(2, 2, 3, seed);
|
|
228
|
+
const C = MPC.keyShare(3, 2, 3, seed);
|
|
229
|
+
// Keys should be deterministic when using seed
|
|
230
|
+
MPC.keyShare(1, 2, 3, seed).should.deepEqual(A);
|
|
231
|
+
MPC.keyShare(2, 2, 3, seed).should.deepEqual(B);
|
|
232
|
+
MPC.keyShare(3, 2, 3, seed).should.deepEqual(C);
|
|
233
|
+
const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);
|
|
234
|
+
const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);
|
|
235
|
+
const C_combine = MPC.keyCombine(C.uShare, [A.yShares[3], B.yShares[3]]);
|
|
236
|
+
const message = 'MPC on a Friday night';
|
|
237
|
+
const message_buffer = Buffer.from(message);
|
|
238
|
+
// signing with A and B
|
|
239
|
+
let A_sign_share = MPC.signShare(message_buffer, A_combine.pShare, [A_combine.jShares[2]], seed);
|
|
240
|
+
let B_sign_share = MPC.signShare(message_buffer, B_combine.pShare, [B_combine.jShares[1]], seed);
|
|
241
|
+
let A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [B_sign_share.rShares[1]], [C.yShares[1]]);
|
|
242
|
+
let B_sign = MPC.sign(message_buffer, B_sign_share.xShare, [A_sign_share.rShares[2]], [C.yShares[2]]);
|
|
243
|
+
let signature = MPC.signCombine([A_sign, B_sign]);
|
|
244
|
+
let result = MPC.verify(message_buffer, signature);
|
|
245
|
+
result.should.equal(true);
|
|
246
|
+
// signing with A and C
|
|
247
|
+
A_sign_share = MPC.signShare(message_buffer, A_combine.pShare, [A_combine.jShares[3]], seed);
|
|
248
|
+
let C_sign_share = MPC.signShare(message_buffer, C_combine.pShare, [C_combine.jShares[1]], seed);
|
|
249
|
+
A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [C_sign_share.rShares[1]], [B.yShares[1]]);
|
|
250
|
+
let C_sign = MPC.sign(message_buffer, C_sign_share.xShare, [A_sign_share.rShares[3]], [B.yShares[3]]);
|
|
251
|
+
signature = MPC.signCombine([A_sign, C_sign]);
|
|
252
|
+
result = MPC.verify(message_buffer, signature);
|
|
253
|
+
result.should.equal(true);
|
|
254
|
+
// signing with B and C
|
|
255
|
+
B_sign_share = MPC.signShare(message_buffer, B_combine.pShare, [B_combine.jShares[3]], seed);
|
|
256
|
+
C_sign_share = MPC.signShare(message_buffer, C_combine.pShare, [C_combine.jShares[2]], seed);
|
|
257
|
+
B_sign = MPC.sign(message_buffer, B_sign_share.xShare, [C_sign_share.rShares[2]], [A.yShares[2]]);
|
|
258
|
+
C_sign = MPC.sign(message_buffer, C_sign_share.xShare, [B_sign_share.rShares[3]], [A.yShares[3]]);
|
|
259
|
+
signature = MPC.signCombine([B_sign, C_sign]);
|
|
260
|
+
result = MPC.verify(message_buffer, signature);
|
|
261
|
+
result.should.equal(true);
|
|
262
|
+
});
|
|
263
|
+
it('should verify BIP32 subkey signature', function () {
|
|
264
|
+
const seed = (0, crypto_1.randomBytes)(64);
|
|
265
|
+
const path = 'm/0/1/2';
|
|
266
|
+
const A = MPC.keyShare(1, 2, 3, seed);
|
|
267
|
+
const B = MPC.keyShare(2, 2, 3, seed);
|
|
268
|
+
const C = MPC.keyShare(3, 2, 3, seed);
|
|
269
|
+
// Keys should be deterministic when using seed
|
|
270
|
+
MPC.keyShare(1, 2, 3, seed).should.deepEqual(A);
|
|
271
|
+
MPC.keyShare(2, 2, 3, seed).should.deepEqual(B);
|
|
272
|
+
MPC.keyShare(3, 2, 3, seed).should.deepEqual(C);
|
|
273
|
+
// Combine shares to common base address.
|
|
274
|
+
const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);
|
|
275
|
+
const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);
|
|
276
|
+
// Party A derives subkey P share and new Y shares.
|
|
277
|
+
const A_subkey = MPC.keyDerive(A.uShare, [B.yShares[1], C.yShares[1]], path);
|
|
278
|
+
// Party B calculates new P share using party A's subkey Y shares.
|
|
279
|
+
const B_subkey = MPC.keyCombine(B.uShare, [A_subkey.yShares[2], C.yShares[2]]);
|
|
280
|
+
// Derive the public subkeychain separately using the common keychain.
|
|
281
|
+
const subkey = hdTree.publicDerive({
|
|
282
|
+
pk: (0, sdk_core_1.bigIntFromBufferLE)(Buffer.from(A_combine.pShare.y, 'hex')),
|
|
283
|
+
chaincode: (0, sdk_core_1.bigIntFromBufferBE)(Buffer.from(A_combine.pShare.chaincode, 'hex')),
|
|
284
|
+
}, path);
|
|
285
|
+
const y = (0, sdk_core_1.bigIntToBufferLE)(subkey.pk, 32).toString('hex');
|
|
286
|
+
const chaincode = (0, sdk_core_1.bigIntToBufferBE)(subkey.chaincode, 32).toString('hex');
|
|
287
|
+
// Verify the keychain in the subkey P shares equals the separately derived public subkeychain.
|
|
288
|
+
A_subkey.pShare.y.should.equal(y);
|
|
289
|
+
A_subkey.pShare.chaincode.should.equal(chaincode);
|
|
290
|
+
B_subkey.pShare.y.should.equal(y);
|
|
291
|
+
B_subkey.pShare.chaincode.should.equal(chaincode);
|
|
292
|
+
const message = 'MPC on a Friday night';
|
|
293
|
+
const message_buffer = Buffer.from(message);
|
|
294
|
+
// Signing with A and B using subkey P shares.
|
|
295
|
+
const A_sign_share = MPC.signShare(message_buffer, A_subkey.pShare, [A_combine.jShares[2]]);
|
|
296
|
+
const B_sign_share = MPC.signShare(message_buffer, B_subkey.pShare, [B_combine.jShares[1]]);
|
|
297
|
+
const A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [B_sign_share.rShares[1]], [C.yShares[1]]);
|
|
298
|
+
const B_sign = MPC.sign(message_buffer, B_sign_share.xShare, [A_sign_share.rShares[2]], [C.yShares[2]]);
|
|
299
|
+
const signature = MPC.signCombine([A_sign, B_sign]);
|
|
300
|
+
const result = MPC.verify(message_buffer, signature);
|
|
301
|
+
result.should.equal(true);
|
|
302
|
+
// Verify the public key in the signature equals the separately derived public subkey.
|
|
303
|
+
signature.y.should.equal(y);
|
|
304
|
+
});
|
|
305
|
+
it('should fail if seed is not length 64', function () {
|
|
306
|
+
assert_1.default.throws(() => MPC.keyShare(1, 2, 3, (0, crypto_1.randomBytes)(33)), /Seed must have length 64/);
|
|
307
|
+
assert_1.default.throws(() => MPC.keyShare(1, 2, 3, (0, crypto_1.randomBytes)(66)), /Seed must have length 64/);
|
|
308
|
+
const fakePShare = {
|
|
309
|
+
i: 1,
|
|
310
|
+
t: 3,
|
|
311
|
+
n: 2,
|
|
312
|
+
y: 'yString',
|
|
313
|
+
u: 'uString',
|
|
314
|
+
prefix: 'prefix',
|
|
315
|
+
chaincode: 'chaincode',
|
|
316
|
+
};
|
|
317
|
+
assert_1.default.throws(() => MPC.signShare(Buffer.from('abcd', 'hex'), fakePShare, [], (0, crypto_1.randomBytes)(33)), /Seed must have length 64/);
|
|
318
|
+
assert_1.default.throws(() => MPC.signShare(Buffer.from('abcd', 'hex'), fakePShare, [], (0, crypto_1.randomBytes)(66)), /Seed must have length 64/);
|
|
319
|
+
});
|
|
320
|
+
});
|
|
321
|
+
});
|
|
322
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eddsa.js","sourceRoot":"","sources":["../../../../../../test/unit/mpc/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport 'should';\nimport assert from 'assert';\nimport * as bs58 from 'bs58';\nimport { randomBytes } from 'crypto';\nimport * as sol from '@solana/web3.js';\n\nimport { Dot, Sol } from '../../../../../src';\n\nimport {\n  bigIntFromBufferLE,\n  bigIntToBufferLE,\n  bigIntFromBufferBE,\n  bigIntToBufferBE,\n  Ed25519BIP32,\n  Eddsa,\n  HDTree,\n} from '@bitgo-beta/sdk-core';\n\ndescribe('TSS EDDSA key generation and signing', function () {\n  let MPC: Eddsa;\n  let hdTree: HDTree;\n\n  before('initialize modules', async function () {\n    hdTree = await Ed25519BIP32.initialize();\n    MPC = await Eddsa.initialize(hdTree);\n  });\n\n  it('should fail to generate keys with invalid config', function () {\n    assert.throws(() => MPC.keyShare(0, 2, 3), /Invalid KeyShare config/);\n    assert.throws(() => MPC.keyShare(5, 2, 3), /Invalid KeyShare config/);\n  });\n\n  it('should sign and verify signature for low number public key', function () {\n    // We use little endian encoding. This means that the following value is a number that is shorter than 32 Bytes when\n    // leading zeroes are cut off. This is exactly what happened when we passed it to the sodium library for verifying\n    // the signature against the public key.\n    const y = '991b12a1b41b966a3382db32fe9b7fa9f80433940d0b17a1759f1e45ada83f00';\n    const R = 'b14386bb518b675357a4c79d2439166a5fc5a3a0e1c579c7b829eff1e7a7d967';\n    const signableHex =\n      '01000307991b12a1b41b966a3382db32fe9b7fa9f80433940d0b17a1759f1e45ada83f0041536a20902b6d253b111fe5abe87757c123c28cc5fe4eb0da11b5857f3f38e65290384154058de76870e94672fc02e5f96f23e99307f08c56073ebea94cbc57d4d6429b650666264cbcdfe6070749d586d32781608958931e9b8d01636c4f320000000000000000000000000000000000000000000000000000000000000000b43af3bab20c3f39ef3c148c85640614a41043eeb306de5996380f10ec105a8e06ddf6e1d765a193d9cbe146ceeb79ac1cb485ed5f5b37913a8cf5857eff00a91073eab4660e8e3a957c7820d52df6338a8c7b60103bf903cb5f82118430922b02040200030c020000005819b217000000000604010502000a0cf40100000000000009';\n    const userToBitgoGShare = {\n      i: 1,\n      y,\n      R,\n      gamma: 'fcfd96d4ee4f3399b728b3c820a8eed4a6fa496828e84af2756197993b5df30b',\n    };\n    const bitgoToUserGShare = {\n      i: 3,\n      y,\n      R,\n      gamma: '89d5e45641dc93539a32a6651eaae2448db4d44f6d3040a1390beb14d0225c00',\n    };\n\n    const signature = MPC.signCombine([userToBitgoGShare, bitgoToUserGShare]);\n    const signablePayloadBuffer = Buffer.from(signableHex, 'hex');\n    const verificationResult = MPC.verify(signablePayloadBuffer, signature);\n    verificationResult.should.be.true();\n  });\n\n  it('should generate keys and sign message', function () {\n    const A = MPC.keyShare(1, 2, 3);\n    const B = MPC.keyShare(2, 2, 3);\n    const C = MPC.keyShare(3, 2, 3);\n\n    const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);\n    const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);\n    const C_combine = MPC.keyCombine(C.uShare, [A.yShares[3], B.yShares[3]]);\n\n    const message = 'MPC on a Friday night';\n    const message_buffer = Buffer.from(message);\n\n    const incorrect_message = 'MPC on a Monday night';\n    const incorrect_message_buffer = Buffer.from(incorrect_message);\n\n    // signing with A and B\n    let A_sign_share = MPC.signShare(message_buffer, A_combine.pShare, [A_combine.jShares[2]]);\n    let B_sign_share = MPC.signShare(message_buffer, B_combine.pShare, [B_combine.jShares[1]]);\n    let A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [B_sign_share.rShares[1]], [C.yShares[1]]);\n    let B_sign = MPC.sign(message_buffer, B_sign_share.xShare, [A_sign_share.rShares[2]], [C.yShares[2]]);\n    let signature = MPC.signCombine([A_sign, B_sign]);\n    let result = MPC.verify(message_buffer, signature);\n    result.should.equal(true);\n    let resultTwo = MPC.verify(incorrect_message_buffer, signature);\n    resultTwo.should.equal(false);\n\n    // signing with A and C\n    A_sign_share = MPC.signShare(message_buffer, A_combine.pShare, [A_combine.jShares[3]]);\n    let C_sign_share = MPC.signShare(message_buffer, C_combine.pShare, [C_combine.jShares[1]]);\n    A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [C_sign_share.rShares[1]], [B.yShares[1]]);\n    let C_sign = MPC.sign(message_buffer, C_sign_share.xShare, [A_sign_share.rShares[3]], [B.yShares[3]]);\n    signature = MPC.signCombine([A_sign, C_sign]);\n    result = MPC.verify(message_buffer, signature);\n    result.should.equal(true);\n    resultTwo = MPC.verify(incorrect_message_buffer, signature);\n    resultTwo.should.equal(false);\n\n    // signing with B and C\n    B_sign_share = MPC.signShare(message_buffer, B_combine.pShare, [B_combine.jShares[3]]);\n    C_sign_share = MPC.signShare(message_buffer, C_combine.pShare, [C_combine.jShares[2]]);\n    B_sign = MPC.sign(message_buffer, B_sign_share.xShare, [C_sign_share.rShares[2]], [A.yShares[2]]);\n    C_sign = MPC.sign(message_buffer, C_sign_share.xShare, [B_sign_share.rShares[3]], [A.yShares[3]]);\n    signature = MPC.signCombine([B_sign, C_sign]);\n    result = MPC.verify(message_buffer, signature);\n    result.should.equal(true);\n    resultTwo = MPC.verify(incorrect_message_buffer, signature);\n    resultTwo.should.equal(false);\n  });\n\n  it('should verify BIP32 subkey signature', function () {\n    const path = 'm/0/1/2';\n    const A = MPC.keyShare(1, 2, 3);\n    const B = MPC.keyShare(2, 2, 3);\n    const C = MPC.keyShare(3, 2, 3);\n\n    // Combine shares to common base address.\n    const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);\n    const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);\n\n    // Party A derives subkey P share and new Y shares.\n    const A_subkey = MPC.keyDerive(A.uShare, [B.yShares[1], C.yShares[1]], path);\n\n    // Party B calculates new P share using party A's subkey Y shares.\n    const B_subkey = MPC.keyCombine(B.uShare, [A_subkey.yShares[2], C.yShares[2]]);\n\n    // Derive the public subkeychain separately using the common keychain.\n    const subkey = hdTree.publicDerive(\n      {\n        pk: bigIntFromBufferLE(Buffer.from(A_combine.pShare.y, 'hex')),\n        chaincode: bigIntFromBufferBE(Buffer.from(A_combine.pShare.chaincode, 'hex')),\n      },\n      path,\n    );\n    const y = bigIntToBufferLE(subkey.pk, 32).toString('hex');\n    const chaincode = bigIntToBufferBE(subkey.chaincode, 32).toString('hex');\n\n    // Verify the keychain in the subkey P shares equals the separately derived public subkeychain.\n    A_subkey.pShare.y.should.equal(y);\n    A_subkey.pShare.chaincode.should.equal(chaincode);\n    B_subkey.pShare.y.should.equal(y);\n    B_subkey.pShare.chaincode.should.equal(chaincode);\n\n    const message = 'MPC on a Friday night';\n    const message_buffer = Buffer.from(message);\n\n    // Signing with A and B using subkey P shares.\n    const A_sign_share = MPC.signShare(message_buffer, A_subkey.pShare, [A_combine.jShares[2]]);\n    const B_sign_share = MPC.signShare(message_buffer, B_subkey.pShare, [B_combine.jShares[1]]);\n    const A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [B_sign_share.rShares[1]], [C.yShares[1]]);\n    const B_sign = MPC.sign(message_buffer, B_sign_share.xShare, [A_sign_share.rShares[2]], [C.yShares[2]]);\n    const signature = MPC.signCombine([A_sign, B_sign]);\n    const result = MPC.verify(message_buffer, signature);\n    result.should.equal(true);\n\n    // Verify the public key in the signature equals the separately derived public subkey.\n    signature.y.should.equal(y);\n  });\n\n  it('should derive unhardened child keys', function () {\n    const A = MPC.keyShare(1, 2, 3);\n    const B = MPC.keyShare(2, 2, 3);\n    const C = MPC.keyShare(3, 2, 3);\n\n    const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);\n\n    const commonKeychain = A_combine.pShare.y + A_combine.pShare.chaincode;\n\n    for (let index = 0; index < 10; index++) {\n      const path = `m/0/0/${index}`;\n      const derive1 = MPC.deriveUnhardened(commonKeychain, path);\n      const subkey = MPC.keyDerive(A.uShare, [B.yShares[1], C.yShares[1]], path);\n      const derive2 = MPC.deriveUnhardened(commonKeychain, path);\n      const derivedPk = derive1.slice(0, 64);\n\n      (subkey.pShare.y + subkey.pShare.chaincode).should.equal(derive1);\n      derive1.should.equal(derive2, 'derivation should be deterministic');\n\n      const solAddress = bs58.encode(Buffer.from(derivedPk, 'hex'));\n      Sol.Utils.isValidPublicKey(solAddress).should.be.true();\n\n      const solPk = new sol.PublicKey(solAddress);\n      solPk.toBuffer().toString('hex').should.equal(derivedPk);\n    }\n\n    const rootPath = 'm/0';\n    const rootKeychain = MPC.deriveUnhardened(commonKeychain, rootPath);\n    const rootPublicKey = Buffer.from(rootKeychain, 'hex').slice(0, 32).toString('hex');\n    const solPk = new sol.PublicKey(bs58.encode(Buffer.from(rootPublicKey, 'hex')));\n    solPk.toBuffer().toString('hex').should.equal(rootPublicKey);\n  });\n\n  it('should derive unhardened valid dot child keys', function () {\n    const A = MPC.keyShare(1, 2, 3);\n    const B = MPC.keyShare(2, 2, 3);\n    const C = MPC.keyShare(3, 2, 3);\n\n    const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);\n\n    const commonKeychain = A_combine.pShare.y + A_combine.pShare.chaincode;\n\n    for (let index = 0; index < 10; index++) {\n      const path = `m/0/0/${index}`;\n      const derive1 = MPC.deriveUnhardened(commonKeychain, path);\n      const derive2 = MPC.deriveUnhardened(commonKeychain, path);\n      const derivedPk = Buffer.from(derive1, 'hex').slice(0, 32).toString('hex');\n\n      derive1.should.equal(derive2, 'derivation should be deterministic');\n\n      const pubKeyPair = new Dot.KeyPair({ pub: derivedPk });\n      pubKeyPair.getKeys().pub.should.equal(derivedPk);\n    }\n\n    const rootPath = 'm/';\n    const rootKeychain = MPC.deriveUnhardened(commonKeychain, rootPath);\n    const rootPublicKey = Buffer.from(rootKeychain, 'hex').slice(0, 32).toString('hex');\n    const pubKeyPair = new Dot.KeyPair({ pub: rootPublicKey });\n    pubKeyPair.getKeys().pub.should.equal(rootPublicKey);\n  });\n\n  it('should fail signing without meeting threshold', function () {\n    const A = MPC.keyShare(1, 2, 3);\n    const B = MPC.keyShare(2, 2, 3);\n    const C = MPC.keyShare(3, 2, 3);\n\n    const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);\n    const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);\n\n    const message = 'MPC on a Friday night';\n    const message_buffer = Buffer.from(message, 'utf-8');\n    const A_sign_share = MPC.signShare(message_buffer, A_combine.pShare, [A_combine.jShares[2]]);\n    const B_sign_share = MPC.signShare(message_buffer, B_combine.pShare, [B_combine.jShares[1]]);\n\n    const A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [B_sign_share.rShares[1]]);\n    const signature = MPC.signCombine([A_sign]);\n    MPC.verify(message_buffer, signature).should.equal(false);\n  });\n\n  describe('with specific seed', function () {\n    it('should generate keys and sign message', function () {\n      const seed = randomBytes(64);\n\n      const A = MPC.keyShare(1, 2, 3, seed);\n      const B = MPC.keyShare(2, 2, 3, seed);\n      const C = MPC.keyShare(3, 2, 3, seed);\n\n      // Keys should be deterministic when using seed\n      MPC.keyShare(1, 2, 3, seed).should.deepEqual(A);\n      MPC.keyShare(2, 2, 3, seed).should.deepEqual(B);\n      MPC.keyShare(3, 2, 3, seed).should.deepEqual(C);\n\n      const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);\n      const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);\n      const C_combine = MPC.keyCombine(C.uShare, [A.yShares[3], B.yShares[3]]);\n\n      const message = 'MPC on a Friday night';\n      const message_buffer = Buffer.from(message);\n\n      // signing with A and B\n      let A_sign_share = MPC.signShare(message_buffer, A_combine.pShare, [A_combine.jShares[2]], seed);\n      let B_sign_share = MPC.signShare(message_buffer, B_combine.pShare, [B_combine.jShares[1]], seed);\n      let A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [B_sign_share.rShares[1]], [C.yShares[1]]);\n      let B_sign = MPC.sign(message_buffer, B_sign_share.xShare, [A_sign_share.rShares[2]], [C.yShares[2]]);\n      let signature = MPC.signCombine([A_sign, B_sign]);\n      let result = MPC.verify(message_buffer, signature);\n      result.should.equal(true);\n\n      // signing with A and C\n      A_sign_share = MPC.signShare(message_buffer, A_combine.pShare, [A_combine.jShares[3]], seed);\n      let C_sign_share = MPC.signShare(message_buffer, C_combine.pShare, [C_combine.jShares[1]], seed);\n      A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [C_sign_share.rShares[1]], [B.yShares[1]]);\n      let C_sign = MPC.sign(message_buffer, C_sign_share.xShare, [A_sign_share.rShares[3]], [B.yShares[3]]);\n      signature = MPC.signCombine([A_sign, C_sign]);\n      result = MPC.verify(message_buffer, signature);\n      result.should.equal(true);\n\n      // signing with B and C\n      B_sign_share = MPC.signShare(message_buffer, B_combine.pShare, [B_combine.jShares[3]], seed);\n      C_sign_share = MPC.signShare(message_buffer, C_combine.pShare, [C_combine.jShares[2]], seed);\n      B_sign = MPC.sign(message_buffer, B_sign_share.xShare, [C_sign_share.rShares[2]], [A.yShares[2]]);\n      C_sign = MPC.sign(message_buffer, C_sign_share.xShare, [B_sign_share.rShares[3]], [A.yShares[3]]);\n      signature = MPC.signCombine([B_sign, C_sign]);\n      result = MPC.verify(message_buffer, signature);\n      result.should.equal(true);\n    });\n\n    it('should verify BIP32 subkey signature', function () {\n      const seed = randomBytes(64);\n      const path = 'm/0/1/2';\n\n      const A = MPC.keyShare(1, 2, 3, seed);\n      const B = MPC.keyShare(2, 2, 3, seed);\n      const C = MPC.keyShare(3, 2, 3, seed);\n\n      // Keys should be deterministic when using seed\n      MPC.keyShare(1, 2, 3, seed).should.deepEqual(A);\n      MPC.keyShare(2, 2, 3, seed).should.deepEqual(B);\n      MPC.keyShare(3, 2, 3, seed).should.deepEqual(C);\n\n      // Combine shares to common base address.\n      const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);\n      const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);\n\n      // Party A derives subkey P share and new Y shares.\n      const A_subkey = MPC.keyDerive(A.uShare, [B.yShares[1], C.yShares[1]], path);\n\n      // Party B calculates new P share using party A's subkey Y shares.\n      const B_subkey = MPC.keyCombine(B.uShare, [A_subkey.yShares[2], C.yShares[2]]);\n\n      // Derive the public subkeychain separately using the common keychain.\n      const subkey = hdTree.publicDerive(\n        {\n          pk: bigIntFromBufferLE(Buffer.from(A_combine.pShare.y, 'hex')),\n          chaincode: bigIntFromBufferBE(Buffer.from(A_combine.pShare.chaincode, 'hex')),\n        },\n        path,\n      );\n      const y = bigIntToBufferLE(subkey.pk, 32).toString('hex');\n      const chaincode = bigIntToBufferBE(subkey.chaincode, 32).toString('hex');\n\n      // Verify the keychain in the subkey P shares equals the separately derived public subkeychain.\n      A_subkey.pShare.y.should.equal(y);\n      A_subkey.pShare.chaincode.should.equal(chaincode);\n      B_subkey.pShare.y.should.equal(y);\n      B_subkey.pShare.chaincode.should.equal(chaincode);\n\n      const message = 'MPC on a Friday night';\n      const message_buffer = Buffer.from(message);\n\n      // Signing with A and B using subkey P shares.\n      const A_sign_share = MPC.signShare(message_buffer, A_subkey.pShare, [A_combine.jShares[2]]);\n      const B_sign_share = MPC.signShare(message_buffer, B_subkey.pShare, [B_combine.jShares[1]]);\n      const A_sign = MPC.sign(message_buffer, A_sign_share.xShare, [B_sign_share.rShares[1]], [C.yShares[1]]);\n      const B_sign = MPC.sign(message_buffer, B_sign_share.xShare, [A_sign_share.rShares[2]], [C.yShares[2]]);\n      const signature = MPC.signCombine([A_sign, B_sign]);\n      const result = MPC.verify(message_buffer, signature);\n      result.should.equal(true);\n\n      // Verify the public key in the signature equals the separately derived public subkey.\n      signature.y.should.equal(y);\n    });\n\n    it('should fail if seed is not length 64', function () {\n      assert.throws(() => MPC.keyShare(1, 2, 3, randomBytes(33)), /Seed must have length 64/);\n      assert.throws(() => MPC.keyShare(1, 2, 3, randomBytes(66)), /Seed must have length 64/);\n\n      const fakePShare = {\n        i: 1,\n        t: 3,\n        n: 2,\n        y: 'yString',\n        u: 'uString',\n        prefix: 'prefix',\n        chaincode: 'chaincode',\n      };\n      assert.throws(\n        () => MPC.signShare(Buffer.from('abcd', 'hex'), fakePShare, [], randomBytes(33)),\n        /Seed must have length 64/,\n      );\n      assert.throws(\n        () => MPC.signShare(Buffer.from('abcd', 'hex'), fakePShare, [], randomBytes(66)),\n        /Seed must have length 64/,\n      );\n    });\n  });\n});\n"]}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
export declare const ntildes: {
|
|
2
|
+
ntilde: bigint;
|
|
3
|
+
h1: bigint;
|
|
4
|
+
h2: bigint;
|
|
5
|
+
}[];
|
|
6
|
+
export declare const paillerKeys: {
|
|
7
|
+
publicKey: {
|
|
8
|
+
n: bigint;
|
|
9
|
+
_n2: bigint;
|
|
10
|
+
g: bigint;
|
|
11
|
+
};
|
|
12
|
+
privateKey: {
|
|
13
|
+
lambda: bigint;
|
|
14
|
+
mu: bigint;
|
|
15
|
+
_p: bigint;
|
|
16
|
+
_q: bigint;
|
|
17
|
+
publicKey: {
|
|
18
|
+
n: bigint;
|
|
19
|
+
_n2: bigint;
|
|
20
|
+
g: bigint;
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
}[];
|
|
24
|
+
export declare const schnorrProofs: {
|
|
25
|
+
vPoint: bigint;
|
|
26
|
+
r: bigint;
|
|
27
|
+
}[];
|
|
28
|
+
export declare const mockPShare: {
|
|
29
|
+
i: number;
|
|
30
|
+
t: number;
|
|
31
|
+
c: number;
|
|
32
|
+
l: string;
|
|
33
|
+
m: string;
|
|
34
|
+
n: string;
|
|
35
|
+
y: string;
|
|
36
|
+
u: string;
|
|
37
|
+
uu: string;
|
|
38
|
+
chaincode: string;
|
|
39
|
+
};
|
|
40
|
+
export declare const mockNShares: {
|
|
41
|
+
i: number;
|
|
42
|
+
j: number;
|
|
43
|
+
n: string;
|
|
44
|
+
y: string;
|
|
45
|
+
v: string;
|
|
46
|
+
u: string;
|
|
47
|
+
chaincode: string;
|
|
48
|
+
}[];
|
|
49
|
+
export declare const mockDKeyShare: {
|
|
50
|
+
xShare: {
|
|
51
|
+
i: number;
|
|
52
|
+
l: string;
|
|
53
|
+
m: string;
|
|
54
|
+
n: string;
|
|
55
|
+
y: string;
|
|
56
|
+
x: string;
|
|
57
|
+
chaincode: string;
|
|
58
|
+
schnorrProofX: {
|
|
59
|
+
vPoint: bigint;
|
|
60
|
+
r: bigint;
|
|
61
|
+
};
|
|
62
|
+
};
|
|
63
|
+
yShares: {
|
|
64
|
+
2: {
|
|
65
|
+
i: number;
|
|
66
|
+
j: number;
|
|
67
|
+
n: string;
|
|
68
|
+
};
|
|
69
|
+
3: {
|
|
70
|
+
i: number;
|
|
71
|
+
j: number;
|
|
72
|
+
n: string;
|
|
73
|
+
};
|
|
74
|
+
};
|
|
75
|
+
};
|
|
76
|
+
export declare const mockEKeyShare: {
|
|
77
|
+
xShare: {
|
|
78
|
+
i: number;
|
|
79
|
+
l: string;
|
|
80
|
+
m: string;
|
|
81
|
+
n: string;
|
|
82
|
+
y: string;
|
|
83
|
+
x: string;
|
|
84
|
+
chaincode: string;
|
|
85
|
+
schnorrProofX: {
|
|
86
|
+
vPoint: bigint;
|
|
87
|
+
r: bigint;
|
|
88
|
+
};
|
|
89
|
+
};
|
|
90
|
+
yShares: {
|
|
91
|
+
1: {
|
|
92
|
+
i: number;
|
|
93
|
+
j: number;
|
|
94
|
+
n: string;
|
|
95
|
+
};
|
|
96
|
+
3: {
|
|
97
|
+
i: number;
|
|
98
|
+
j: number;
|
|
99
|
+
n: string;
|
|
100
|
+
};
|
|
101
|
+
};
|
|
102
|
+
};
|
|
103
|
+
export declare const mockFKeyShare: {
|
|
104
|
+
xShare: {
|
|
105
|
+
i: number;
|
|
106
|
+
l: string;
|
|
107
|
+
m: string;
|
|
108
|
+
n: string;
|
|
109
|
+
y: string;
|
|
110
|
+
x: string;
|
|
111
|
+
chaincode: string;
|
|
112
|
+
schnorrProofX: {
|
|
113
|
+
vPoint: bigint;
|
|
114
|
+
r: bigint;
|
|
115
|
+
};
|
|
116
|
+
};
|
|
117
|
+
yShares: {
|
|
118
|
+
1: {
|
|
119
|
+
i: number;
|
|
120
|
+
j: number;
|
|
121
|
+
n: string;
|
|
122
|
+
};
|
|
123
|
+
2: {
|
|
124
|
+
i: number;
|
|
125
|
+
j: number;
|
|
126
|
+
n: string;
|
|
127
|
+
};
|
|
128
|
+
};
|
|
129
|
+
};
|
|
130
|
+
//# sourceMappingURL=ecdsa.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ecdsa.d.ts","sourceRoot":"","sources":["../../../../../../test/unit/mpc/tss/fixtures/ecdsa.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,OAAO;;;;GAuMnB,CAAC;AAEF,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;GAmHvB,CAAC;AAEF,eAAO,MAAM,aAAa;;;GAyBzB,CAAC;AAEF,eAAO,MAAM,UAAU;;;;;;;;;;;CAWtB,CAAC;AAEF,eAAO,MAAM,WAAW;;;;;;;;GAmBvB,CAAC;AAGF,eAAO,MAAM,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;;CAuBzB,CAAC;AAEF,eAAO,MAAM,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;;CAuBzB,CAAC;AAEF,eAAO,MAAM,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;;CAuBzB,CAAC"}
|