@bitgo-beta/sdk-lib-mpc 8.2.0-beta.4 → 8.2.0-beta.41
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/tss/ecdsa/index.d.ts +1 -1
- package/dist/src/tss/ecdsa/index.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/index.js +3 -3
- package/dist/src/tss/ecdsa/{pallierproof.d.ts → paillierproof.d.ts} +7 -6
- 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/types.d.ts +23 -22
- package/dist/src/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/types.js +26 -26
- package/dist/src/util.d.ts +1 -1
- package/dist/src/util.js +2 -2
- package/dist/tsconfig.tsbuildinfo +13 -13
- package/package.json +2 -2
- package/dist/src/tss/ecdsa/pallierproof.d.ts.map +0 -1
- package/dist/src/tss/ecdsa/pallierproof.js +0 -86
package/CHANGELOG.md
CHANGED
|
@@ -2,3 +2,37 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
|
+
|
|
6
|
+
# [8.5.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-lib-mpc@8.4.0...@bitgo/sdk-lib-mpc@8.5.0) (2023-06-13)
|
|
7
|
+
|
|
8
|
+
### Features
|
|
9
|
+
|
|
10
|
+
- **sdk-core:** make paillier proofs mandatory ([4c62dd8](https://github.com/BitGo/BitGoJS/commit/4c62dd8bae41b0a66a4aa840c16f2cdf5abc9997))
|
|
11
|
+
|
|
12
|
+
# [8.4.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-lib-mpc@8.3.1...@bitgo/sdk-lib-mpc@8.4.0) (2023-06-05)
|
|
13
|
+
|
|
14
|
+
### Bug Fixes
|
|
15
|
+
|
|
16
|
+
- **sdk-lib-mpc:** add retry to generateModulus fn ([95b1598](https://github.com/BitGo/BitGoJS/commit/95b1598b32743a69fea3b4cd9365216b693b6c59))
|
|
17
|
+
- **sdk-lib-mpc:** pallier -> paillier ([e4182d4](https://github.com/BitGo/BitGoJS/commit/e4182d4457b1fb14d0df71d7db769e61970864fe))
|
|
18
|
+
- **sdk-lib-mpc:** pallier -> paillier ([9d0a12d](https://github.com/BitGo/BitGoJS/commit/9d0a12dd1d2e1d6e3107f62e2757263fb2fd258e))
|
|
19
|
+
|
|
20
|
+
### Features
|
|
21
|
+
|
|
22
|
+
- **root:** add optional paillier proof plumbing ([18093bf](https://github.com/BitGo/BitGoJS/commit/18093bfc370745130958075349814d493d5a8c72))
|
|
23
|
+
- **sdk-core:** paillier proof user<>backup ([8c0a381](https://github.com/BitGo/BitGoJS/commit/8c0a381318be2088572e06e34c3627323d7bfe38))
|
|
24
|
+
- **sdk-lib-mpc:** add proof of paillier correctness ([e759a13](https://github.com/BitGo/BitGoJS/commit/e759a13ea0aaf6d88b5ca26c6c75ffa6a27819f1)), closes [#3502](https://github.com/BitGo/BitGoJS/issues/3502)
|
|
25
|
+
- **sdk-lib-mpc:** add tests for palierproof and utils ([7c4674b](https://github.com/BitGo/BitGoJS/commit/7c4674b430741ccb33f4b447b4efca7942ee70e7))
|
|
26
|
+
- **sdk-lib-mpc:** make rangeProof challenges mandatory for appendChallenge ([1f68b30](https://github.com/BitGo/BitGoJS/commit/1f68b30676966720cb1a42c039e35d3ddeea4974))
|
|
27
|
+
- **sdk-lib-mpc:** move randomCoPrimeLessThan to utils ([5c2f7f2](https://github.com/BitGo/BitGoJS/commit/5c2f7f233858ff695081e86f827e0e72f99c27f7))
|
|
28
|
+
- **sdk-lib-mpc:** optimize pallier proof prove,verify ([c1a9c1e](https://github.com/BitGo/BitGoJS/commit/c1a9c1eff5d65c89341351b9dbc5750b3e5bd4a6))
|
|
29
|
+
|
|
30
|
+
## [8.3.1](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-lib-mpc@8.3.0...@bitgo/sdk-lib-mpc@8.3.1) (2023-05-25)
|
|
31
|
+
|
|
32
|
+
**Note:** Version bump only for package @bitgo/sdk-lib-mpc
|
|
33
|
+
|
|
34
|
+
# 8.3.0 (2023-05-17)
|
|
35
|
+
|
|
36
|
+
### Features
|
|
37
|
+
|
|
38
|
+
- **sdk-lib-mpc:** init module with range proof ([bfd8368](https://github.com/BitGo/BitGoJS/commit/bfd836823f6dd7596924421b9066f5186b0df186))
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export * as EcdsaTypes from './types';
|
|
2
2
|
export * as EcdsaRangeProof from './rangeproof';
|
|
3
|
-
export * as
|
|
3
|
+
export * as EcdsaPaillierProof from './paillierproof';
|
|
4
4
|
export declare const minModulusBitLength = 3072;
|
|
5
5
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,UAAU,MAAM,SAAS,CAAC;AACtC,OAAO,KAAK,eAAe,MAAM,cAAc,CAAC;AAChD,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,UAAU,MAAM,SAAS,CAAC;AACtC,OAAO,KAAK,eAAe,MAAM,cAAc,CAAC;AAChD,OAAO,KAAK,kBAAkB,MAAM,iBAAiB,CAAC;AAEtD,eAAO,MAAM,mBAAmB,OAAO,CAAC"}
|
|
@@ -19,9 +19,9 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
19
19
|
return result;
|
|
20
20
|
};
|
|
21
21
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
|
-
exports.minModulusBitLength = exports.
|
|
22
|
+
exports.minModulusBitLength = exports.EcdsaPaillierProof = exports.EcdsaRangeProof = exports.EcdsaTypes = void 0;
|
|
23
23
|
exports.EcdsaTypes = __importStar(require("./types"));
|
|
24
24
|
exports.EcdsaRangeProof = __importStar(require("./rangeproof"));
|
|
25
|
-
exports.
|
|
25
|
+
exports.EcdsaPaillierProof = __importStar(require("./paillierproof"));
|
|
26
26
|
exports.minModulusBitLength = 3072;
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHNzL2VjZHNhL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxzREFBc0M7QUFDdEMsZ0VBQWdEO0FBQ2hELHNFQUFzRDtBQUV6QyxRQUFBLG1CQUFtQixHQUFHLElBQUksQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGFzIEVjZHNhVHlwZXMgZnJvbSAnLi90eXBlcyc7XG5leHBvcnQgKiBhcyBFY2RzYVJhbmdlUHJvb2YgZnJvbSAnLi9yYW5nZXByb29mJztcbmV4cG9ydCAqIGFzIEVjZHNhUGFpbGxpZXJQcm9vZiBmcm9tICcuL3BhaWxsaWVycHJvb2YnO1xuXG5leHBvcnQgY29uc3QgbWluTW9kdWx1c0JpdExlbmd0aCA9IDMwNzI7XG4iXX0=
|
|
@@ -1,13 +1,14 @@
|
|
|
1
|
+
export declare const alpha = 319567;
|
|
1
2
|
export declare const m: number;
|
|
2
3
|
/**
|
|
3
|
-
* Generate a set of challenges $p$ for a given
|
|
4
|
-
* @param n -
|
|
4
|
+
* Generate a set of challenges $p$ for a given paillier public key modulus $n$.
|
|
5
|
+
* @param n - paillier public key modulus
|
|
5
6
|
* @returns {Promise<Array<bigint>>} - array of challenges $p_i$
|
|
6
7
|
*/
|
|
7
8
|
export declare function generateP(n: bigint): Promise<Array<bigint>>;
|
|
8
9
|
/**
|
|
9
|
-
* Generate a set of proofs $sigma$ for a given set of challenges $p$ using the
|
|
10
|
-
* @param n -
|
|
10
|
+
* Generate a set of proofs $sigma$ for a given set of challenges $p$ using the paillier public key modulus $n$ and the private key $\lambda$.
|
|
11
|
+
* @param n - paillier public key modulus $n$
|
|
11
12
|
* @param lambda - private key $\lambda, which is the $\euler(N) = (p-1)(q-1)$
|
|
12
13
|
* @param p - array of challenges $p$
|
|
13
14
|
* @returns {Promise<Array<bigint>>} - array of proofs $\sigma$
|
|
@@ -15,9 +16,9 @@ export declare function generateP(n: bigint): Promise<Array<bigint>>;
|
|
|
15
16
|
export declare function prove(n: bigint, lambda: bigint, p: Array<bigint>): bigint[];
|
|
16
17
|
/**
|
|
17
18
|
* Verify a set of proofs $\sigma$ on the modulus $n$ using the challenges $p$ that were provided to the prover to generate the proofs.
|
|
18
|
-
* @param n -
|
|
19
|
+
* @param n - paillier public key modulus $n$
|
|
19
20
|
* @param p - array of challenges $p$
|
|
20
21
|
* @param sigma - array of proofs $\sigma$
|
|
21
22
|
*/
|
|
22
23
|
export declare function verify(n: bigint, p: Array<bigint>, sigma: Array<bigint>): boolean;
|
|
23
|
-
//# sourceMappingURL=
|
|
24
|
+
//# sourceMappingURL=paillierproof.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"paillierproof.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa/paillierproof.ts"],"names":[],"mappings":"AAWA,eAAO,MAAM,KAAK,SAAS,CAAC;AAC5B,eAAO,MAAM,CAAC,QAAkC,CAAC;AAEjD;;;;GAIG;AACH,wBAAsB,SAAS,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CASjE;AAED;;;;;;GAMG;AACH,wBAAgB,KAAK,CAAC,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,GAAG,MAAM,EAAE,CAM3E;AAED;;;;;GAKG;AACH,wBAAgB,MAAM,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,GAAG,OAAO,CAkCjF"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.verify = exports.prove = exports.generateP = exports.m = exports.alpha = void 0;
|
|
4
|
+
const bigint_crypto_utils_1 = require("bigint-crypto-utils");
|
|
5
|
+
const bigint_mod_arith_1 = require("bigint-mod-arith");
|
|
6
|
+
const util_1 = require("../../util");
|
|
7
|
+
const index_1 = require("./index");
|
|
8
|
+
const primes_1 = require("./primes");
|
|
9
|
+
// Security parameters.
|
|
10
|
+
const k = 128;
|
|
11
|
+
// eprint.iacr.org/2018/057.pdf#page6 section 5
|
|
12
|
+
// https://github.com/BitGo/BitGoJS/pull/3502#discussion_r1203070392
|
|
13
|
+
exports.alpha = 319567;
|
|
14
|
+
exports.m = Math.ceil(k / Math.log2(exports.alpha));
|
|
15
|
+
/**
|
|
16
|
+
* Generate a set of challenges $p$ for a given paillier public key modulus $n$.
|
|
17
|
+
* @param n - paillier public key modulus
|
|
18
|
+
* @returns {Promise<Array<bigint>>} - array of challenges $p_i$
|
|
19
|
+
*/
|
|
20
|
+
async function generateP(n) {
|
|
21
|
+
if (bigint_crypto_utils_1.bitLength(n) < index_1.minModulusBitLength) {
|
|
22
|
+
throw new Error(`modulus n must have a bit length larger than or equal to ${index_1.minModulusBitLength}`);
|
|
23
|
+
}
|
|
24
|
+
return Promise.all(Array(exports.m)
|
|
25
|
+
.fill(null)
|
|
26
|
+
.map(() => util_1.randomPositiveCoPrimeLessThan(n)));
|
|
27
|
+
}
|
|
28
|
+
exports.generateP = generateP;
|
|
29
|
+
/**
|
|
30
|
+
* Generate a set of proofs $sigma$ for a given set of challenges $p$ using the paillier public key modulus $n$ and the private key $\lambda$.
|
|
31
|
+
* @param n - paillier public key modulus $n$
|
|
32
|
+
* @param lambda - private key $\lambda, which is the $\euler(N) = (p-1)(q-1)$
|
|
33
|
+
* @param p - array of challenges $p$
|
|
34
|
+
* @returns {Promise<Array<bigint>>} - array of proofs $\sigma$
|
|
35
|
+
*/
|
|
36
|
+
function prove(n, lambda, p) {
|
|
37
|
+
if (!p.every((p_i) => p_i > 0)) {
|
|
38
|
+
throw new Error('All paillier challenge values must be positive.');
|
|
39
|
+
}
|
|
40
|
+
const n_inv = bigint_mod_arith_1.modInv(n, lambda);
|
|
41
|
+
return p.map((p_i) => bigint_mod_arith_1.modPow(p_i, n_inv, n));
|
|
42
|
+
}
|
|
43
|
+
exports.prove = prove;
|
|
44
|
+
/**
|
|
45
|
+
* Verify a set of proofs $\sigma$ on the modulus $n$ using the challenges $p$ that were provided to the prover to generate the proofs.
|
|
46
|
+
* @param n - paillier public key modulus $n$
|
|
47
|
+
* @param p - array of challenges $p$
|
|
48
|
+
* @param sigma - array of proofs $\sigma$
|
|
49
|
+
*/
|
|
50
|
+
function verify(n, p, sigma) {
|
|
51
|
+
if (!p.every((p_i) => p_i > 0)) {
|
|
52
|
+
throw new Error('All paillier challenge values must be positive.');
|
|
53
|
+
}
|
|
54
|
+
if (!sigma.every((sigma_i) => sigma_i > 0)) {
|
|
55
|
+
throw new Error('All paillier challenge proof values must be positive.');
|
|
56
|
+
}
|
|
57
|
+
// a) Check that $N$ is a positive integer and is not divisible by all
|
|
58
|
+
// the primes less than $\alpha$.
|
|
59
|
+
if (n <= 0) {
|
|
60
|
+
return false;
|
|
61
|
+
}
|
|
62
|
+
if (exports.alpha !== 319567) {
|
|
63
|
+
throw new Error('unsupported alpha value');
|
|
64
|
+
}
|
|
65
|
+
for (const prime of primes_1.primesSmallerThan319567) {
|
|
66
|
+
if (n % BigInt(prime) === BigInt(0)) {
|
|
67
|
+
return false;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
// b) Check that $\sigma_i$ is a positive integer $i = 1...m$.
|
|
71
|
+
if (sigma.length !== exports.m) {
|
|
72
|
+
return false;
|
|
73
|
+
}
|
|
74
|
+
if (!sigma.every((sigma_i) => sigma_i > 0)) {
|
|
75
|
+
return false;
|
|
76
|
+
}
|
|
77
|
+
// c) Verify that $p_i = \sigma_i^N \mod N$ for $i = 1...m$.
|
|
78
|
+
for (let i = 0; i < exports.m; i++) {
|
|
79
|
+
if (p[i] !== bigint_mod_arith_1.modPow(sigma[i], n, n)) {
|
|
80
|
+
return false;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
return true;
|
|
84
|
+
}
|
|
85
|
+
exports.verify = verify;
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFpbGxpZXJwcm9vZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy90c3MvZWNkc2EvcGFpbGxpZXJwcm9vZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSw2REFBZ0Q7QUFDaEQsdURBQWtEO0FBRWxELHFDQUEyRDtBQUMzRCxtQ0FBOEM7QUFDOUMscUNBQW1EO0FBRW5ELHVCQUF1QjtBQUN2QixNQUFNLENBQUMsR0FBRyxHQUFHLENBQUM7QUFDZCwrQ0FBK0M7QUFDL0Msb0VBQW9FO0FBQ3ZELFFBQUEsS0FBSyxHQUFHLE1BQU0sQ0FBQztBQUNmLFFBQUEsQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBSyxDQUFDLENBQUMsQ0FBQztBQUVqRDs7OztHQUlHO0FBQ0ksS0FBSyxVQUFVLFNBQVMsQ0FBQyxDQUFTO0lBQ3ZDLElBQUksK0JBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRywyQkFBbUIsRUFBRTtRQUN0QyxNQUFNLElBQUksS0FBSyxDQUFDLDREQUE0RCwyQkFBbUIsRUFBRSxDQUFDLENBQUM7S0FDcEc7SUFDRCxPQUFPLE9BQU8sQ0FBQyxHQUFHLENBQ2hCLEtBQUssQ0FBQyxTQUFDLENBQUM7U0FDTCxJQUFJLENBQUMsSUFBSSxDQUFDO1NBQ1YsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLG9DQUE2QixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQy9DLENBQUM7QUFDSixDQUFDO0FBVEQsOEJBU0M7QUFFRDs7Ozs7O0dBTUc7QUFDSCxTQUFnQixLQUFLLENBQUMsQ0FBUyxFQUFFLE1BQWMsRUFBRSxDQUFnQjtJQUMvRCxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQyxFQUFFO1FBQzlCLE1BQU0sSUFBSSxLQUFLLENBQUMsaURBQWlELENBQUMsQ0FBQztLQUNwRTtJQUNELE1BQU0sS0FBSyxHQUFHLHlCQUFNLENBQUMsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ2hDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMseUJBQU0sQ0FBQyxHQUFHLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDL0MsQ0FBQztBQU5ELHNCQU1DO0FBRUQ7Ozs7O0dBS0c7QUFDSCxTQUFnQixNQUFNLENBQUMsQ0FBUyxFQUFFLENBQWdCLEVBQUUsS0FBb0I7SUFDdEUsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUMsRUFBRTtRQUM5QixNQUFNLElBQUksS0FBSyxDQUFDLGlEQUFpRCxDQUFDLENBQUM7S0FDcEU7SUFDRCxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxHQUFHLENBQUMsQ0FBQyxFQUFFO1FBQzFDLE1BQU0sSUFBSSxLQUFLLENBQUMsdURBQXVELENBQUMsQ0FBQztLQUMxRTtJQUNELHNFQUFzRTtJQUN0RSxpQ0FBaUM7SUFDakMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFO1FBQ1YsT0FBTyxLQUFLLENBQUM7S0FDZDtJQUNELElBQUksYUFBSyxLQUFLLE1BQU0sRUFBRTtRQUNwQixNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7S0FDNUM7SUFDRCxLQUFLLE1BQU0sS0FBSyxJQUFJLGdDQUF1QixFQUFFO1FBQzNDLElBQUksQ0FBQyxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsS0FBSyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDbkMsT0FBTyxLQUFLLENBQUM7U0FDZDtLQUNGO0lBQ0QsOERBQThEO0lBQzlELElBQUksS0FBSyxDQUFDLE1BQU0sS0FBSyxTQUFDLEVBQUU7UUFDdEIsT0FBTyxLQUFLLENBQUM7S0FDZDtJQUNELElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDLEVBQUU7UUFDMUMsT0FBTyxLQUFLLENBQUM7S0FDZDtJQUNELDREQUE0RDtJQUM1RCxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsU0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFO1FBQzFCLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLHlCQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRTtZQUNuQyxPQUFPLEtBQUssQ0FBQztTQUNkO0tBQ0Y7SUFDRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUM7QUFsQ0Qsd0JBa0NDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYml0TGVuZ3RoIH0gZnJvbSAnYmlnaW50LWNyeXB0by11dGlscyc7XG5pbXBvcnQgeyBtb2RJbnYsIG1vZFBvdyB9IGZyb20gJ2JpZ2ludC1tb2QtYXJpdGgnO1xuXG5pbXBvcnQgeyByYW5kb21Qb3NpdGl2ZUNvUHJpbWVMZXNzVGhhbiB9IGZyb20gJy4uLy4uL3V0aWwnO1xuaW1wb3J0IHsgbWluTW9kdWx1c0JpdExlbmd0aCB9IGZyb20gJy4vaW5kZXgnO1xuaW1wb3J0IHsgcHJpbWVzU21hbGxlclRoYW4zMTk1NjcgfSBmcm9tICcuL3ByaW1lcyc7XG5cbi8vIFNlY3VyaXR5IHBhcmFtZXRlcnMuXG5jb25zdCBrID0gMTI4O1xuLy8gZXByaW50LmlhY3Iub3JnLzIwMTgvMDU3LnBkZiNwYWdlNiBzZWN0aW9uIDVcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9CaXRHby9CaXRHb0pTL3B1bGwvMzUwMiNkaXNjdXNzaW9uX3IxMjAzMDcwMzkyXG5leHBvcnQgY29uc3QgYWxwaGEgPSAzMTk1Njc7XG5leHBvcnQgY29uc3QgbSA9IE1hdGguY2VpbChrIC8gTWF0aC5sb2cyKGFscGhhKSk7XG5cbi8qKlxuICogR2VuZXJhdGUgYSBzZXQgb2YgY2hhbGxlbmdlcyAkcCQgZm9yIGEgZ2l2ZW4gcGFpbGxpZXIgcHVibGljIGtleSBtb2R1bHVzICRuJC5cbiAqIEBwYXJhbSBuIC0gcGFpbGxpZXIgcHVibGljIGtleSBtb2R1bHVzXG4gKiBAcmV0dXJucyB7UHJvbWlzZTxBcnJheTxiaWdpbnQ+Pn0gLSBhcnJheSBvZiBjaGFsbGVuZ2VzICRwX2kkXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBnZW5lcmF0ZVAobjogYmlnaW50KTogUHJvbWlzZTxBcnJheTxiaWdpbnQ+PiB7XG4gIGlmIChiaXRMZW5ndGgobikgPCBtaW5Nb2R1bHVzQml0TGVuZ3RoKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBtb2R1bHVzIG4gbXVzdCBoYXZlIGEgYml0IGxlbmd0aCBsYXJnZXIgdGhhbiBvciBlcXVhbCB0byAke21pbk1vZHVsdXNCaXRMZW5ndGh9YCk7XG4gIH1cbiAgcmV0dXJuIFByb21pc2UuYWxsKFxuICAgIEFycmF5KG0pXG4gICAgICAuZmlsbChudWxsKVxuICAgICAgLm1hcCgoKSA9PiByYW5kb21Qb3NpdGl2ZUNvUHJpbWVMZXNzVGhhbihuKSlcbiAgKTtcbn1cblxuLyoqXG4gKiBHZW5lcmF0ZSBhIHNldCBvZiBwcm9vZnMgJHNpZ21hJCBmb3IgYSBnaXZlbiBzZXQgb2YgY2hhbGxlbmdlcyAkcCQgdXNpbmcgdGhlIHBhaWxsaWVyIHB1YmxpYyBrZXkgbW9kdWx1cyAkbiQgYW5kIHRoZSBwcml2YXRlIGtleSAkXFxsYW1iZGEkLlxuICogQHBhcmFtIG4gLSBwYWlsbGllciBwdWJsaWMga2V5IG1vZHVsdXMgJG4kXG4gKiBAcGFyYW0gbGFtYmRhIC0gcHJpdmF0ZSBrZXkgJFxcbGFtYmRhLCAgd2hpY2ggaXMgdGhlICRcXGV1bGVyKE4pID0gKHAtMSkocS0xKSRcbiAqIEBwYXJhbSBwIC0gYXJyYXkgb2YgY2hhbGxlbmdlcyAkcCRcbiAqIEByZXR1cm5zIHtQcm9taXNlPEFycmF5PGJpZ2ludD4+fSAtIGFycmF5IG9mIHByb29mcyAkXFxzaWdtYSRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHByb3ZlKG46IGJpZ2ludCwgbGFtYmRhOiBiaWdpbnQsIHA6IEFycmF5PGJpZ2ludD4pOiBiaWdpbnRbXSB7XG4gIGlmICghcC5ldmVyeSgocF9pKSA9PiBwX2kgPiAwKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignQWxsIHBhaWxsaWVyIGNoYWxsZW5nZSB2YWx1ZXMgbXVzdCBiZSBwb3NpdGl2ZS4nKTtcbiAgfVxuICBjb25zdCBuX2ludiA9IG1vZEludihuLCBsYW1iZGEpO1xuICByZXR1cm4gcC5tYXAoKHBfaSkgPT4gbW9kUG93KHBfaSwgbl9pbnYsIG4pKTtcbn1cblxuLyoqXG4gKiBWZXJpZnkgYSBzZXQgb2YgcHJvb2ZzICRcXHNpZ21hJCBvbiB0aGUgbW9kdWx1cyAkbiQgdXNpbmcgdGhlIGNoYWxsZW5nZXMgJHAkIHRoYXQgd2VyZSBwcm92aWRlZCB0byB0aGUgcHJvdmVyIHRvIGdlbmVyYXRlIHRoZSBwcm9vZnMuXG4gKiBAcGFyYW0gbiAtIHBhaWxsaWVyIHB1YmxpYyBrZXkgbW9kdWx1cyAkbiRcbiAqIEBwYXJhbSBwIC0gYXJyYXkgb2YgY2hhbGxlbmdlcyAkcCRcbiAqIEBwYXJhbSBzaWdtYSAtIGFycmF5IG9mIHByb29mcyAkXFxzaWdtYSRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHZlcmlmeShuOiBiaWdpbnQsIHA6IEFycmF5PGJpZ2ludD4sIHNpZ21hOiBBcnJheTxiaWdpbnQ+KTogYm9vbGVhbiB7XG4gIGlmICghcC5ldmVyeSgocF9pKSA9PiBwX2kgPiAwKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignQWxsIHBhaWxsaWVyIGNoYWxsZW5nZSB2YWx1ZXMgbXVzdCBiZSBwb3NpdGl2ZS4nKTtcbiAgfVxuICBpZiAoIXNpZ21hLmV2ZXJ5KChzaWdtYV9pKSA9PiBzaWdtYV9pID4gMCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ0FsbCBwYWlsbGllciBjaGFsbGVuZ2UgcHJvb2YgdmFsdWVzIG11c3QgYmUgcG9zaXRpdmUuJyk7XG4gIH1cbiAgLy8gYSkgQ2hlY2sgdGhhdCAkTiQgaXMgYSBwb3NpdGl2ZSBpbnRlZ2VyIGFuZCBpcyBub3QgZGl2aXNpYmxlIGJ5IGFsbFxuICAvLyB0aGUgcHJpbWVzIGxlc3MgdGhhbiAkXFxhbHBoYSQuXG4gIGlmIChuIDw9IDApIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgaWYgKGFscGhhICE9PSAzMTk1NjcpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ3Vuc3VwcG9ydGVkIGFscGhhIHZhbHVlJyk7XG4gIH1cbiAgZm9yIChjb25zdCBwcmltZSBvZiBwcmltZXNTbWFsbGVyVGhhbjMxOTU2Nykge1xuICAgIGlmIChuICUgQmlnSW50KHByaW1lKSA9PT0gQmlnSW50KDApKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICB9XG4gIC8vIGIpIENoZWNrIHRoYXQgJFxcc2lnbWFfaSQgaXMgYSBwb3NpdGl2ZSBpbnRlZ2VyICRpID0gMS4uLm0kLlxuICBpZiAoc2lnbWEubGVuZ3RoICE9PSBtKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG4gIGlmICghc2lnbWEuZXZlcnkoKHNpZ21hX2kpID0+IHNpZ21hX2kgPiAwKSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuICAvLyBjKSBWZXJpZnkgdGhhdCAkcF9pID0gXFxzaWdtYV9pXk4gXFxtb2QgTiQgZm9yICRpID0gMS4uLm0kLlxuICBmb3IgKGxldCBpID0gMDsgaSA8IG07IGkrKykge1xuICAgIGlmIChwW2ldICE9PSBtb2RQb3coc2lnbWFbaV0sIG4sIG4pKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICB9XG4gIHJldHVybiB0cnVlO1xufVxuIl19
|
|
@@ -28,6 +28,7 @@ export declare type DeserializedNtildeWithProofs = DeserializedNtilde & {
|
|
|
28
28
|
export declare type SerializedNtildeWithProofs = SerializedNtilde & {
|
|
29
29
|
ntildeProof: SerializedNtildeProofs;
|
|
30
30
|
};
|
|
31
|
+
export declare type SerializedEcdsaChallenges = SerializedNtilde & SerializedPaillierChallenge;
|
|
31
32
|
/**
|
|
32
33
|
* Deserializes a challenge from hex strings to bigint
|
|
33
34
|
* @param challenge
|
|
@@ -48,53 +49,53 @@ export declare function deserializeNtildeWithProofs(challenge: SerializedNtildeW
|
|
|
48
49
|
* @param challenge
|
|
49
50
|
*/
|
|
50
51
|
export declare function serializeNtildeWithProofs(challenge: DeserializedNtildeWithProofs): SerializedNtildeWithProofs;
|
|
51
|
-
declare type
|
|
52
|
+
declare type PaillierChallenge<T> = {
|
|
52
53
|
p: T[];
|
|
53
54
|
};
|
|
54
|
-
declare type
|
|
55
|
+
declare type PaillierChallengeProof<T> = {
|
|
55
56
|
sigma: T[];
|
|
56
57
|
};
|
|
57
|
-
export declare type
|
|
58
|
-
export declare type
|
|
59
|
-
export declare type
|
|
60
|
-
export declare type
|
|
58
|
+
export declare type DeserializedPaillierChallenge = PaillierChallenge<bigint>;
|
|
59
|
+
export declare type SerializedPaillierChallenge = PaillierChallenge<string>;
|
|
60
|
+
export declare type DeserializedPaillierChallengeProofs = PaillierChallengeProof<bigint>;
|
|
61
|
+
export declare type SerializedPaillierChallengeProofs = PaillierChallengeProof<string>;
|
|
61
62
|
/**
|
|
62
|
-
* The
|
|
63
|
-
* If party A is completing a
|
|
63
|
+
* The paillier proofs are done interactively between two parties.
|
|
64
|
+
* If party A is completing a paillier proof $sigma$ with party B, then $p$ refers to
|
|
64
65
|
* a challenge given to A by B, and $sigma$ represents the proof to the challenge
|
|
65
66
|
*/
|
|
66
|
-
export declare type
|
|
67
|
-
export declare type
|
|
67
|
+
export declare type DeserializedPaillierChallengeWithProofs = DeserializedPaillierChallenge & DeserializedPaillierChallengeProofs;
|
|
68
|
+
export declare type SerializedPaillierChallengeWithProofs = SerializedPaillierChallenge & SerializedPaillierChallengeProofs;
|
|
68
69
|
/**
|
|
69
|
-
* Deserializes a
|
|
70
|
+
* Deserializes a paillier challenge to hex strings.
|
|
70
71
|
* @param challenge
|
|
71
72
|
*/
|
|
72
|
-
export declare function
|
|
73
|
+
export declare function deserializePaillierChallenge(challenge: SerializedPaillierChallenge): DeserializedPaillierChallenge;
|
|
73
74
|
/**
|
|
74
|
-
* Deserializes a
|
|
75
|
+
* Deserializes a paillier challenge proof to hex strings.
|
|
75
76
|
* @param challenge
|
|
76
77
|
*/
|
|
77
|
-
export declare function
|
|
78
|
+
export declare function deserializePaillierChallengeProofs(challenge: SerializedPaillierChallengeProofs): DeserializedPaillierChallengeProofs;
|
|
78
79
|
/**
|
|
79
|
-
* Deserializes a
|
|
80
|
+
* Deserializes a paillier challenge and its proof to hex strings.
|
|
80
81
|
* @param challengeWithProofs
|
|
81
82
|
*/
|
|
82
|
-
export declare function
|
|
83
|
+
export declare function deserializePaillierChallengeWithProofs(challengeWithProofs: SerializedPaillierChallengeWithProofs): DeserializedPaillierChallengeWithProofs;
|
|
83
84
|
/**
|
|
84
|
-
* Serializes a
|
|
85
|
+
* Serializes a paillier challenge to hex strings.
|
|
85
86
|
* @param challenge
|
|
86
87
|
*/
|
|
87
|
-
export declare function
|
|
88
|
+
export declare function serializePaillierChallenge(challenge: DeserializedPaillierChallenge): SerializedPaillierChallenge;
|
|
88
89
|
/**
|
|
89
|
-
* Serializes a
|
|
90
|
+
* Serializes a paillier challenge proof to hex strings.
|
|
90
91
|
* @param challenge
|
|
91
92
|
*/
|
|
92
|
-
export declare function
|
|
93
|
+
export declare function serializePaillierChallengeProofs(challenge: DeserializedPaillierChallengeProofs): SerializedPaillierChallengeProofs;
|
|
93
94
|
/**
|
|
94
|
-
* Serializes a
|
|
95
|
+
* Serializes a paillier challenge and its proof to hex strings.
|
|
95
96
|
* @param challengeWithProofs
|
|
96
97
|
*/
|
|
97
|
-
export declare function
|
|
98
|
+
export declare function serializePaillierChallengeWithProofs(challengeWithProofs: DeserializedPaillierChallengeWithProofs): SerializedPaillierChallengeWithProofs;
|
|
98
99
|
export interface RSAModulus {
|
|
99
100
|
n: bigint;
|
|
100
101
|
q1: bigint;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa/types.ts"],"names":[],"mappings":"AAGA,UAAU,WAAW,CAAC,CAAC;IACrB,KAAK,EAAE,CAAC,EAAE,CAAC;IACX,CAAC,EAAE,CAAC,EAAE,CAAC;CACR;AAGD,UAAU,YAAY,CAAC,CAAC;IACtB,OAAO,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC;IACxB,OAAO,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC;CACzB;AAGD,UAAU,MAAM,CAAC,CAAC;IAChB,MAAM,EAAE,CAAC,CAAC;IACV,EAAE,EAAE,CAAC,CAAC;IACN,EAAE,EAAE,CAAC,CAAC;CACP;AAED,oBAAY,kBAAkB,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;AAChD,oBAAY,gBAAgB,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;AAC9C,oBAAY,uBAAuB,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC;AAC1D,oBAAY,qBAAqB,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC;AACxD,oBAAY,wBAAwB,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC;AAC5D,oBAAY,sBAAsB,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC;AAE1D;;;;GAIG;AACH,oBAAY,4BAA4B,GAAG,kBAAkB,GAAG;IAC9D,WAAW,EAAE,wBAAwB,CAAC;CACvC,CAAC;AACF,oBAAY,0BAA0B,GAAG,gBAAgB,GAAG;IAC1D,WAAW,EAAE,sBAAsB,CAAC;CACrC,CAAC;AAEF;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,SAAS,EAAE,gBAAgB,GAAG,kBAAkB,CAMjF;AAED;;;GAGG;AACH,wBAAgB,eAAe,CAAC,SAAS,EAAE,kBAAkB,GAAG,gBAAgB,CAM/E;AAED;;;GAGG;AACH,wBAAgB,2BAA2B,CAAC,SAAS,EAAE,0BAA0B,GAAG,4BAA4B,CAc/G;AAED;;;GAGG;AACH,wBAAgB,yBAAyB,CAAC,SAAS,EAAE,4BAA4B,GAAG,0BAA0B,CAc7G;AAED,aAAK,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.serializePaillierChallengeWithProofs = exports.serializePaillierChallengeProofs = exports.serializePaillierChallenge = exports.deserializePaillierChallengeWithProofs = exports.deserializePaillierChallengeProofs = exports.deserializePaillierChallenge = exports.serializeNtildeWithProofs = exports.deserializeNtildeWithProofs = exports.serializeNtilde = exports.deserializeNtilde = void 0;
|
|
4
4
|
// Ntilde Proof where both alpha and t are a set of 128 proofs each.
|
|
5
5
|
const util_1 = require("../../util");
|
|
6
6
|
/**
|
|
@@ -68,65 +68,65 @@ function serializeNtildeWithProofs(challenge) {
|
|
|
68
68
|
}
|
|
69
69
|
exports.serializeNtildeWithProofs = serializeNtildeWithProofs;
|
|
70
70
|
/**
|
|
71
|
-
* Deserializes a
|
|
71
|
+
* Deserializes a paillier challenge to hex strings.
|
|
72
72
|
* @param challenge
|
|
73
73
|
*/
|
|
74
|
-
function
|
|
74
|
+
function deserializePaillierChallenge(challenge) {
|
|
75
75
|
return {
|
|
76
76
|
p: util_1.convertHexArrToBigIntArr(challenge.p),
|
|
77
77
|
};
|
|
78
78
|
}
|
|
79
|
-
exports.
|
|
79
|
+
exports.deserializePaillierChallenge = deserializePaillierChallenge;
|
|
80
80
|
/**
|
|
81
|
-
* Deserializes a
|
|
81
|
+
* Deserializes a paillier challenge proof to hex strings.
|
|
82
82
|
* @param challenge
|
|
83
83
|
*/
|
|
84
|
-
function
|
|
84
|
+
function deserializePaillierChallengeProofs(challenge) {
|
|
85
85
|
return {
|
|
86
86
|
sigma: util_1.convertHexArrToBigIntArr(challenge.sigma),
|
|
87
87
|
};
|
|
88
88
|
}
|
|
89
|
-
exports.
|
|
89
|
+
exports.deserializePaillierChallengeProofs = deserializePaillierChallengeProofs;
|
|
90
90
|
/**
|
|
91
|
-
* Deserializes a
|
|
91
|
+
* Deserializes a paillier challenge and its proof to hex strings.
|
|
92
92
|
* @param challengeWithProofs
|
|
93
93
|
*/
|
|
94
|
-
function
|
|
94
|
+
function deserializePaillierChallengeWithProofs(challengeWithProofs) {
|
|
95
95
|
return {
|
|
96
|
-
|
|
97
|
-
|
|
96
|
+
...deserializePaillierChallenge(challengeWithProofs),
|
|
97
|
+
...deserializePaillierChallengeProofs(challengeWithProofs),
|
|
98
98
|
};
|
|
99
99
|
}
|
|
100
|
-
exports.
|
|
100
|
+
exports.deserializePaillierChallengeWithProofs = deserializePaillierChallengeWithProofs;
|
|
101
101
|
/**
|
|
102
|
-
* Serializes a
|
|
102
|
+
* Serializes a paillier challenge to hex strings.
|
|
103
103
|
* @param challenge
|
|
104
104
|
*/
|
|
105
|
-
function
|
|
105
|
+
function serializePaillierChallenge(challenge) {
|
|
106
106
|
return {
|
|
107
|
-
p: util_1.convertBigIntArrToHexArr(challenge.p,
|
|
107
|
+
p: util_1.convertBigIntArrToHexArr(challenge.p, 768),
|
|
108
108
|
};
|
|
109
109
|
}
|
|
110
|
-
exports.
|
|
110
|
+
exports.serializePaillierChallenge = serializePaillierChallenge;
|
|
111
111
|
/**
|
|
112
|
-
* Serializes a
|
|
112
|
+
* Serializes a paillier challenge proof to hex strings.
|
|
113
113
|
* @param challenge
|
|
114
114
|
*/
|
|
115
|
-
function
|
|
115
|
+
function serializePaillierChallengeProofs(challenge) {
|
|
116
116
|
return {
|
|
117
|
-
sigma: util_1.convertBigIntArrToHexArr(challenge.sigma,
|
|
117
|
+
sigma: util_1.convertBigIntArrToHexArr(challenge.sigma, 768),
|
|
118
118
|
};
|
|
119
119
|
}
|
|
120
|
-
exports.
|
|
120
|
+
exports.serializePaillierChallengeProofs = serializePaillierChallengeProofs;
|
|
121
121
|
/**
|
|
122
|
-
* Serializes a
|
|
122
|
+
* Serializes a paillier challenge and its proof to hex strings.
|
|
123
123
|
* @param challengeWithProofs
|
|
124
124
|
*/
|
|
125
|
-
function
|
|
125
|
+
function serializePaillierChallengeWithProofs(challengeWithProofs) {
|
|
126
126
|
return {
|
|
127
|
-
...
|
|
128
|
-
...
|
|
127
|
+
...serializePaillierChallenge(challengeWithProofs),
|
|
128
|
+
...serializePaillierChallengeProofs(challengeWithProofs),
|
|
129
129
|
};
|
|
130
130
|
}
|
|
131
|
-
exports.
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa/types.ts"],"names":[],"mappings":";;;AAAA,oEAAoE;AACpE,qCAA0G;AAuC1G;;;GAGG;AACH,SAAgB,iBAAiB,CAAC,SAA2B;IAC3D,OAAO;QACL,MAAM,EAAE,kBAAW,CAAC,SAAS,CAAC,MAAM,CAAC;QACrC,EAAE,EAAE,kBAAW,CAAC,SAAS,CAAC,EAAE,CAAC;QAC7B,EAAE,EAAE,kBAAW,CAAC,SAAS,CAAC,EAAE,CAAC;KAC9B,CAAC;AACJ,CAAC;AAND,8CAMC;AAED;;;GAGG;AACH,SAAgB,eAAe,CAAC,SAA6B;IAC3D,OAAO;QACL,MAAM,EAAE,kBAAW,CAAC,SAAS,CAAC,MAAM,CAAC;QACrC,EAAE,EAAE,kBAAW,CAAC,SAAS,CAAC,EAAE,CAAC;QAC7B,EAAE,EAAE,kBAAW,CAAC,SAAS,CAAC,EAAE,CAAC;KAC9B,CAAC;AACJ,CAAC;AAND,0CAMC;AAED;;;GAGG;AACH,SAAgB,2BAA2B,CAAC,SAAqC;IAC/E,OAAO;QACL,GAAG,iBAAiB,CAAC,SAAS,CAAC;QAC/B,WAAW,EAAE;YACX,OAAO,EAAE;gBACP,KAAK,EAAE,+BAAwB,CAAC,SAAS,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC;gBACpE,CAAC,EAAE,+BAAwB,CAAC,SAAS,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;aAC7D;YACD,OAAO,EAAE;gBACP,KAAK,EAAE,+BAAwB,CAAC,SAAS,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC;gBACpE,CAAC,EAAE,+BAAwB,CAAC,SAAS,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;aAC7D;SACF;KACF,CAAC;AACJ,CAAC;AAdD,kEAcC;AAED;;;GAGG;AACH,SAAgB,yBAAyB,CAAC,SAAuC;IAC/E,OAAO;QACL,GAAG,eAAe,CAAC,SAAS,CAAC;QAC7B,WAAW,EAAE;YACX,OAAO,EAAE;gBACP,KAAK,EAAE,+BAAwB,CAAC,SAAS,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC;gBACpE,CAAC,EAAE,+BAAwB,CAAC,SAAS,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;aAC7D;YACD,OAAO,EAAE;gBACP,KAAK,EAAE,+BAAwB,CAAC,SAAS,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC;gBACpE,CAAC,EAAE,+BAAwB,CAAC,SAAS,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;aAC7D;SACF;KACF,CAAC;AACJ,CAAC;AAdD,8DAcC;AAsBD;;;GAGG;AACH,SAAgB,2BAA2B,CAAC,SAAqC;IAC/E,OAAO;QACL,CAAC,EAAE,+BAAwB,CAAC,SAAS,CAAC,CAAC,CAAC;KACzC,CAAC;AACJ,CAAC;AAJD,kEAIC;AAED;;;GAGG;AACH,SAAgB,iCAAiC,CAC/C,SAA2C;IAE3C,OAAO;QACL,KAAK,EAAE,+BAAwB,CAAC,SAAS,CAAC,KAAK,CAAC;KACjD,CAAC;AACJ,CAAC;AAND,8EAMC;AAED;;;GAGG;AACH,SAAgB,qCAAqC,CACnD,mBAAyD;IAEzD,OAAO;QACL,CAAC,EAAE,2BAA2B,CAAC,mBAAmB,CAAC,CAAC,CAAC;QACrD,KAAK,EAAE,iCAAiC,CAAC,mBAAmB,CAAC,CAAC,KAAK;KACpE,CAAC;AACJ,CAAC;AAPD,sFAOC;AAED;;;GAGG;AACH,SAAgB,yBAAyB,CAAC,SAAuC;IAC/E,OAAO;QACL,CAAC,EAAE,+BAAwB,CAAC,SAAS,CAAC,CAAC,EAAE,GAAG,CAAC;KAC9C,CAAC;AACJ,CAAC;AAJD,8DAIC;AAED;;;GAGG;AACH,SAAgB,+BAA+B,CAC7C,SAA6C;IAE7C,OAAO;QACL,KAAK,EAAE,+BAAwB,CAAC,SAAS,CAAC,KAAK,EAAE,GAAG,CAAC;KACtD,CAAC;AACJ,CAAC;AAND,0EAMC;AAED;;;GAGG;AACH,SAAgB,mCAAmC,CACjD,mBAA2D;IAE3D,OAAO;QACL,GAAG,yBAAyB,CAAC,mBAAmB,CAAC;QACjD,GAAG,+BAA+B,CAAC,mBAAmB,CAAC;KACxD,CAAC;AACJ,CAAC;AAPD,kFAOC","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\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 PallierChallenge<T> = {\n  p: T[];\n};\n\ntype PallierChallengeProof<T> = {\n  sigma: T[];\n};\n\nexport type DeserializedPallierChallenge = PallierChallenge<bigint>;\nexport type SerializedPallierChallenge = PallierChallenge<string>;\nexport type DeserializedPallierChallengeProofs = PallierChallengeProof<bigint>;\nexport type SerializedPallierChallengeProofs = PallierChallengeProof<string>;\n/**\n * The pallier proofs are done interactively between two parties.\n * If party A is completing a pallier 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 DeserializedPallierChallengeWithProofs = DeserializedPallierChallenge & DeserializedPallierChallengeProofs;\nexport type SerializedPallierChallengeWithProofs = SerializedPallierChallenge & SerializedPallierChallengeProofs;\n\n/**\n * Deserializes a pallier challenge to hex strings.\n * @param challenge\n */\nexport function deserializePallierChallenge(challenge: SerializedPallierChallenge): DeserializedPallierChallenge {\n  return {\n    p: convertHexArrToBigIntArr(challenge.p),\n  };\n}\n\n/**\n * Deserializes a pallier challenge proof to hex strings.\n * @param challenge\n */\nexport function deserializePallierChallengeProofs(\n  challenge: SerializedPallierChallengeProofs\n): DeserializedPallierChallengeProofs {\n  return {\n    sigma: convertHexArrToBigIntArr(challenge.sigma),\n  };\n}\n\n/**\n * Deserializes a pallier challenge and its proof to hex strings.\n * @param challengeWithProofs\n */\nexport function deserializePallierChallengeWithProofs(\n  challengeWithProofs: SerializedPallierChallengeWithProofs\n): DeserializedPallierChallengeWithProofs {\n  return {\n    p: deserializePallierChallenge(challengeWithProofs).p,\n    sigma: deserializePallierChallengeProofs(challengeWithProofs).sigma,\n  };\n}\n\n/**\n * Serializes a pallier challenge to hex strings.\n * @param challenge\n */\nexport function serializePallierChallenge(challenge: DeserializedPallierChallenge): SerializedPallierChallenge {\n  return {\n    p: convertBigIntArrToHexArr(challenge.p, 384),\n  };\n}\n\n/**\n * Serializes a pallier challenge proof to hex strings.\n * @param challenge\n */\nexport function serializePallierChallengeProofs(\n  challenge: DeserializedPallierChallengeProofs\n): SerializedPallierChallengeProofs {\n  return {\n    sigma: convertBigIntArrToHexArr(challenge.sigma, 384),\n  };\n}\n\n/**\n * Serializes a pallier challenge and its proof to hex strings.\n * @param challengeWithProofs\n */\nexport function serializePallierChallengeWithProofs(\n  challengeWithProofs: DeserializedPallierChallengeWithProofs\n): SerializedPallierChallengeWithProofs {\n  return {\n    ...serializePallierChallenge(challengeWithProofs),\n    ...serializePallierChallengeProofs(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"]}
|
|
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/util.d.ts
CHANGED
|
@@ -27,7 +27,7 @@ export declare function bigIntFromBufferBE(buf: Buffer): bigint;
|
|
|
27
27
|
export declare function bigIntFromU8ABE(buf: Uint8Array): bigint;
|
|
28
28
|
export declare function clamp(u: bigint): bigint;
|
|
29
29
|
/**
|
|
30
|
-
* Function get
|
|
30
|
+
* Function get paillier public key simple varient
|
|
31
31
|
* @param {bigint} n
|
|
32
32
|
* @returns {bigint}
|
|
33
33
|
*/
|
package/dist/src/util.js
CHANGED
|
@@ -92,7 +92,7 @@ function clamp(u) {
|
|
|
92
92
|
}
|
|
93
93
|
exports.clamp = clamp;
|
|
94
94
|
/**
|
|
95
|
-
* Function get
|
|
95
|
+
* Function get paillier public key simple varient
|
|
96
96
|
* @param {bigint} n
|
|
97
97
|
* @returns {bigint}
|
|
98
98
|
*/
|
|
@@ -140,4 +140,4 @@ async function randomBigInt(bitlength) {
|
|
|
140
140
|
return bigIntFromBufferBE(Buffer.from(await bigint_crypto_utils_1.randBits(bitlength, true)));
|
|
141
141
|
}
|
|
142
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 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 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"]}
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":";;;AAAA,qDAA4C;AAC5C,6DAA0D;AAC1D,uDAAuC;AAEvC;;;GAGG;AACH,SAAgB,wBAAwB,CAAC,MAAgB;IACvD,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QAC1B,OAAO,WAAW,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;AACL,CAAC;AAJD,4DAIC;AAED;;;;GAIG;AACH,SAAgB,wBAAwB,CAAC,MAAgB,EAAE,SAAkB;IAC3E,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QAC1B,OAAO,WAAW,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC;AAJD,4DAIC;AAED,SAAgB,WAAW,CAAC,GAAW;IACrC,+DAA+D;IAC/D,4DAA4D;IAC5D,8DAA8D;IAC9D,mDAAmD;IACnD,mBAAmB;IACnB,IAAI,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,EAAE;QAC5B,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC;KACpB;IACD,OAAO,MAAM,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC;AAC5B,CAAC;AAVD,kCAUC;AAED;;;;;;GAMG;AACH,SAAgB,WAAW,CAAC,MAAc,EAAE,SAAkB;IAC5D,IAAI,GAAG,GAAG,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IAC9B,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;IACzC,IAAI,SAAS,EAAE;QACb,GAAG,GAAG,GAAG,CAAC,QAAQ,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;KACpC;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AAPD,kCAOC;AAED,SAAgB,gBAAgB,CAAC,CAAS,EAAE,KAAc;IACxD,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IACvB,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IACnC,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC;IAC5C,IAAI,KAAK,IAAI,GAAG,CAAC,MAAM,GAAG,KAAK,EAAE;QAC/B,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;KAC/D;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AARD,4CAQC;AAED,SAAgB,kBAAkB,CAAC,GAAW;IAC5C,OAAO,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;AACnE,CAAC;AAFD,gDAEC;AAED,SAAgB,gBAAgB,CAAC,CAAS,EAAE,KAAc;IACxD,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IACvB,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IACnC,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;IAClC,IAAI,KAAK,IAAI,GAAG,CAAC,MAAM,GAAG,KAAK,EAAE;QAC/B,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;KAC/D;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AARD,4CAQC;AAED,SAAgB,kBAAkB,CAAC,GAAW;IAC5C,OAAO,MAAM,CAAC,IAAI,GAAG,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;AAC5C,CAAC;AAFD,gDAEC;AAED,SAAgB,eAAe,CAAC,GAAe;IAC7C,OAAO,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AAC9C,CAAC;AAFD,0CAEC;AAED,SAAgB,KAAK,CAAC,CAAS;IAC7B,CAAC,IAAI,MAAM,CAAC,oEAAoE,CAAC,CAAC;IAClF,CAAC,IAAI,MAAM,CAAC,oEAAoE,CAAC,CAAC;IAClF,OAAO,CAAC,CAAC;AACX,CAAC;AAJD,sBAIC;AAED;;;;GAIG;AACH,SAAgB,oBAAoB,CAAC,CAAS;IAC5C,OAAO,IAAI,2BAAS,CAAC,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AACzC,CAAC;AAFD,oDAEC;AAED;;;;GAIG;AACI,KAAK,UAAU,uBAAuB,CAAC,CAAS;IACrD,OAAO,IAAI,EAAE;QACX,MAAM,CAAC,GAAG,MAAM,YAAY,CAAC,+BAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,sBAAG,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,EAAE;YAC5C,OAAO,CAAC,CAAC;SACV;KACF;AACH,CAAC;AAPD,0DAOC;AAED;;;;GAIG;AACI,KAAK,UAAU,6BAA6B,CAAC,CAAS;IAC3D,IAAI,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE;QAClB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;KAC5C;IACD,OAAO,IAAI,EAAE;QACX,MAAM,CAAC,GAAG,MAAM,YAAY,CAAC,+BAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,sBAAG,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,EAAE;YACrD,OAAO,CAAC,CAAC;SACV;KACF;AACH,CAAC;AAVD,sEAUC;AAED;;;;GAIG;AACI,KAAK,UAAU,YAAY,CAAC,SAAiB;IAClD,OAAO,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,8BAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;AAC1E,CAAC;AAFD,oCAEC","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": {
|
|
@@ -556,14 +556,14 @@
|
|
|
556
556
|
"signature": "0d7cac78bc999e97ee5ba5cfa87c6453ed457a6c83786625042e653868edd234",
|
|
557
557
|
"affectsGlobalScope": false
|
|
558
558
|
},
|
|
559
|
-
"../src/tss/ecdsa/
|
|
560
|
-
"version": "
|
|
561
|
-
"signature": "
|
|
559
|
+
"../src/tss/ecdsa/paillierproof.ts": {
|
|
560
|
+
"version": "eaced94643ae69cb88d3d7c43b312d9d101ed3fdadb7fa8106c0332df0639c59",
|
|
561
|
+
"signature": "f7a684dc92f6027cd074080aa2f6105ece4a65c2c64bce2a7214ca4a2ce38d3c",
|
|
562
562
|
"affectsGlobalScope": false
|
|
563
563
|
},
|
|
564
564
|
"../src/tss/ecdsa/index.ts": {
|
|
565
|
-
"version": "
|
|
566
|
-
"signature": "
|
|
565
|
+
"version": "1e8c4bd55bc9bdffadc507eb9ba26e830d34cbda68c5f074ec1f03a2e1c09072",
|
|
566
|
+
"signature": "b9707f86e0e401b657ed40193fcae1cff492e43c201624f9a72aef2f328d76b7",
|
|
567
567
|
"affectsGlobalScope": false
|
|
568
568
|
},
|
|
569
569
|
"../src/tss/index.ts": {
|
|
@@ -1488,11 +1488,11 @@
|
|
|
1488
1488
|
"../src/openssl/opensslbytes.ts"
|
|
1489
1489
|
],
|
|
1490
1490
|
"../src/tss/ecdsa/index.ts": [
|
|
1491
|
-
"../src/tss/ecdsa/
|
|
1491
|
+
"../src/tss/ecdsa/paillierproof.ts",
|
|
1492
1492
|
"../src/tss/ecdsa/rangeproof.ts",
|
|
1493
1493
|
"../src/tss/ecdsa/types.ts"
|
|
1494
1494
|
],
|
|
1495
|
-
"../src/tss/ecdsa/
|
|
1495
|
+
"../src/tss/ecdsa/paillierproof.ts": [
|
|
1496
1496
|
"../../../node_modules/bigint-crypto-utils/types/index.d.ts",
|
|
1497
1497
|
"../../../node_modules/bigint-mod-arith/types/index.d.ts",
|
|
1498
1498
|
"../src/tss/ecdsa/index.ts",
|
|
@@ -2438,7 +2438,7 @@
|
|
|
2438
2438
|
"../src/openssl/openssl.ts"
|
|
2439
2439
|
],
|
|
2440
2440
|
"../src/tss/ecdsa/index.ts": [
|
|
2441
|
-
"../src/tss/ecdsa/
|
|
2441
|
+
"../src/tss/ecdsa/paillierproof.ts",
|
|
2442
2442
|
"../src/tss/ecdsa/rangeproof.ts",
|
|
2443
2443
|
"../src/tss/ecdsa/types.ts"
|
|
2444
2444
|
],
|
|
@@ -3361,7 +3361,7 @@
|
|
|
3361
3361
|
"../src/openssl/openssl.ts",
|
|
3362
3362
|
"../src/openssl/opensslbytes.ts",
|
|
3363
3363
|
"../src/tss/ecdsa/index.ts",
|
|
3364
|
-
"../src/tss/ecdsa/
|
|
3364
|
+
"../src/tss/ecdsa/paillierproof.ts",
|
|
3365
3365
|
"../src/tss/ecdsa/primes.ts",
|
|
3366
3366
|
"../src/tss/ecdsa/rangeproof.ts",
|
|
3367
3367
|
"../src/tss/ecdsa/types.ts",
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bitgo-beta/sdk-lib-mpc",
|
|
3
|
-
"version": "8.2.0-beta.
|
|
3
|
+
"version": "8.2.0-beta.41",
|
|
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": "1c44174889f0361cce544863fdd489b690a9c4a5"
|
|
52
52
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"pallierproof.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa/pallierproof.ts"],"names":[],"mappings":"AAYA,eAAO,MAAM,CAAC,QAAkC,CAAC;AAEjD;;;;GAIG;AACH,wBAAsB,SAAS,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CASjE;AAED;;;;;;GAMG;AACH,wBAAgB,KAAK,CAAC,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,GAAG,MAAM,EAAE,CAM3E;AAED;;;;;GAKG;AACH,wBAAgB,MAAM,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,GAAG,OAAO,CAkCjF"}
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.verify = exports.prove = exports.generateP = exports.m = void 0;
|
|
4
|
-
const bigint_crypto_utils_1 = require("bigint-crypto-utils");
|
|
5
|
-
const bigint_mod_arith_1 = require("bigint-mod-arith");
|
|
6
|
-
const util_1 = require("../../util");
|
|
7
|
-
const index_1 = require("./index");
|
|
8
|
-
const primes_1 = require("./primes");
|
|
9
|
-
// Security parameters.
|
|
10
|
-
const k = 128;
|
|
11
|
-
// eprint.iacr.org/2018/057.pdf#page6 section 5
|
|
12
|
-
// https://github.com/BitGo/BitGoJS/pull/3502#discussion_r1203070392
|
|
13
|
-
const alpha = 319567;
|
|
14
|
-
exports.m = Math.ceil(k / Math.log2(alpha));
|
|
15
|
-
/**
|
|
16
|
-
* Generate a set of challenges $p$ for a given pallier public key modulus $n$.
|
|
17
|
-
* @param n - pallier public key modulus
|
|
18
|
-
* @returns {Promise<Array<bigint>>} - array of challenges $p_i$
|
|
19
|
-
*/
|
|
20
|
-
async function generateP(n) {
|
|
21
|
-
if (bigint_crypto_utils_1.bitLength(n) < index_1.minModulusBitLength) {
|
|
22
|
-
throw new Error('modulus n must have a bit length larger than or equal to 3072');
|
|
23
|
-
}
|
|
24
|
-
return Promise.all(Array(exports.m)
|
|
25
|
-
.fill(null)
|
|
26
|
-
.map(() => util_1.randomPositiveCoPrimeLessThan(n)));
|
|
27
|
-
}
|
|
28
|
-
exports.generateP = generateP;
|
|
29
|
-
/**
|
|
30
|
-
* Generate a set of proofs $sigma$ for a given set of challenges $p$ using the pallier public key modulus $n$ and the private key $\lambda$.
|
|
31
|
-
* @param n - pallier public key modulus $n$
|
|
32
|
-
* @param lambda - private key $\lambda, which is the $\euler(N) = (p-1)(q-1)$
|
|
33
|
-
* @param p - array of challenges $p$
|
|
34
|
-
* @returns {Promise<Array<bigint>>} - array of proofs $\sigma$
|
|
35
|
-
*/
|
|
36
|
-
function prove(n, lambda, p) {
|
|
37
|
-
if (!p.every((p_i) => p_i > 0)) {
|
|
38
|
-
throw new Error('All pallier challenge values must be positive.');
|
|
39
|
-
}
|
|
40
|
-
const n_inv = bigint_mod_arith_1.modInv(n, lambda);
|
|
41
|
-
return p.map((p_i) => bigint_mod_arith_1.modPow(p_i, n_inv, n));
|
|
42
|
-
}
|
|
43
|
-
exports.prove = prove;
|
|
44
|
-
/**
|
|
45
|
-
* Verify a set of proofs $\sigma$ on the modulus $n$ using the challenges $p$ that were provided to the prover to generate the proofs.
|
|
46
|
-
* @param n - pallier public key modulus $n$
|
|
47
|
-
* @param p - array of challenges $p$
|
|
48
|
-
* @param sigma - array of proofs $\sigma$
|
|
49
|
-
*/
|
|
50
|
-
function verify(n, p, sigma) {
|
|
51
|
-
if (!p.every((p_i) => p_i > 0)) {
|
|
52
|
-
throw new Error('All pallier challenge values must be positive.');
|
|
53
|
-
}
|
|
54
|
-
if (!sigma.every((sigma_i) => sigma_i > 0)) {
|
|
55
|
-
throw new Error('All pallier challenge proof values must be positive.');
|
|
56
|
-
}
|
|
57
|
-
// a) Check that $N$ is a positive integer and is not divisible by all
|
|
58
|
-
// the primes less than $\alpha$.
|
|
59
|
-
if (n <= 0) {
|
|
60
|
-
return false;
|
|
61
|
-
}
|
|
62
|
-
if (alpha !== 319567) {
|
|
63
|
-
throw new Error('unsupported alpha value');
|
|
64
|
-
}
|
|
65
|
-
for (const prime of primes_1.primesSmallerThan319567) {
|
|
66
|
-
if (n % BigInt(prime) === BigInt(0)) {
|
|
67
|
-
return false;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
// b) Check that $\sigma_i$ is a positive integer $i = 1...m$.
|
|
71
|
-
if (sigma.length !== exports.m) {
|
|
72
|
-
return false;
|
|
73
|
-
}
|
|
74
|
-
if (!sigma.every((sigma_i) => sigma_i > 0)) {
|
|
75
|
-
return false;
|
|
76
|
-
}
|
|
77
|
-
// c) Verify that $p_i = \sigma_i^N \mod N$ for $i = 1...m$.
|
|
78
|
-
for (let i = 0; i < exports.m; i++) {
|
|
79
|
-
if (p[i] !== bigint_mod_arith_1.modPow(sigma[i], n, n)) {
|
|
80
|
-
return false;
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
return true;
|
|
84
|
-
}
|
|
85
|
-
exports.verify = verify;
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFsbGllcnByb29mLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3Rzcy9lY2RzYS9wYWxsaWVycHJvb2YudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkRBQWdEO0FBQ2hELHVEQUFrRDtBQUVsRCxxQ0FBMkQ7QUFDM0QsbUNBQThDO0FBQzlDLHFDQUFtRDtBQUVuRCx1QkFBdUI7QUFDdkIsTUFBTSxDQUFDLEdBQUcsR0FBRyxDQUFDO0FBQ2QsK0NBQStDO0FBQy9DLG9FQUFvRTtBQUNwRSxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUM7QUFDUixRQUFBLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7QUFFakQ7Ozs7R0FJRztBQUNJLEtBQUssVUFBVSxTQUFTLENBQUMsQ0FBUztJQUN2QyxJQUFJLCtCQUFTLENBQUMsQ0FBQyxDQUFDLEdBQUcsMkJBQW1CLEVBQUU7UUFDdEMsTUFBTSxJQUFJLEtBQUssQ0FBQywrREFBK0QsQ0FBQyxDQUFDO0tBQ2xGO0lBQ0QsT0FBTyxPQUFPLENBQUMsR0FBRyxDQUNoQixLQUFLLENBQUMsU0FBQyxDQUFDO1NBQ0wsSUFBSSxDQUFDLElBQUksQ0FBQztTQUNWLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxvQ0FBNkIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUMvQyxDQUFDO0FBQ0osQ0FBQztBQVRELDhCQVNDO0FBRUQ7Ozs7OztHQU1HO0FBQ0gsU0FBZ0IsS0FBSyxDQUFDLENBQVMsRUFBRSxNQUFjLEVBQUUsQ0FBZ0I7SUFDL0QsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUMsRUFBRTtRQUM5QixNQUFNLElBQUksS0FBSyxDQUFDLGdEQUFnRCxDQUFDLENBQUM7S0FDbkU7SUFDRCxNQUFNLEtBQUssR0FBRyx5QkFBTSxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNoQyxPQUFPLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLHlCQUFNLENBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQy9DLENBQUM7QUFORCxzQkFNQztBQUVEOzs7OztHQUtHO0FBQ0gsU0FBZ0IsTUFBTSxDQUFDLENBQVMsRUFBRSxDQUFnQixFQUFFLEtBQW9CO0lBQ3RFLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxDQUFDLEVBQUU7UUFDOUIsTUFBTSxJQUFJLEtBQUssQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDO0tBQ25FO0lBQ0QsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLE9BQU8sR0FBRyxDQUFDLENBQUMsRUFBRTtRQUMxQyxNQUFNLElBQUksS0FBSyxDQUFDLHNEQUFzRCxDQUFDLENBQUM7S0FDekU7SUFDRCxzRUFBc0U7SUFDdEUsaUNBQWlDO0lBQ2pDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUNWLE9BQU8sS0FBSyxDQUFDO0tBQ2Q7SUFDRCxJQUFJLEtBQUssS0FBSyxNQUFNLEVBQUU7UUFDcEIsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0tBQzVDO0lBQ0QsS0FBSyxNQUFNLEtBQUssSUFBSSxnQ0FBdUIsRUFBRTtRQUMzQyxJQUFJLENBQUMsR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQ25DLE9BQU8sS0FBSyxDQUFDO1NBQ2Q7S0FDRjtJQUNELDhEQUE4RDtJQUM5RCxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssU0FBQyxFQUFFO1FBQ3RCLE9BQU8sS0FBSyxDQUFDO0tBQ2Q7SUFDRCxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxHQUFHLENBQUMsQ0FBQyxFQUFFO1FBQzFDLE9BQU8sS0FBSyxDQUFDO0tBQ2Q7SUFDRCw0REFBNEQ7SUFDNUQsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLFNBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRTtRQUMxQixJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyx5QkFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLEVBQUU7WUFDbkMsT0FBTyxLQUFLLENBQUM7U0FDZDtLQUNGO0lBQ0QsT0FBTyxJQUFJLENBQUM7QUFDZCxDQUFDO0FBbENELHdCQWtDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJpdExlbmd0aCB9IGZyb20gJ2JpZ2ludC1jcnlwdG8tdXRpbHMnO1xuaW1wb3J0IHsgbW9kSW52LCBtb2RQb3cgfSBmcm9tICdiaWdpbnQtbW9kLWFyaXRoJztcblxuaW1wb3J0IHsgcmFuZG9tUG9zaXRpdmVDb1ByaW1lTGVzc1RoYW4gfSBmcm9tICcuLi8uLi91dGlsJztcbmltcG9ydCB7IG1pbk1vZHVsdXNCaXRMZW5ndGggfSBmcm9tICcuL2luZGV4JztcbmltcG9ydCB7IHByaW1lc1NtYWxsZXJUaGFuMzE5NTY3IH0gZnJvbSAnLi9wcmltZXMnO1xuXG4vLyBTZWN1cml0eSBwYXJhbWV0ZXJzLlxuY29uc3QgayA9IDEyODtcbi8vIGVwcmludC5pYWNyLm9yZy8yMDE4LzA1Ny5wZGYjcGFnZTYgc2VjdGlvbiA1XG4vLyBodHRwczovL2dpdGh1Yi5jb20vQml0R28vQml0R29KUy9wdWxsLzM1MDIjZGlzY3Vzc2lvbl9yMTIwMzA3MDM5MlxuY29uc3QgYWxwaGEgPSAzMTk1Njc7XG5leHBvcnQgY29uc3QgbSA9IE1hdGguY2VpbChrIC8gTWF0aC5sb2cyKGFscGhhKSk7XG5cbi8qKlxuICogR2VuZXJhdGUgYSBzZXQgb2YgY2hhbGxlbmdlcyAkcCQgZm9yIGEgZ2l2ZW4gcGFsbGllciBwdWJsaWMga2V5IG1vZHVsdXMgJG4kLlxuICogQHBhcmFtIG4gLSBwYWxsaWVyIHB1YmxpYyBrZXkgbW9kdWx1c1xuICogQHJldHVybnMge1Byb21pc2U8QXJyYXk8YmlnaW50Pj59IC0gYXJyYXkgb2YgY2hhbGxlbmdlcyAkcF9pJFxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2VuZXJhdGVQKG46IGJpZ2ludCk6IFByb21pc2U8QXJyYXk8YmlnaW50Pj4ge1xuICBpZiAoYml0TGVuZ3RoKG4pIDwgbWluTW9kdWx1c0JpdExlbmd0aCkge1xuICAgIHRocm93IG5ldyBFcnJvcignbW9kdWx1cyBuIG11c3QgaGF2ZSBhIGJpdCBsZW5ndGggbGFyZ2VyIHRoYW4gb3IgZXF1YWwgdG8gMzA3MicpO1xuICB9XG4gIHJldHVybiBQcm9taXNlLmFsbChcbiAgICBBcnJheShtKVxuICAgICAgLmZpbGwobnVsbClcbiAgICAgIC5tYXAoKCkgPT4gcmFuZG9tUG9zaXRpdmVDb1ByaW1lTGVzc1RoYW4obikpXG4gICk7XG59XG5cbi8qKlxuICogR2VuZXJhdGUgYSBzZXQgb2YgcHJvb2ZzICRzaWdtYSQgZm9yIGEgZ2l2ZW4gc2V0IG9mIGNoYWxsZW5nZXMgJHAkIHVzaW5nIHRoZSBwYWxsaWVyIHB1YmxpYyBrZXkgbW9kdWx1cyAkbiQgYW5kIHRoZSBwcml2YXRlIGtleSAkXFxsYW1iZGEkLlxuICogQHBhcmFtIG4gLSBwYWxsaWVyIHB1YmxpYyBrZXkgbW9kdWx1cyAkbiRcbiAqIEBwYXJhbSBsYW1iZGEgLSBwcml2YXRlIGtleSAkXFxsYW1iZGEsICB3aGljaCBpcyB0aGUgJFxcZXVsZXIoTikgPSAocC0xKShxLTEpJFxuICogQHBhcmFtIHAgLSBhcnJheSBvZiBjaGFsbGVuZ2VzICRwJFxuICogQHJldHVybnMge1Byb21pc2U8QXJyYXk8YmlnaW50Pj59IC0gYXJyYXkgb2YgcHJvb2ZzICRcXHNpZ21hJFxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJvdmUobjogYmlnaW50LCBsYW1iZGE6IGJpZ2ludCwgcDogQXJyYXk8YmlnaW50Pik6IGJpZ2ludFtdIHtcbiAgaWYgKCFwLmV2ZXJ5KChwX2kpID0+IHBfaSA+IDApKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdBbGwgcGFsbGllciBjaGFsbGVuZ2UgdmFsdWVzIG11c3QgYmUgcG9zaXRpdmUuJyk7XG4gIH1cbiAgY29uc3Qgbl9pbnYgPSBtb2RJbnYobiwgbGFtYmRhKTtcbiAgcmV0dXJuIHAubWFwKChwX2kpID0+IG1vZFBvdyhwX2ksIG5faW52LCBuKSk7XG59XG5cbi8qKlxuICogVmVyaWZ5IGEgc2V0IG9mIHByb29mcyAkXFxzaWdtYSQgb24gdGhlIG1vZHVsdXMgJG4kIHVzaW5nIHRoZSBjaGFsbGVuZ2VzICRwJCB0aGF0IHdlcmUgcHJvdmlkZWQgdG8gdGhlIHByb3ZlciB0byBnZW5lcmF0ZSB0aGUgcHJvb2ZzLlxuICogQHBhcmFtIG4gLSBwYWxsaWVyIHB1YmxpYyBrZXkgbW9kdWx1cyAkbiRcbiAqIEBwYXJhbSBwIC0gYXJyYXkgb2YgY2hhbGxlbmdlcyAkcCRcbiAqIEBwYXJhbSBzaWdtYSAtIGFycmF5IG9mIHByb29mcyAkXFxzaWdtYSRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHZlcmlmeShuOiBiaWdpbnQsIHA6IEFycmF5PGJpZ2ludD4sIHNpZ21hOiBBcnJheTxiaWdpbnQ+KTogYm9vbGVhbiB7XG4gIGlmICghcC5ldmVyeSgocF9pKSA9PiBwX2kgPiAwKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignQWxsIHBhbGxpZXIgY2hhbGxlbmdlIHZhbHVlcyBtdXN0IGJlIHBvc2l0aXZlLicpO1xuICB9XG4gIGlmICghc2lnbWEuZXZlcnkoKHNpZ21hX2kpID0+IHNpZ21hX2kgPiAwKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignQWxsIHBhbGxpZXIgY2hhbGxlbmdlIHByb29mIHZhbHVlcyBtdXN0IGJlIHBvc2l0aXZlLicpO1xuICB9XG4gIC8vIGEpIENoZWNrIHRoYXQgJE4kIGlzIGEgcG9zaXRpdmUgaW50ZWdlciBhbmQgaXMgbm90IGRpdmlzaWJsZSBieSBhbGxcbiAgLy8gdGhlIHByaW1lcyBsZXNzIHRoYW4gJFxcYWxwaGEkLlxuICBpZiAobiA8PSAwKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG4gIGlmIChhbHBoYSAhPT0gMzE5NTY3KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCd1bnN1cHBvcnRlZCBhbHBoYSB2YWx1ZScpO1xuICB9XG4gIGZvciAoY29uc3QgcHJpbWUgb2YgcHJpbWVzU21hbGxlclRoYW4zMTk1NjcpIHtcbiAgICBpZiAobiAlIEJpZ0ludChwcmltZSkgPT09IEJpZ0ludCgwKSkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgfVxuICAvLyBiKSBDaGVjayB0aGF0ICRcXHNpZ21hX2kkIGlzIGEgcG9zaXRpdmUgaW50ZWdlciAkaSA9IDEuLi5tJC5cbiAgaWYgKHNpZ21hLmxlbmd0aCAhPT0gbSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuICBpZiAoIXNpZ21hLmV2ZXJ5KChzaWdtYV9pKSA9PiBzaWdtYV9pID4gMCkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgLy8gYykgVmVyaWZ5IHRoYXQgJHBfaSA9IFxcc2lnbWFfaV5OIFxcbW9kIE4kIGZvciAkaSA9IDEuLi5tJC5cbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBtOyBpKyspIHtcbiAgICBpZiAocFtpXSAhPT0gbW9kUG93KHNpZ21hW2ldLCBuLCBuKSkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn1cbiJdfQ==
|