@bitgo-beta/sdk-lib-mpc 8.2.1-alpha.1 → 8.2.1-alpha.11
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 +34 -0
- package/dist/src/curves/baseCurve.d.ts +1 -2
- package/dist/src/curves/baseCurve.d.ts.map +1 -1
- package/dist/src/curves/baseCurve.js +1 -1
- package/dist/src/curves/index.d.ts +2 -2
- package/dist/src/curves/index.d.ts.map +1 -1
- package/dist/src/curves/index.js +13 -1
- package/dist/src/curves/secp256k1.d.ts +17 -0
- package/dist/src/curves/secp256k1.d.ts.map +1 -0
- package/dist/src/curves/secp256k1.js +70 -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 +3 -1
- package/dist/src/tss/ecdsa/index.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/index.js +5 -3
- 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 +3 -4
- package/dist/src/tss/ecdsa/rangeproof.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/rangeproof.js +21 -32
- package/dist/src/tss/ecdsa/types.d.ts +79 -7
- package/dist/src/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/types.js +130 -1
- package/dist/src/tss/index.d.ts +1 -1
- package/dist/src/tss/index.d.ts.map +1 -1
- package/dist/src/tss/index.js +4 -14
- package/dist/src/util.d.ts +47 -0
- package/dist/src/util.d.ts.map +1 -1
- package/dist/src/util.js +113 -2
- package/dist/tsconfig.tsbuildinfo +87 -30
- package/package.json +3 -2
|
@@ -1,3 +1,132 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
|
|
3
|
+
exports.serializePaillierChallengeWithProofs = exports.serializePaillierChallengeProofs = exports.serializePaillierChallenge = exports.deserializePaillierChallengeWithProofs = exports.deserializePaillierChallengeProofs = exports.deserializePaillierChallenge = exports.serializeNtildeWithProofs = exports.deserializeNtildeWithProofs = exports.serializeNtilde = exports.deserializeNtilde = void 0;
|
|
4
|
+
// Ntilde Proof where both alpha and t are a set of 128 proofs each.
|
|
5
|
+
const util_1 = require("../../util");
|
|
6
|
+
/**
|
|
7
|
+
* Deserializes a challenge from hex strings to bigint
|
|
8
|
+
* @param challenge
|
|
9
|
+
*/
|
|
10
|
+
function deserializeNtilde(challenge) {
|
|
11
|
+
return {
|
|
12
|
+
ntilde: util_1.hexToBigInt(challenge.ntilde),
|
|
13
|
+
h1: util_1.hexToBigInt(challenge.h1),
|
|
14
|
+
h2: util_1.hexToBigInt(challenge.h2),
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
exports.deserializeNtilde = deserializeNtilde;
|
|
18
|
+
/**
|
|
19
|
+
* Serializes a challenge from big int to hex strings.
|
|
20
|
+
* @param challenge
|
|
21
|
+
*/
|
|
22
|
+
function serializeNtilde(challenge) {
|
|
23
|
+
return {
|
|
24
|
+
ntilde: util_1.bigIntToHex(challenge.ntilde),
|
|
25
|
+
h1: util_1.bigIntToHex(challenge.h1),
|
|
26
|
+
h2: util_1.bigIntToHex(challenge.h2),
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
exports.serializeNtilde = serializeNtilde;
|
|
30
|
+
/**
|
|
31
|
+
* Deserializes a challenge and it's proofs from hex strings to bigint
|
|
32
|
+
* @param challenge
|
|
33
|
+
*/
|
|
34
|
+
function deserializeNtildeWithProofs(challenge) {
|
|
35
|
+
return {
|
|
36
|
+
...deserializeNtilde(challenge),
|
|
37
|
+
ntildeProof: {
|
|
38
|
+
h1WrtH2: {
|
|
39
|
+
alpha: util_1.convertHexArrToBigIntArr(challenge.ntildeProof.h1WrtH2.alpha),
|
|
40
|
+
t: util_1.convertHexArrToBigIntArr(challenge.ntildeProof.h1WrtH2.t),
|
|
41
|
+
},
|
|
42
|
+
h2WrtH1: {
|
|
43
|
+
alpha: util_1.convertHexArrToBigIntArr(challenge.ntildeProof.h2WrtH1.alpha),
|
|
44
|
+
t: util_1.convertHexArrToBigIntArr(challenge.ntildeProof.h2WrtH1.t),
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
exports.deserializeNtildeWithProofs = deserializeNtildeWithProofs;
|
|
50
|
+
/**
|
|
51
|
+
* Serializes a challenge and it's proofs from big int to hex strings.
|
|
52
|
+
* @param challenge
|
|
53
|
+
*/
|
|
54
|
+
function serializeNtildeWithProofs(challenge) {
|
|
55
|
+
return {
|
|
56
|
+
...serializeNtilde(challenge),
|
|
57
|
+
ntildeProof: {
|
|
58
|
+
h1WrtH2: {
|
|
59
|
+
alpha: util_1.convertBigIntArrToHexArr(challenge.ntildeProof.h1WrtH2.alpha),
|
|
60
|
+
t: util_1.convertBigIntArrToHexArr(challenge.ntildeProof.h1WrtH2.t),
|
|
61
|
+
},
|
|
62
|
+
h2WrtH1: {
|
|
63
|
+
alpha: util_1.convertBigIntArrToHexArr(challenge.ntildeProof.h2WrtH1.alpha),
|
|
64
|
+
t: util_1.convertBigIntArrToHexArr(challenge.ntildeProof.h2WrtH1.t),
|
|
65
|
+
},
|
|
66
|
+
},
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
exports.serializeNtildeWithProofs = serializeNtildeWithProofs;
|
|
70
|
+
/**
|
|
71
|
+
* Deserializes a paillier challenge to hex strings.
|
|
72
|
+
* @param challenge
|
|
73
|
+
*/
|
|
74
|
+
function deserializePaillierChallenge(challenge) {
|
|
75
|
+
return {
|
|
76
|
+
p: util_1.convertHexArrToBigIntArr(challenge.p),
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
exports.deserializePaillierChallenge = deserializePaillierChallenge;
|
|
80
|
+
/**
|
|
81
|
+
* Deserializes a paillier challenge proof to hex strings.
|
|
82
|
+
* @param challenge
|
|
83
|
+
*/
|
|
84
|
+
function deserializePaillierChallengeProofs(challenge) {
|
|
85
|
+
return {
|
|
86
|
+
sigma: util_1.convertHexArrToBigIntArr(challenge.sigma),
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
exports.deserializePaillierChallengeProofs = deserializePaillierChallengeProofs;
|
|
90
|
+
/**
|
|
91
|
+
* Deserializes a paillier challenge and its proof to hex strings.
|
|
92
|
+
* @param challengeWithProofs
|
|
93
|
+
*/
|
|
94
|
+
function deserializePaillierChallengeWithProofs(challengeWithProofs) {
|
|
95
|
+
return {
|
|
96
|
+
...deserializePaillierChallenge(challengeWithProofs),
|
|
97
|
+
...deserializePaillierChallengeProofs(challengeWithProofs),
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
exports.deserializePaillierChallengeWithProofs = deserializePaillierChallengeWithProofs;
|
|
101
|
+
/**
|
|
102
|
+
* Serializes a paillier challenge to hex strings.
|
|
103
|
+
* @param challenge
|
|
104
|
+
*/
|
|
105
|
+
function serializePaillierChallenge(challenge) {
|
|
106
|
+
return {
|
|
107
|
+
p: util_1.convertBigIntArrToHexArr(challenge.p, 768),
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
exports.serializePaillierChallenge = serializePaillierChallenge;
|
|
111
|
+
/**
|
|
112
|
+
* Serializes a paillier challenge proof to hex strings.
|
|
113
|
+
* @param challenge
|
|
114
|
+
*/
|
|
115
|
+
function serializePaillierChallengeProofs(challenge) {
|
|
116
|
+
return {
|
|
117
|
+
sigma: util_1.convertBigIntArrToHexArr(challenge.sigma, 768),
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
exports.serializePaillierChallengeProofs = serializePaillierChallengeProofs;
|
|
121
|
+
/**
|
|
122
|
+
* Serializes a paillier challenge and its proof to hex strings.
|
|
123
|
+
* @param challengeWithProofs
|
|
124
|
+
*/
|
|
125
|
+
function serializePaillierChallengeWithProofs(challengeWithProofs) {
|
|
126
|
+
return {
|
|
127
|
+
...serializePaillierChallenge(challengeWithProofs),
|
|
128
|
+
...serializePaillierChallengeProofs(challengeWithProofs),
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
exports.serializePaillierChallengeWithProofs = serializePaillierChallengeWithProofs;
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa/types.ts"],"names":[],"mappings":"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","sourcesContent":["// Ntilde Proof where both alpha and t are a set of 128 proofs each.\nimport { bigIntToHex, convertBigIntArrToHexArr, convertHexArrToBigIntArr, hexToBigInt } from '../../util';\n\ninterface NtildeProof<T> {\n  alpha: T[];\n  t: T[];\n}\n\n// Ntilde Proof\ninterface NtildeProofs<T> {\n  h1WrtH2: NtildeProof<T>;\n  h2WrtH1: NtildeProof<T>;\n}\n\n// Ntilde challenge values\ninterface Ntilde<T> {\n  ntilde: T;\n  h1: T;\n  h2: T;\n}\n\nexport type DeserializedNtilde = Ntilde<bigint>;\nexport type SerializedNtilde = Ntilde<string>;\nexport type DeserializedNtildeProof = NtildeProof<bigint>;\nexport type SerializedNtildeProof = NtildeProof<string>;\nexport type DeserializedNtildeProofs = NtildeProofs<bigint>;\nexport type SerializedNtildeProofs = NtildeProofs<string>;\n\n/**\n * The ntilde proofs are done non-interactively,\n * therefore a party generates both ntilde, h1, h2 and the proofs without\n * interaction with the other party.\n */\nexport type DeserializedNtildeWithProofs = DeserializedNtilde & {\n  ntildeProof: DeserializedNtildeProofs;\n};\nexport type SerializedNtildeWithProofs = SerializedNtilde & {\n  ntildeProof: SerializedNtildeProofs;\n};\n\nexport type SerializedEcdsaChallenges = SerializedNtilde & SerializedPaillierChallenge;\n\n/**\n * Deserializes a challenge from hex strings to bigint\n * @param challenge\n */\nexport function deserializeNtilde(challenge: SerializedNtilde): DeserializedNtilde {\n  return {\n    ntilde: hexToBigInt(challenge.ntilde),\n    h1: hexToBigInt(challenge.h1),\n    h2: hexToBigInt(challenge.h2),\n  };\n}\n\n/**\n * Serializes a challenge from big int to hex strings.\n * @param challenge\n */\nexport function serializeNtilde(challenge: DeserializedNtilde): SerializedNtilde {\n  return {\n    ntilde: bigIntToHex(challenge.ntilde),\n    h1: bigIntToHex(challenge.h1),\n    h2: bigIntToHex(challenge.h2),\n  };\n}\n\n/**\n * Deserializes a challenge and it's proofs from hex strings to bigint\n * @param challenge\n */\nexport function deserializeNtildeWithProofs(challenge: SerializedNtildeWithProofs): DeserializedNtildeWithProofs {\n  return {\n    ...deserializeNtilde(challenge),\n    ntildeProof: {\n      h1WrtH2: {\n        alpha: convertHexArrToBigIntArr(challenge.ntildeProof.h1WrtH2.alpha),\n        t: convertHexArrToBigIntArr(challenge.ntildeProof.h1WrtH2.t),\n      },\n      h2WrtH1: {\n        alpha: convertHexArrToBigIntArr(challenge.ntildeProof.h2WrtH1.alpha),\n        t: convertHexArrToBigIntArr(challenge.ntildeProof.h2WrtH1.t),\n      },\n    },\n  };\n}\n\n/**\n * Serializes a challenge and it's proofs from big int to hex strings.\n * @param challenge\n */\nexport function serializeNtildeWithProofs(challenge: DeserializedNtildeWithProofs): SerializedNtildeWithProofs {\n  return {\n    ...serializeNtilde(challenge),\n    ntildeProof: {\n      h1WrtH2: {\n        alpha: convertBigIntArrToHexArr(challenge.ntildeProof.h1WrtH2.alpha),\n        t: convertBigIntArrToHexArr(challenge.ntildeProof.h1WrtH2.t),\n      },\n      h2WrtH1: {\n        alpha: convertBigIntArrToHexArr(challenge.ntildeProof.h2WrtH1.alpha),\n        t: convertBigIntArrToHexArr(challenge.ntildeProof.h2WrtH1.t),\n      },\n    },\n  };\n}\n\ntype PaillierChallenge<T> = {\n  p: T[];\n};\n\ntype PaillierChallengeProof<T> = {\n  sigma: T[];\n};\n\nexport type DeserializedPaillierChallenge = PaillierChallenge<bigint>;\nexport type SerializedPaillierChallenge = PaillierChallenge<string>;\nexport type DeserializedPaillierChallengeProofs = PaillierChallengeProof<bigint>;\nexport type SerializedPaillierChallengeProofs = PaillierChallengeProof<string>;\n/**\n * The paillier proofs are done interactively between two parties.\n * If party A is completing a paillier proof $sigma$ with party B, then $p$ refers to\n * a challenge given to A by B, and $sigma$ represents the proof to the challenge\n */\nexport type DeserializedPaillierChallengeWithProofs = DeserializedPaillierChallenge &\n  DeserializedPaillierChallengeProofs;\nexport type SerializedPaillierChallengeWithProofs = SerializedPaillierChallenge & SerializedPaillierChallengeProofs;\n\n/**\n * Deserializes a paillier challenge to hex strings.\n * @param challenge\n */\nexport function deserializePaillierChallenge(challenge: SerializedPaillierChallenge): DeserializedPaillierChallenge {\n  return {\n    p: convertHexArrToBigIntArr(challenge.p),\n  };\n}\n\n/**\n * Deserializes a paillier challenge proof to hex strings.\n * @param challenge\n */\nexport function deserializePaillierChallengeProofs(\n  challenge: SerializedPaillierChallengeProofs\n): DeserializedPaillierChallengeProofs {\n  return {\n    sigma: convertHexArrToBigIntArr(challenge.sigma),\n  };\n}\n\n/**\n * Deserializes a paillier challenge and its proof to hex strings.\n * @param challengeWithProofs\n */\nexport function deserializePaillierChallengeWithProofs(\n  challengeWithProofs: SerializedPaillierChallengeWithProofs\n): DeserializedPaillierChallengeWithProofs {\n  return {\n    ...deserializePaillierChallenge(challengeWithProofs),\n    ...deserializePaillierChallengeProofs(challengeWithProofs),\n  };\n}\n\n/**\n * Serializes a paillier challenge to hex strings.\n * @param challenge\n */\nexport function serializePaillierChallenge(challenge: DeserializedPaillierChallenge): SerializedPaillierChallenge {\n  return {\n    p: convertBigIntArrToHexArr(challenge.p, 768),\n  };\n}\n\n/**\n * Serializes a paillier challenge proof to hex strings.\n * @param challenge\n */\nexport function serializePaillierChallengeProofs(\n  challenge: DeserializedPaillierChallengeProofs\n): SerializedPaillierChallengeProofs {\n  return {\n    sigma: convertBigIntArrToHexArr(challenge.sigma, 768),\n  };\n}\n\n/**\n * Serializes a paillier challenge and its proof to hex strings.\n * @param challengeWithProofs\n */\nexport function serializePaillierChallengeWithProofs(\n  challengeWithProofs: DeserializedPaillierChallengeWithProofs\n): SerializedPaillierChallengeWithProofs {\n  return {\n    ...serializePaillierChallenge(challengeWithProofs),\n    ...serializePaillierChallengeProofs(challengeWithProofs),\n  };\n}\n\nexport interface RSAModulus {\n  n: bigint;\n  // Sophie Germain primes.\n  q1: bigint;\n  q2: bigint;\n}\n\n// Range proof values\nexport interface RangeProof {\n  z: bigint;\n  u: bigint;\n  w: bigint;\n  s: bigint;\n  s1: bigint;\n  s2: bigint;\n}\n\n// Range proof values\nexport interface RangeProofWithCheck {\n  z: bigint;\n  zprm: bigint;\n  t: bigint;\n  v: bigint;\n  w: bigint;\n  s: bigint;\n  s1: bigint;\n  s2: bigint;\n  t1: bigint;\n  t2: bigint;\n  u: bigint;\n}\n"]}
|
package/dist/src/tss/index.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export *
|
|
1
|
+
export * from './ecdsa';
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tss/index.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tss/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC"}
|
package/dist/src/tss/index.js
CHANGED
|
@@ -6,19 +6,9 @@ var __createBinding = (this && this.__createBinding) || (Object.create ? (functi
|
|
|
6
6
|
if (k2 === undefined) k2 = k;
|
|
7
7
|
o[k2] = m[k];
|
|
8
8
|
}));
|
|
9
|
-
var
|
|
10
|
-
|
|
11
|
-
}) : function(o, v) {
|
|
12
|
-
o["default"] = v;
|
|
13
|
-
});
|
|
14
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
-
if (mod && mod.__esModule) return mod;
|
|
16
|
-
var result = {};
|
|
17
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
-
__setModuleDefault(result, mod);
|
|
19
|
-
return result;
|
|
9
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
20
11
|
};
|
|
21
12
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
|
-
exports
|
|
23
|
-
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdHNzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxpREFBaUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBhcyBFY2RzYSBmcm9tICcuL2VjZHNhJztcbiJdfQ==
|
|
13
|
+
__exportStar(require("./ecdsa"), exports);
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdHNzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQUFBLDBDQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZWNkc2EnO1xuIl19
|
package/dist/src/util.d.ts
CHANGED
|
@@ -1,6 +1,53 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
|
+
import { PublicKey } from 'paillier-bigint';
|
|
3
|
+
/**
|
|
4
|
+
* Returns a bigint array from a hex string array
|
|
5
|
+
* @param values
|
|
6
|
+
*/
|
|
7
|
+
export declare function convertHexArrToBigIntArr(values: string[]): bigint[];
|
|
8
|
+
/**
|
|
9
|
+
* Returns a hex string array from a bigint array
|
|
10
|
+
* @param values
|
|
11
|
+
* @param hexLength - length to pad each big int number too
|
|
12
|
+
*/
|
|
13
|
+
export declare function convertBigIntArrToHexArr(values: bigint[], hexLength?: number): string[];
|
|
14
|
+
export declare function hexToBigInt(hex: string): bigint;
|
|
15
|
+
/**
|
|
16
|
+
* Returns an hex string of the given bigint
|
|
17
|
+
*
|
|
18
|
+
* @param {bigint} bigint - the bigint to be converted to hex
|
|
19
|
+
* @param hexLength
|
|
20
|
+
* @returns {string} - the hex value
|
|
21
|
+
*/
|
|
22
|
+
export declare function bigIntToHex(bigint: bigint, hexLength?: number): string;
|
|
2
23
|
export declare function bigIntToBufferLE(n: bigint, bytes?: number): Buffer;
|
|
3
24
|
export declare function bigIntFromBufferLE(buf: Buffer): bigint;
|
|
4
25
|
export declare function bigIntToBufferBE(n: bigint, bytes?: number): Buffer;
|
|
5
26
|
export declare function bigIntFromBufferBE(buf: Buffer): bigint;
|
|
27
|
+
export declare function bigIntFromU8ABE(buf: Uint8Array): bigint;
|
|
28
|
+
export declare function clamp(u: bigint): bigint;
|
|
29
|
+
/**
|
|
30
|
+
* Function get paillier public key simple varient
|
|
31
|
+
* @param {bigint} n
|
|
32
|
+
* @returns {bigint}
|
|
33
|
+
*/
|
|
34
|
+
export declare function getPaillierPublicKey(n: bigint): PublicKey;
|
|
35
|
+
/**
|
|
36
|
+
* Generate a random positive integer co-prime to x
|
|
37
|
+
* @param x
|
|
38
|
+
* @returns {Promise<bigint>}
|
|
39
|
+
*/
|
|
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>;
|
|
47
|
+
/**
|
|
48
|
+
* Generate a random number of a given bitlength
|
|
49
|
+
* @param bitlength
|
|
50
|
+
* @returns {Promise<bigint>}
|
|
51
|
+
*/
|
|
52
|
+
export declare function randomBigInt(bitlength: number): Promise<bigint>;
|
|
6
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,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"}
|
|
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,58 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.bigIntFromBufferBE = exports.bigIntToBufferBE = exports.bigIntFromBufferLE = exports.bigIntToBufferLE = void 0;
|
|
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
|
+
const paillier_bigint_1 = require("paillier-bigint");
|
|
5
|
+
const bigint_crypto_utils_1 = require("bigint-crypto-utils");
|
|
6
|
+
const bigint_mod_arith_1 = require("bigint-mod-arith");
|
|
7
|
+
/**
|
|
8
|
+
* Returns a bigint array from a hex string array
|
|
9
|
+
* @param values
|
|
10
|
+
*/
|
|
11
|
+
function convertHexArrToBigIntArr(values) {
|
|
12
|
+
return values.map((value) => {
|
|
13
|
+
return hexToBigInt(value);
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
exports.convertHexArrToBigIntArr = convertHexArrToBigIntArr;
|
|
17
|
+
/**
|
|
18
|
+
* Returns a hex string array from a bigint array
|
|
19
|
+
* @param values
|
|
20
|
+
* @param hexLength - length to pad each big int number too
|
|
21
|
+
*/
|
|
22
|
+
function convertBigIntArrToHexArr(values, hexLength) {
|
|
23
|
+
return values.map((value) => {
|
|
24
|
+
return bigIntToHex(value, hexLength);
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
exports.convertBigIntArrToHexArr = convertBigIntArrToHexArr;
|
|
28
|
+
function hexToBigInt(hex) {
|
|
29
|
+
// Strangely bigint.toString(16) gives a hex string without 0x,
|
|
30
|
+
// but it won't accept the same string without 0x to convert
|
|
31
|
+
// to a bigint (BigInt(hex string)). So have to introduce this
|
|
32
|
+
// check to convert to add 0x in case if hex string
|
|
33
|
+
// doesn't have it.
|
|
34
|
+
if (hex.slice(0, 2) === '0x') {
|
|
35
|
+
return BigInt(hex);
|
|
36
|
+
}
|
|
37
|
+
return BigInt('0x' + hex);
|
|
38
|
+
}
|
|
39
|
+
exports.hexToBigInt = hexToBigInt;
|
|
40
|
+
/**
|
|
41
|
+
* Returns an hex string of the given bigint
|
|
42
|
+
*
|
|
43
|
+
* @param {bigint} bigint - the bigint to be converted to hex
|
|
44
|
+
* @param hexLength
|
|
45
|
+
* @returns {string} - the hex value
|
|
46
|
+
*/
|
|
47
|
+
function bigIntToHex(bigint, hexLength) {
|
|
48
|
+
let hex = bigint.toString(16);
|
|
49
|
+
hex = '0'.slice(0, hex.length % 2) + hex;
|
|
50
|
+
if (hexLength) {
|
|
51
|
+
hex = hex.padStart(hexLength, '0');
|
|
52
|
+
}
|
|
53
|
+
return hex;
|
|
54
|
+
}
|
|
55
|
+
exports.bigIntToHex = bigIntToHex;
|
|
4
56
|
function bigIntToBufferLE(n, bytes) {
|
|
5
57
|
let v = n.toString(16);
|
|
6
58
|
v = '0'.slice(0, v.length % 2) + v;
|
|
@@ -29,4 +81,63 @@ function bigIntFromBufferBE(buf) {
|
|
|
29
81
|
return BigInt('0x' + buf.toString('hex'));
|
|
30
82
|
}
|
|
31
83
|
exports.bigIntFromBufferBE = bigIntFromBufferBE;
|
|
32
|
-
|
|
84
|
+
function bigIntFromU8ABE(buf) {
|
|
85
|
+
return bigIntFromBufferBE(Buffer.from(buf));
|
|
86
|
+
}
|
|
87
|
+
exports.bigIntFromU8ABE = bigIntFromU8ABE;
|
|
88
|
+
function clamp(u) {
|
|
89
|
+
u &= BigInt('0x7ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8');
|
|
90
|
+
u |= BigInt('0x4000000000000000000000000000000000000000000000000000000000000000');
|
|
91
|
+
return u;
|
|
92
|
+
}
|
|
93
|
+
exports.clamp = clamp;
|
|
94
|
+
/**
|
|
95
|
+
* Function get paillier public key simple varient
|
|
96
|
+
* @param {bigint} n
|
|
97
|
+
* @returns {bigint}
|
|
98
|
+
*/
|
|
99
|
+
function getPaillierPublicKey(n) {
|
|
100
|
+
return new paillier_bigint_1.PublicKey(n, n + BigInt(1));
|
|
101
|
+
}
|
|
102
|
+
exports.getPaillierPublicKey = getPaillierPublicKey;
|
|
103
|
+
/**
|
|
104
|
+
* Generate a random positive integer co-prime to x
|
|
105
|
+
* @param x
|
|
106
|
+
* @returns {Promise<bigint>}
|
|
107
|
+
*/
|
|
108
|
+
async function randomPositiveCoPrimeTo(x) {
|
|
109
|
+
while (true) {
|
|
110
|
+
const y = await randomBigInt(bigint_crypto_utils_1.bitLength(x));
|
|
111
|
+
if (y > BigInt(0) && bigint_mod_arith_1.gcd(x, y) === BigInt(1)) {
|
|
112
|
+
return y;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}
|
|
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;
|
|
134
|
+
/**
|
|
135
|
+
* Generate a random number of a given bitlength
|
|
136
|
+
* @param bitlength
|
|
137
|
+
* @returns {Promise<bigint>}
|
|
138
|
+
*/
|
|
139
|
+
async function randomBigInt(bitlength) {
|
|
140
|
+
return bigIntFromBufferBE(Buffer.from(await bigint_crypto_utils_1.randBits(bitlength, true)));
|
|
141
|
+
}
|
|
142
|
+
exports.randomBigInt = randomBigInt;
|
|
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"]}
|
|
@@ -166,21 +166,6 @@
|
|
|
166
166
|
"signature": "506b80b9951c9381dc5f11897b31fca5e2a65731d96ddefa19687fbc26b23c6e",
|
|
167
167
|
"affectsGlobalScope": true
|
|
168
168
|
},
|
|
169
|
-
"../src/tss/ecdsa/types.ts": {
|
|
170
|
-
"version": "fafc5910768b8c9b0a465b351eb95790cdc80c0662ff08d1dae854a5139c82c1",
|
|
171
|
-
"signature": "e9092beb32fa8bf79cb3d15b4244861b9b3cb58a82f58d5ebdab1c753f47767a",
|
|
172
|
-
"affectsGlobalScope": false
|
|
173
|
-
},
|
|
174
|
-
"../src/curves/baseCurve.ts": {
|
|
175
|
-
"version": "42db9e1cbeff410125f481ab98ce4b1feee9576fad7709e222f43d8bbbd505dc",
|
|
176
|
-
"signature": "378aa4af3f4566fcefd59441cb22863fe74f53ab88f32de586f6c2d254e4a11a",
|
|
177
|
-
"affectsGlobalScope": false
|
|
178
|
-
},
|
|
179
|
-
"../src/curves/index.ts": {
|
|
180
|
-
"version": "9a6ea5199f2a0541be2428fa2f90a985bb0c248deff61fe806342a70cb995f33",
|
|
181
|
-
"signature": "31a560d2dd5fb1dc1d4dd2be36d7268776329f13eaf049656bfcf3ec5c71d2c3",
|
|
182
|
-
"affectsGlobalScope": false
|
|
183
|
-
},
|
|
184
169
|
"../../../node_modules/paillier-bigint/types/PublicKey.d.ts": {
|
|
185
170
|
"version": "2755882608d931e0eed4ba7ab0161124973ac6e3fa156fac2bd9a3c77d4d1f02",
|
|
186
171
|
"signature": "2755882608d931e0eed4ba7ab0161124973ac6e3fa156fac2bd9a3c77d4d1f02",
|
|
@@ -507,8 +492,33 @@
|
|
|
507
492
|
"affectsGlobalScope": false
|
|
508
493
|
},
|
|
509
494
|
"../src/util.ts": {
|
|
510
|
-
"version": "
|
|
511
|
-
"signature": "
|
|
495
|
+
"version": "fd31445d8f629550b620ddcd943aaa9ed900840b3fb7ec5f14398791298f9dc5",
|
|
496
|
+
"signature": "ba550feb8b9e414177b5401a7f23efc1c2d31a0dd9666c365b7c66e2016e7177",
|
|
497
|
+
"affectsGlobalScope": false
|
|
498
|
+
},
|
|
499
|
+
"../src/tss/ecdsa/types.ts": {
|
|
500
|
+
"version": "c7a03a5ca457650449b39b11fb7c2b78066d5aa0feb44f794f74f4463542e8a7",
|
|
501
|
+
"signature": "cfe1012f8175c674dd19a39cf93391a0103aebd465920faa6718842bd1740389",
|
|
502
|
+
"affectsGlobalScope": false
|
|
503
|
+
},
|
|
504
|
+
"../src/curves/baseCurve.ts": {
|
|
505
|
+
"version": "16082093c420773965931b50cb4ecdc75c36fdcecd6b941b91d1690fcb3cddd3",
|
|
506
|
+
"signature": "d368716cf32dc5ea7975f7b08943b107c57ec5b182ef881cdd20373eb212c0ae",
|
|
507
|
+
"affectsGlobalScope": false
|
|
508
|
+
},
|
|
509
|
+
"../../../node_modules/@noble/secp256k1/lib/index.d.ts": {
|
|
510
|
+
"version": "5a3dcc9298412e6b92b1805ed396d3a208e1de1e6b0d3270d92305c15b1e03b7",
|
|
511
|
+
"signature": "5a3dcc9298412e6b92b1805ed396d3a208e1de1e6b0d3270d92305c15b1e03b7",
|
|
512
|
+
"affectsGlobalScope": false
|
|
513
|
+
},
|
|
514
|
+
"../src/curves/secp256k1.ts": {
|
|
515
|
+
"version": "db641606e38f40ac73f286c75138df1005dbbf1a0a6568a978006750761fcc2e",
|
|
516
|
+
"signature": "355d4c9436c26539ce47bbc3b13b3dcbea9364f78b2a68c37360348e88eaeb04",
|
|
517
|
+
"affectsGlobalScope": false
|
|
518
|
+
},
|
|
519
|
+
"../src/curves/index.ts": {
|
|
520
|
+
"version": "af95cea7b6bdd53cb01afd28ef16481871806cfba81019716a16f56bcbf6296c",
|
|
521
|
+
"signature": "5c57cfc1e2eefc34d61c967318d06439fcb7d2c0a84b3fad179eca46aab43f58",
|
|
512
522
|
"affectsGlobalScope": false
|
|
513
523
|
},
|
|
514
524
|
"../../../node_modules/@wasmer/wasi/dist/pkg/wasmer_wasi_js.d.ts": {
|
|
@@ -537,23 +547,33 @@
|
|
|
537
547
|
"affectsGlobalScope": false
|
|
538
548
|
},
|
|
539
549
|
"../src/tss/ecdsa/rangeproof.ts": {
|
|
540
|
-
"version": "
|
|
541
|
-
"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",
|
|
542
562
|
"affectsGlobalScope": false
|
|
543
563
|
},
|
|
544
564
|
"../src/tss/ecdsa/index.ts": {
|
|
545
|
-
"version": "
|
|
546
|
-
"signature": "
|
|
565
|
+
"version": "1e8c4bd55bc9bdffadc507eb9ba26e830d34cbda68c5f074ec1f03a2e1c09072",
|
|
566
|
+
"signature": "b9707f86e0e401b657ed40193fcae1cff492e43c201624f9a72aef2f328d76b7",
|
|
547
567
|
"affectsGlobalScope": false
|
|
548
568
|
},
|
|
549
569
|
"../src/tss/index.ts": {
|
|
550
|
-
"version": "
|
|
551
|
-
"signature": "
|
|
570
|
+
"version": "989d9dc97f194f8af5ac1cd74b4cf1bc4078bdd99c9a48f6b9aa9db9ad7f48f1",
|
|
571
|
+
"signature": "a92e95f58dd6504c0723e1edd377139e9861a7861f175d3ca62142eba1ae72c4",
|
|
552
572
|
"affectsGlobalScope": false
|
|
553
573
|
},
|
|
554
574
|
"../src/index.ts": {
|
|
555
|
-
"version": "
|
|
556
|
-
"signature": "
|
|
575
|
+
"version": "e1f3d3827d13ac0e8aaff65905936e016fe8ca8c9d7dc16917dcf38b9e641942",
|
|
576
|
+
"signature": "13a8e31ae2b0004e4fab84b790e9a8bc0faf140c53c20e7d55af61ba4eebb18f",
|
|
557
577
|
"affectsGlobalScope": false
|
|
558
578
|
},
|
|
559
579
|
"../../../node_modules/bignumber.js/bignumber.d.ts": {
|
|
@@ -562,8 +582,8 @@
|
|
|
562
582
|
"affectsGlobalScope": false
|
|
563
583
|
},
|
|
564
584
|
"../../../types/bignumber.js/index.d.ts": {
|
|
565
|
-
"version": "
|
|
566
|
-
"signature": "
|
|
585
|
+
"version": "1cf13a0e412ccde6ac154f59ad8e7c04ec603951a090c7799e107e5aff594c5c",
|
|
586
|
+
"signature": "1cf13a0e412ccde6ac154f59ad8e7c04ec603951a090c7799e107e5aff594c5c",
|
|
567
587
|
"affectsGlobalScope": false
|
|
568
588
|
},
|
|
569
589
|
"../../../types/express/index.d.ts": {
|
|
@@ -577,8 +597,8 @@
|
|
|
577
597
|
"affectsGlobalScope": true
|
|
578
598
|
},
|
|
579
599
|
"../../../types/should-sinon/index.d.ts": {
|
|
580
|
-
"version": "
|
|
581
|
-
"signature": "
|
|
600
|
+
"version": "4de163cf9037509faf9276540c717c0879309ee4e385b5ccfe6de54868d50de1",
|
|
601
|
+
"signature": "4de163cf9037509faf9276540c717c0879309ee4e385b5ccfe6de54868d50de1",
|
|
582
602
|
"affectsGlobalScope": false
|
|
583
603
|
},
|
|
584
604
|
"../../../node_modules/@types/cookiejar/index.d.ts": {
|
|
@@ -1446,10 +1466,17 @@
|
|
|
1446
1466
|
},
|
|
1447
1467
|
"referencedMap": {
|
|
1448
1468
|
"../src/curves/index.ts": [
|
|
1449
|
-
"../src/curves/baseCurve.ts"
|
|
1469
|
+
"../src/curves/baseCurve.ts",
|
|
1470
|
+
"../src/curves/secp256k1.ts"
|
|
1471
|
+
],
|
|
1472
|
+
"../src/curves/secp256k1.ts": [
|
|
1473
|
+
"../../../node_modules/@noble/secp256k1/lib/index.d.ts",
|
|
1474
|
+
"../src/curves/baseCurve.ts",
|
|
1475
|
+
"../src/util.ts"
|
|
1450
1476
|
],
|
|
1451
1477
|
"../src/index.ts": [
|
|
1452
1478
|
"../src/curves/index.ts",
|
|
1479
|
+
"../src/openssl/index.ts",
|
|
1453
1480
|
"../src/tss/index.ts",
|
|
1454
1481
|
"../src/util.ts"
|
|
1455
1482
|
],
|
|
@@ -1461,9 +1488,17 @@
|
|
|
1461
1488
|
"../src/openssl/opensslbytes.ts"
|
|
1462
1489
|
],
|
|
1463
1490
|
"../src/tss/ecdsa/index.ts": [
|
|
1491
|
+
"../src/tss/ecdsa/paillierproof.ts",
|
|
1464
1492
|
"../src/tss/ecdsa/rangeproof.ts",
|
|
1465
1493
|
"../src/tss/ecdsa/types.ts"
|
|
1466
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
|
+
],
|
|
1467
1502
|
"../src/tss/ecdsa/rangeproof.ts": [
|
|
1468
1503
|
"../../../node_modules/@types/node/crypto.d.ts",
|
|
1469
1504
|
"../../../node_modules/bigint-crypto-utils/types/index.d.ts",
|
|
@@ -1471,12 +1506,21 @@
|
|
|
1471
1506
|
"../../../node_modules/paillier-bigint/types/index.d.ts",
|
|
1472
1507
|
"../src/curves/index.ts",
|
|
1473
1508
|
"../src/openssl/index.ts",
|
|
1509
|
+
"../src/tss/ecdsa/index.ts",
|
|
1474
1510
|
"../src/tss/ecdsa/types.ts",
|
|
1475
1511
|
"../src/util.ts"
|
|
1476
1512
|
],
|
|
1513
|
+
"../src/tss/ecdsa/types.ts": [
|
|
1514
|
+
"../src/util.ts"
|
|
1515
|
+
],
|
|
1477
1516
|
"../src/tss/index.ts": [
|
|
1478
1517
|
"../src/tss/ecdsa/index.ts"
|
|
1479
1518
|
],
|
|
1519
|
+
"../src/util.ts": [
|
|
1520
|
+
"../../../node_modules/bigint-crypto-utils/types/index.d.ts",
|
|
1521
|
+
"../../../node_modules/bigint-mod-arith/types/index.d.ts",
|
|
1522
|
+
"../../../node_modules/paillier-bigint/types/index.d.ts"
|
|
1523
|
+
],
|
|
1480
1524
|
"../../../node_modules/@types/bn.js/index.d.ts": [
|
|
1481
1525
|
"../../../node_modules/@types/node/index.d.ts"
|
|
1482
1526
|
],
|
|
@@ -2378,10 +2422,15 @@
|
|
|
2378
2422
|
},
|
|
2379
2423
|
"exportedModulesMap": {
|
|
2380
2424
|
"../src/curves/index.ts": [
|
|
2425
|
+
"../src/curves/baseCurve.ts",
|
|
2426
|
+
"../src/curves/secp256k1.ts"
|
|
2427
|
+
],
|
|
2428
|
+
"../src/curves/secp256k1.ts": [
|
|
2381
2429
|
"../src/curves/baseCurve.ts"
|
|
2382
2430
|
],
|
|
2383
2431
|
"../src/index.ts": [
|
|
2384
2432
|
"../src/curves/index.ts",
|
|
2433
|
+
"../src/openssl/index.ts",
|
|
2385
2434
|
"../src/tss/index.ts",
|
|
2386
2435
|
"../src/util.ts"
|
|
2387
2436
|
],
|
|
@@ -2389,6 +2438,7 @@
|
|
|
2389
2438
|
"../src/openssl/openssl.ts"
|
|
2390
2439
|
],
|
|
2391
2440
|
"../src/tss/ecdsa/index.ts": [
|
|
2441
|
+
"../src/tss/ecdsa/paillierproof.ts",
|
|
2392
2442
|
"../src/tss/ecdsa/rangeproof.ts",
|
|
2393
2443
|
"../src/tss/ecdsa/types.ts"
|
|
2394
2444
|
],
|
|
@@ -2400,6 +2450,9 @@
|
|
|
2400
2450
|
"../src/tss/index.ts": [
|
|
2401
2451
|
"../src/tss/ecdsa/index.ts"
|
|
2402
2452
|
],
|
|
2453
|
+
"../src/util.ts": [
|
|
2454
|
+
"../../../node_modules/paillier-bigint/types/index.d.ts"
|
|
2455
|
+
],
|
|
2403
2456
|
"../../../node_modules/@types/bn.js/index.d.ts": [
|
|
2404
2457
|
"../../../node_modules/@types/node/index.d.ts"
|
|
2405
2458
|
],
|
|
@@ -3302,15 +3355,19 @@
|
|
|
3302
3355
|
"semanticDiagnosticsPerFile": [
|
|
3303
3356
|
"../src/curves/baseCurve.ts",
|
|
3304
3357
|
"../src/curves/index.ts",
|
|
3358
|
+
"../src/curves/secp256k1.ts",
|
|
3305
3359
|
"../src/index.ts",
|
|
3306
3360
|
"../src/openssl/index.ts",
|
|
3307
3361
|
"../src/openssl/openssl.ts",
|
|
3308
3362
|
"../src/openssl/opensslbytes.ts",
|
|
3309
3363
|
"../src/tss/ecdsa/index.ts",
|
|
3364
|
+
"../src/tss/ecdsa/paillierproof.ts",
|
|
3365
|
+
"../src/tss/ecdsa/primes.ts",
|
|
3310
3366
|
"../src/tss/ecdsa/rangeproof.ts",
|
|
3311
3367
|
"../src/tss/ecdsa/types.ts",
|
|
3312
3368
|
"../src/tss/index.ts",
|
|
3313
3369
|
"../src/util.ts",
|
|
3370
|
+
"../../../node_modules/@noble/secp256k1/lib/index.d.ts",
|
|
3314
3371
|
"../../../node_modules/@types/archy/index.d.ts",
|
|
3315
3372
|
"../../../node_modules/@types/argparse/index.d.ts",
|
|
3316
3373
|
"../../../node_modules/@types/aria-query/index.d.ts",
|