@bitgo-beta/sdk-lib-mpc 8.2.1-alpha.5 → 8.2.1-alpha.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +28 -0
- package/dist/src/index.d.ts +1 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +2 -1
- package/dist/src/tss/ecdsa/index.d.ts +2 -0
- package/dist/src/tss/ecdsa/index.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/index.js +4 -2
- package/dist/src/tss/ecdsa/paillierproof.d.ts +24 -0
- package/dist/src/tss/ecdsa/paillierproof.d.ts.map +1 -0
- package/dist/src/tss/ecdsa/paillierproof.js +86 -0
- package/dist/src/tss/ecdsa/primes.d.ts +2 -0
- package/dist/src/tss/ecdsa/primes.d.ts.map +1 -0
- package/dist/src/tss/ecdsa/primes.js +1846 -0
- package/dist/src/tss/ecdsa/rangeproof.d.ts +1 -1
- package/dist/src/tss/ecdsa/rangeproof.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/rangeproof.js +21 -23
- package/dist/src/tss/ecdsa/types.d.ts +66 -13
- package/dist/src/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/types.js +76 -14
- package/dist/src/util.d.ts +13 -4
- package/dist/src/util.d.ts.map +1 -1
- package/dist/src/util.js +28 -8
- package/dist/tsconfig.tsbuildinfo +34 -10
- package/package.json +2 -2
package/dist/src/util.d.ts
CHANGED
|
@@ -8,8 +8,9 @@ export declare function convertHexArrToBigIntArr(values: string[]): bigint[];
|
|
|
8
8
|
/**
|
|
9
9
|
* Returns a hex string array from a bigint array
|
|
10
10
|
* @param values
|
|
11
|
+
* @param hexLength - length to pad each big int number too
|
|
11
12
|
*/
|
|
12
|
-
export declare function convertBigIntArrToHexArr(values: bigint[]): string[];
|
|
13
|
+
export declare function convertBigIntArrToHexArr(values: bigint[], hexLength?: number): string[];
|
|
13
14
|
export declare function hexToBigInt(hex: string): bigint;
|
|
14
15
|
/**
|
|
15
16
|
* Returns an hex string of the given bigint
|
|
@@ -26,19 +27,27 @@ export declare function bigIntFromBufferBE(buf: Buffer): bigint;
|
|
|
26
27
|
export declare function bigIntFromU8ABE(buf: Uint8Array): bigint;
|
|
27
28
|
export declare function clamp(u: bigint): bigint;
|
|
28
29
|
/**
|
|
29
|
-
* Function get
|
|
30
|
+
* Function get paillier public key simple varient
|
|
30
31
|
* @param {bigint} n
|
|
31
32
|
* @returns {bigint}
|
|
32
33
|
*/
|
|
33
34
|
export declare function getPaillierPublicKey(n: bigint): PublicKey;
|
|
34
35
|
/**
|
|
35
|
-
* Generate a random
|
|
36
|
+
* Generate a random positive integer co-prime to x
|
|
36
37
|
* @param x
|
|
38
|
+
* @returns {Promise<bigint>}
|
|
37
39
|
*/
|
|
38
|
-
export declare function
|
|
40
|
+
export declare function randomPositiveCoPrimeTo(x: bigint): Promise<bigint>;
|
|
41
|
+
/**
|
|
42
|
+
* Generate a random positive integer coprime less than x with the same bit depth.
|
|
43
|
+
* @param x
|
|
44
|
+
* @returns {Promise<bigint>}
|
|
45
|
+
*/
|
|
46
|
+
export declare function randomPositiveCoPrimeLessThan(x: bigint): Promise<bigint>;
|
|
39
47
|
/**
|
|
40
48
|
* Generate a random number of a given bitlength
|
|
41
49
|
* @param bitlength
|
|
50
|
+
* @returns {Promise<bigint>}
|
|
42
51
|
*/
|
|
43
52
|
export declare function randomBigInt(bitlength: number): Promise<bigint>;
|
|
44
53
|
//# sourceMappingURL=util.d.ts.map
|
package/dist/src/util.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAI5C;;;GAGG;AACH,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAInE;AAED
|
|
1
|
+
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAI5C;;;GAGG;AACH,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAInE;AAED;;;;GAIG;AACH,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAIvF;AAED,wBAAgB,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAU/C;AAED;;;;;;GAMG;AACH,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAOtE;AAED,wBAAgB,gBAAgB,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAQlE;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAEtD;AAED,wBAAgB,gBAAgB,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAQlE;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAEtD;AAED,wBAAgB,eAAe,CAAC,GAAG,EAAE,UAAU,GAAG,MAAM,CAEvD;AAED,wBAAgB,KAAK,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAIvC;AAED;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,CAAC,EAAE,MAAM,GAAG,SAAS,CAEzD;AAED;;;;GAIG;AACH,wBAAsB,uBAAuB,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAOxE;AAED;;;;GAIG;AACH,wBAAsB,6BAA6B,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAU9E;AAED;;;;GAIG;AACH,wBAAsB,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAErE"}
|
package/dist/src/util.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.randomBigInt = exports.
|
|
3
|
+
exports.randomBigInt = exports.randomPositiveCoPrimeLessThan = exports.randomPositiveCoPrimeTo = exports.getPaillierPublicKey = exports.clamp = exports.bigIntFromU8ABE = exports.bigIntFromBufferBE = exports.bigIntToBufferBE = exports.bigIntFromBufferLE = exports.bigIntToBufferLE = exports.bigIntToHex = exports.hexToBigInt = exports.convertBigIntArrToHexArr = exports.convertHexArrToBigIntArr = void 0;
|
|
4
4
|
const paillier_bigint_1 = require("paillier-bigint");
|
|
5
5
|
const bigint_crypto_utils_1 = require("bigint-crypto-utils");
|
|
6
6
|
const bigint_mod_arith_1 = require("bigint-mod-arith");
|
|
@@ -17,10 +17,11 @@ exports.convertHexArrToBigIntArr = convertHexArrToBigIntArr;
|
|
|
17
17
|
/**
|
|
18
18
|
* Returns a hex string array from a bigint array
|
|
19
19
|
* @param values
|
|
20
|
+
* @param hexLength - length to pad each big int number too
|
|
20
21
|
*/
|
|
21
|
-
function convertBigIntArrToHexArr(values) {
|
|
22
|
+
function convertBigIntArrToHexArr(values, hexLength) {
|
|
22
23
|
return values.map((value) => {
|
|
23
|
-
return bigIntToHex(value);
|
|
24
|
+
return bigIntToHex(value, hexLength);
|
|
24
25
|
});
|
|
25
26
|
}
|
|
26
27
|
exports.convertBigIntArrToHexArr = convertBigIntArrToHexArr;
|
|
@@ -91,7 +92,7 @@ function clamp(u) {
|
|
|
91
92
|
}
|
|
92
93
|
exports.clamp = clamp;
|
|
93
94
|
/**
|
|
94
|
-
* Function get
|
|
95
|
+
* Function get paillier public key simple varient
|
|
95
96
|
* @param {bigint} n
|
|
96
97
|
* @returns {bigint}
|
|
97
98
|
*/
|
|
@@ -100,10 +101,11 @@ function getPaillierPublicKey(n) {
|
|
|
100
101
|
}
|
|
101
102
|
exports.getPaillierPublicKey = getPaillierPublicKey;
|
|
102
103
|
/**
|
|
103
|
-
* Generate a random
|
|
104
|
+
* Generate a random positive integer co-prime to x
|
|
104
105
|
* @param x
|
|
106
|
+
* @returns {Promise<bigint>}
|
|
105
107
|
*/
|
|
106
|
-
async function
|
|
108
|
+
async function randomPositiveCoPrimeTo(x) {
|
|
107
109
|
while (true) {
|
|
108
110
|
const y = await randomBigInt(bigint_crypto_utils_1.bitLength(x));
|
|
109
111
|
if (y > BigInt(0) && bigint_mod_arith_1.gcd(x, y) === BigInt(1)) {
|
|
@@ -111,13 +113,31 @@ async function randomCoPrimeTo(x) {
|
|
|
111
113
|
}
|
|
112
114
|
}
|
|
113
115
|
}
|
|
114
|
-
exports.
|
|
116
|
+
exports.randomPositiveCoPrimeTo = randomPositiveCoPrimeTo;
|
|
117
|
+
/**
|
|
118
|
+
* Generate a random positive integer coprime less than x with the same bit depth.
|
|
119
|
+
* @param x
|
|
120
|
+
* @returns {Promise<bigint>}
|
|
121
|
+
*/
|
|
122
|
+
async function randomPositiveCoPrimeLessThan(x) {
|
|
123
|
+
if (x <= BigInt(2)) {
|
|
124
|
+
throw new Error('x must be larger than 2');
|
|
125
|
+
}
|
|
126
|
+
while (true) {
|
|
127
|
+
const y = await randomBigInt(bigint_crypto_utils_1.bitLength(x));
|
|
128
|
+
if (y > BigInt(0) && y < x && bigint_mod_arith_1.gcd(x, y) === BigInt(1)) {
|
|
129
|
+
return y;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
exports.randomPositiveCoPrimeLessThan = randomPositiveCoPrimeLessThan;
|
|
115
134
|
/**
|
|
116
135
|
* Generate a random number of a given bitlength
|
|
117
136
|
* @param bitlength
|
|
137
|
+
* @returns {Promise<bigint>}
|
|
118
138
|
*/
|
|
119
139
|
async function randomBigInt(bitlength) {
|
|
120
140
|
return bigIntFromBufferBE(Buffer.from(await bigint_crypto_utils_1.randBits(bitlength, true)));
|
|
121
141
|
}
|
|
122
142
|
exports.randomBigInt = randomBigInt;
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":"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","sourcesContent":["import { PublicKey } from 'paillier-bigint';\nimport { bitLength, randBits } from 'bigint-crypto-utils';\nimport { gcd } from 'bigint-mod-arith';\n\n/**\n * Returns a bigint array from a hex string array\n * @param values\n */\nexport function convertHexArrToBigIntArr(values: string[]): bigint[] {\n  return values.map((value) => {\n    return hexToBigInt(value);\n  });\n}\n\n/**\n * Returns a hex string array from a bigint array\n * @param values\n */\nexport function convertBigIntArrToHexArr(values: bigint[]): string[] {\n  return values.map((value) => {\n    return bigIntToHex(value);\n  });\n}\n\nexport function hexToBigInt(hex: string): bigint {\n  // Strangely bigint.toString(16) gives a hex string without 0x,\n  // but it won't accept the same string without 0x to convert\n  // to a bigint (BigInt(hex string)). So have to introduce this\n  // check to convert to add 0x in case if hex string\n  // doesn't have it.\n  if (hex.slice(0, 2) === '0x') {\n    return BigInt(hex);\n  }\n  return BigInt('0x' + hex);\n}\n\n/**\n * Returns an hex string of the given bigint\n *\n * @param {bigint} bigint - the bigint to be converted to hex\n * @param hexLength\n * @returns {string} - the hex value\n */\nexport function bigIntToHex(bigint: bigint, hexLength?: number): string {\n  let hex = bigint.toString(16);\n  hex = '0'.slice(0, hex.length % 2) + hex;\n  if (hexLength) {\n    hex = hex.padStart(hexLength, '0');\n  }\n  return hex;\n}\n\nexport function bigIntToBufferLE(n: bigint, bytes?: number): Buffer {\n  let v = n.toString(16);\n  v = '0'.slice(0, v.length % 2) + v;\n  const buf = Buffer.from(v, 'hex').reverse();\n  if (bytes && buf.length < bytes) {\n    return Buffer.concat([buf, Buffer.alloc(bytes - buf.length)]);\n  }\n  return buf;\n}\n\nexport function bigIntFromBufferLE(buf: Buffer): bigint {\n  return BigInt('0x' + Buffer.from(buf).reverse().toString('hex'));\n}\n\nexport function bigIntToBufferBE(n: bigint, bytes?: number): Buffer {\n  let v = n.toString(16);\n  v = '0'.slice(0, v.length % 2) + v;\n  const buf = Buffer.from(v, 'hex');\n  if (bytes && buf.length < bytes) {\n    return Buffer.concat([Buffer.alloc(bytes - buf.length), buf]);\n  }\n  return buf;\n}\n\nexport function bigIntFromBufferBE(buf: Buffer): bigint {\n  return BigInt('0x' + buf.toString('hex'));\n}\n\nexport function bigIntFromU8ABE(buf: Uint8Array): bigint {\n  return bigIntFromBufferBE(Buffer.from(buf));\n}\n\nexport function clamp(u: bigint): bigint {\n  u &= BigInt('0x7ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8');\n  u |= BigInt('0x4000000000000000000000000000000000000000000000000000000000000000');\n  return u;\n}\n\n/**\n * Function get pallier public key simple varient\n * @param {bigint} n\n * @returns {bigint}\n */\nexport function getPaillierPublicKey(n: bigint): PublicKey {\n  return new PublicKey(n, n + BigInt(1));\n}\n\n/**\n * Generate a random number co-prime to x\n * @param x\n */\nexport async function randomCoPrimeTo(x: bigint): Promise<bigint> {\n  while (true) {\n    const y = await randomBigInt(bitLength(x));\n    if (y > BigInt(0) && gcd(x, y) === BigInt(1)) {\n      return y;\n    }\n  }\n}\n\n/**\n * Generate a random number of a given bitlength\n * @param bitlength\n */\nexport async function randomBigInt(bitlength: number): Promise<bigint> {\n  return bigIntFromBufferBE(Buffer.from(await randBits(bitlength, true)));\n}\n"]}
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":"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","sourcesContent":["import { PublicKey } from 'paillier-bigint';\nimport { bitLength, randBits } from 'bigint-crypto-utils';\nimport { gcd } from 'bigint-mod-arith';\n\n/**\n * Returns a bigint array from a hex string array\n * @param values\n */\nexport function convertHexArrToBigIntArr(values: string[]): bigint[] {\n  return values.map((value) => {\n    return hexToBigInt(value);\n  });\n}\n\n/**\n * Returns a hex string array from a bigint array\n * @param values\n * @param hexLength - length to pad each big int number too\n */\nexport function convertBigIntArrToHexArr(values: bigint[], hexLength?: number): string[] {\n  return values.map((value) => {\n    return bigIntToHex(value, hexLength);\n  });\n}\n\nexport function hexToBigInt(hex: string): bigint {\n  // Strangely bigint.toString(16) gives a hex string without 0x,\n  // but it won't accept the same string without 0x to convert\n  // to a bigint (BigInt(hex string)). So have to introduce this\n  // check to convert to add 0x in case if hex string\n  // doesn't have it.\n  if (hex.slice(0, 2) === '0x') {\n    return BigInt(hex);\n  }\n  return BigInt('0x' + hex);\n}\n\n/**\n * Returns an hex string of the given bigint\n *\n * @param {bigint} bigint - the bigint to be converted to hex\n * @param hexLength\n * @returns {string} - the hex value\n */\nexport function bigIntToHex(bigint: bigint, hexLength?: number): string {\n  let hex = bigint.toString(16);\n  hex = '0'.slice(0, hex.length % 2) + hex;\n  if (hexLength) {\n    hex = hex.padStart(hexLength, '0');\n  }\n  return hex;\n}\n\nexport function bigIntToBufferLE(n: bigint, bytes?: number): Buffer {\n  let v = n.toString(16);\n  v = '0'.slice(0, v.length % 2) + v;\n  const buf = Buffer.from(v, 'hex').reverse();\n  if (bytes && buf.length < bytes) {\n    return Buffer.concat([buf, Buffer.alloc(bytes - buf.length)]);\n  }\n  return buf;\n}\n\nexport function bigIntFromBufferLE(buf: Buffer): bigint {\n  return BigInt('0x' + Buffer.from(buf).reverse().toString('hex'));\n}\n\nexport function bigIntToBufferBE(n: bigint, bytes?: number): Buffer {\n  let v = n.toString(16);\n  v = '0'.slice(0, v.length % 2) + v;\n  const buf = Buffer.from(v, 'hex');\n  if (bytes && buf.length < bytes) {\n    return Buffer.concat([Buffer.alloc(bytes - buf.length), buf]);\n  }\n  return buf;\n}\n\nexport function bigIntFromBufferBE(buf: Buffer): bigint {\n  return BigInt('0x' + buf.toString('hex'));\n}\n\nexport function bigIntFromU8ABE(buf: Uint8Array): bigint {\n  return bigIntFromBufferBE(Buffer.from(buf));\n}\n\nexport function clamp(u: bigint): bigint {\n  u &= BigInt('0x7ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8');\n  u |= BigInt('0x4000000000000000000000000000000000000000000000000000000000000000');\n  return u;\n}\n\n/**\n * Function get paillier public key simple varient\n * @param {bigint} n\n * @returns {bigint}\n */\nexport function getPaillierPublicKey(n: bigint): PublicKey {\n  return new PublicKey(n, n + BigInt(1));\n}\n\n/**\n * Generate a random positive integer co-prime to x\n * @param x\n * @returns {Promise<bigint>}\n */\nexport async function randomPositiveCoPrimeTo(x: bigint): Promise<bigint> {\n  while (true) {\n    const y = await randomBigInt(bitLength(x));\n    if (y > BigInt(0) && gcd(x, y) === BigInt(1)) {\n      return y;\n    }\n  }\n}\n\n/**\n * Generate a random positive integer coprime less than x with the same bit depth.\n * @param x\n * @returns {Promise<bigint>}\n */\nexport async function randomPositiveCoPrimeLessThan(x: bigint): Promise<bigint> {\n  if (x <= BigInt(2)) {\n    throw new Error('x must be larger than 2');\n  }\n  while (true) {\n    const y = await randomBigInt(bitLength(x));\n    if (y > BigInt(0) && y < x && gcd(x, y) === BigInt(1)) {\n      return y;\n    }\n  }\n}\n\n/**\n * Generate a random number of a given bitlength\n * @param bitlength\n * @returns {Promise<bigint>}\n */\nexport async function randomBigInt(bitlength: number): Promise<bigint> {\n  return bigIntFromBufferBE(Buffer.from(await randBits(bitlength, true)));\n}\n"]}
|
|
@@ -492,13 +492,13 @@
|
|
|
492
492
|
"affectsGlobalScope": false
|
|
493
493
|
},
|
|
494
494
|
"../src/util.ts": {
|
|
495
|
-
"version": "
|
|
496
|
-
"signature": "
|
|
495
|
+
"version": "fd31445d8f629550b620ddcd943aaa9ed900840b3fb7ec5f14398791298f9dc5",
|
|
496
|
+
"signature": "ba550feb8b9e414177b5401a7f23efc1c2d31a0dd9666c365b7c66e2016e7177",
|
|
497
497
|
"affectsGlobalScope": false
|
|
498
498
|
},
|
|
499
499
|
"../src/tss/ecdsa/types.ts": {
|
|
500
|
-
"version": "
|
|
501
|
-
"signature": "
|
|
500
|
+
"version": "c7a03a5ca457650449b39b11fb7c2b78066d5aa0feb44f794f74f4463542e8a7",
|
|
501
|
+
"signature": "cfe1012f8175c674dd19a39cf93391a0103aebd465920faa6718842bd1740389",
|
|
502
502
|
"affectsGlobalScope": false
|
|
503
503
|
},
|
|
504
504
|
"../src/curves/baseCurve.ts": {
|
|
@@ -547,13 +547,23 @@
|
|
|
547
547
|
"affectsGlobalScope": false
|
|
548
548
|
},
|
|
549
549
|
"../src/tss/ecdsa/rangeproof.ts": {
|
|
550
|
-
"version": "
|
|
551
|
-
"signature": "
|
|
550
|
+
"version": "f43d13766f7f4f5724629a92058e4182d906279231138529a01123b3be86da30",
|
|
551
|
+
"signature": "8b22694f385be2f039e3676ea7d112b449729da6333e3e1af5f08aae3db99d2b",
|
|
552
|
+
"affectsGlobalScope": false
|
|
553
|
+
},
|
|
554
|
+
"../src/tss/ecdsa/primes.ts": {
|
|
555
|
+
"version": "d5b762b692d14b48d000077e07ff3dcb05d09a472cfaddfb32d80f87adcc212b",
|
|
556
|
+
"signature": "0d7cac78bc999e97ee5ba5cfa87c6453ed457a6c83786625042e653868edd234",
|
|
557
|
+
"affectsGlobalScope": false
|
|
558
|
+
},
|
|
559
|
+
"../src/tss/ecdsa/paillierproof.ts": {
|
|
560
|
+
"version": "eaced94643ae69cb88d3d7c43b312d9d101ed3fdadb7fa8106c0332df0639c59",
|
|
561
|
+
"signature": "f7a684dc92f6027cd074080aa2f6105ece4a65c2c64bce2a7214ca4a2ce38d3c",
|
|
552
562
|
"affectsGlobalScope": false
|
|
553
563
|
},
|
|
554
564
|
"../src/tss/ecdsa/index.ts": {
|
|
555
|
-
"version": "
|
|
556
|
-
"signature": "
|
|
565
|
+
"version": "1e8c4bd55bc9bdffadc507eb9ba26e830d34cbda68c5f074ec1f03a2e1c09072",
|
|
566
|
+
"signature": "b9707f86e0e401b657ed40193fcae1cff492e43c201624f9a72aef2f328d76b7",
|
|
557
567
|
"affectsGlobalScope": false
|
|
558
568
|
},
|
|
559
569
|
"../src/tss/index.ts": {
|
|
@@ -562,8 +572,8 @@
|
|
|
562
572
|
"affectsGlobalScope": false
|
|
563
573
|
},
|
|
564
574
|
"../src/index.ts": {
|
|
565
|
-
"version": "
|
|
566
|
-
"signature": "
|
|
575
|
+
"version": "e1f3d3827d13ac0e8aaff65905936e016fe8ca8c9d7dc16917dcf38b9e641942",
|
|
576
|
+
"signature": "13a8e31ae2b0004e4fab84b790e9a8bc0faf140c53c20e7d55af61ba4eebb18f",
|
|
567
577
|
"affectsGlobalScope": false
|
|
568
578
|
},
|
|
569
579
|
"../../../node_modules/bignumber.js/bignumber.d.ts": {
|
|
@@ -1466,6 +1476,7 @@
|
|
|
1466
1476
|
],
|
|
1467
1477
|
"../src/index.ts": [
|
|
1468
1478
|
"../src/curves/index.ts",
|
|
1479
|
+
"../src/openssl/index.ts",
|
|
1469
1480
|
"../src/tss/index.ts",
|
|
1470
1481
|
"../src/util.ts"
|
|
1471
1482
|
],
|
|
@@ -1477,9 +1488,17 @@
|
|
|
1477
1488
|
"../src/openssl/opensslbytes.ts"
|
|
1478
1489
|
],
|
|
1479
1490
|
"../src/tss/ecdsa/index.ts": [
|
|
1491
|
+
"../src/tss/ecdsa/paillierproof.ts",
|
|
1480
1492
|
"../src/tss/ecdsa/rangeproof.ts",
|
|
1481
1493
|
"../src/tss/ecdsa/types.ts"
|
|
1482
1494
|
],
|
|
1495
|
+
"../src/tss/ecdsa/paillierproof.ts": [
|
|
1496
|
+
"../../../node_modules/bigint-crypto-utils/types/index.d.ts",
|
|
1497
|
+
"../../../node_modules/bigint-mod-arith/types/index.d.ts",
|
|
1498
|
+
"../src/tss/ecdsa/index.ts",
|
|
1499
|
+
"../src/tss/ecdsa/primes.ts",
|
|
1500
|
+
"../src/util.ts"
|
|
1501
|
+
],
|
|
1483
1502
|
"../src/tss/ecdsa/rangeproof.ts": [
|
|
1484
1503
|
"../../../node_modules/@types/node/crypto.d.ts",
|
|
1485
1504
|
"../../../node_modules/bigint-crypto-utils/types/index.d.ts",
|
|
@@ -1487,6 +1506,7 @@
|
|
|
1487
1506
|
"../../../node_modules/paillier-bigint/types/index.d.ts",
|
|
1488
1507
|
"../src/curves/index.ts",
|
|
1489
1508
|
"../src/openssl/index.ts",
|
|
1509
|
+
"../src/tss/ecdsa/index.ts",
|
|
1490
1510
|
"../src/tss/ecdsa/types.ts",
|
|
1491
1511
|
"../src/util.ts"
|
|
1492
1512
|
],
|
|
@@ -2410,6 +2430,7 @@
|
|
|
2410
2430
|
],
|
|
2411
2431
|
"../src/index.ts": [
|
|
2412
2432
|
"../src/curves/index.ts",
|
|
2433
|
+
"../src/openssl/index.ts",
|
|
2413
2434
|
"../src/tss/index.ts",
|
|
2414
2435
|
"../src/util.ts"
|
|
2415
2436
|
],
|
|
@@ -2417,6 +2438,7 @@
|
|
|
2417
2438
|
"../src/openssl/openssl.ts"
|
|
2418
2439
|
],
|
|
2419
2440
|
"../src/tss/ecdsa/index.ts": [
|
|
2441
|
+
"../src/tss/ecdsa/paillierproof.ts",
|
|
2420
2442
|
"../src/tss/ecdsa/rangeproof.ts",
|
|
2421
2443
|
"../src/tss/ecdsa/types.ts"
|
|
2422
2444
|
],
|
|
@@ -3339,6 +3361,8 @@
|
|
|
3339
3361
|
"../src/openssl/openssl.ts",
|
|
3340
3362
|
"../src/openssl/opensslbytes.ts",
|
|
3341
3363
|
"../src/tss/ecdsa/index.ts",
|
|
3364
|
+
"../src/tss/ecdsa/paillierproof.ts",
|
|
3365
|
+
"../src/tss/ecdsa/primes.ts",
|
|
3342
3366
|
"../src/tss/ecdsa/rangeproof.ts",
|
|
3343
3367
|
"../src/tss/ecdsa/types.ts",
|
|
3344
3368
|
"../src/tss/index.ts",
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bitgo-beta/sdk-lib-mpc",
|
|
3
|
-
"version": "8.2.1-alpha.
|
|
3
|
+
"version": "8.2.1-alpha.7",
|
|
4
4
|
"description": "library functions for BitGo's MPC solution",
|
|
5
5
|
"main": "./dist/src/index.js",
|
|
6
6
|
"types": "./dist/src/index.d.ts",
|
|
@@ -48,5 +48,5 @@
|
|
|
48
48
|
"@types/lodash": "^4.14.151",
|
|
49
49
|
"nyc": "^15.0.0"
|
|
50
50
|
},
|
|
51
|
-
"gitHead": "
|
|
51
|
+
"gitHead": "ce20ee41a7a39623bfd344b8b2ef9b7f18bf822f"
|
|
52
52
|
}
|