@bitgo-beta/sdk-lib-mpc 8.2.1-alpha.4 → 8.2.1-alpha.400

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (103) hide show
  1. package/dist/src/curves/constant.d.ts +2 -0
  2. package/dist/src/curves/constant.d.ts.map +1 -0
  3. package/dist/src/curves/constant.js +6 -0
  4. package/dist/src/curves/{baseCurve.d.ts → ed25519.d.ts} +9 -8
  5. package/dist/src/curves/ed25519.d.ts.map +1 -0
  6. package/dist/src/curves/ed25519.js +72 -0
  7. package/dist/src/curves/ed25519Bip32HdTree.d.ts +10 -0
  8. package/dist/src/curves/ed25519Bip32HdTree.d.ts.map +1 -0
  9. package/dist/src/curves/ed25519Bip32HdTree.js +85 -0
  10. package/dist/src/curves/index.d.ts +6 -1
  11. package/dist/src/curves/index.d.ts.map +1 -1
  12. package/dist/src/curves/index.js +12 -3
  13. package/dist/src/curves/secp256k1.d.ts +3 -2
  14. package/dist/src/curves/secp256k1.d.ts.map +1 -1
  15. package/dist/src/curves/secp256k1.js +29 -38
  16. package/dist/src/curves/secp256k1Bip32HdTree.d.ts +8 -0
  17. package/dist/src/curves/secp256k1Bip32HdTree.d.ts.map +1 -0
  18. package/dist/src/curves/secp256k1Bip32HdTree.js +54 -0
  19. package/dist/src/curves/types.d.ts +35 -0
  20. package/dist/src/curves/types.d.ts.map +1 -0
  21. package/dist/src/curves/types.js +3 -0
  22. package/dist/src/curves/util.d.ts +4 -0
  23. package/dist/src/curves/util.d.ts.map +1 -0
  24. package/dist/src/curves/util.js +42 -0
  25. package/dist/src/hashCommitment.d.ts +16 -0
  26. package/dist/src/hashCommitment.d.ts.map +1 -0
  27. package/dist/src/hashCommitment.js +44 -0
  28. package/dist/src/index.d.ts +6 -1
  29. package/dist/src/index.d.ts.map +1 -1
  30. package/dist/src/index.js +35 -3
  31. package/dist/src/openssl/index.js +6 -2
  32. package/dist/src/openssl/openssl.d.ts +1 -2
  33. package/dist/src/openssl/openssl.d.ts.map +1 -1
  34. package/dist/src/openssl/openssl.js +4 -12
  35. package/dist/src/safePrime.d.ts +3 -0
  36. package/dist/src/safePrime.d.ts.map +1 -0
  37. package/dist/src/safePrime.js +19 -0
  38. package/dist/src/schnorrProof.d.ts +21 -0
  39. package/dist/src/schnorrProof.d.ts.map +1 -0
  40. package/dist/src/schnorrProof.js +61 -0
  41. package/dist/src/shamir/index.d.ts +3 -0
  42. package/dist/src/shamir/index.d.ts.map +1 -0
  43. package/dist/src/shamir/index.js +19 -0
  44. package/dist/src/shamir/shamir.d.ts +38 -0
  45. package/dist/src/shamir/shamir.d.ts.map +1 -0
  46. package/dist/src/shamir/shamir.js +136 -0
  47. package/dist/src/shamir/types.d.ts +5 -0
  48. package/dist/src/shamir/types.d.ts.map +1 -0
  49. package/dist/src/shamir/types.js +3 -0
  50. package/dist/src/tss/ecdsa/index.d.ts +3 -0
  51. package/dist/src/tss/ecdsa/index.d.ts.map +1 -1
  52. package/dist/src/tss/ecdsa/index.js +27 -10
  53. package/dist/src/tss/ecdsa/paillierproof.d.ts +24 -0
  54. package/dist/src/tss/ecdsa/paillierproof.d.ts.map +1 -0
  55. package/dist/src/tss/ecdsa/paillierproof.js +86 -0
  56. package/dist/src/tss/ecdsa/primes.d.ts +2 -0
  57. package/dist/src/tss/ecdsa/primes.d.ts.map +1 -0
  58. package/dist/src/tss/ecdsa/primes.js +1846 -0
  59. package/dist/src/tss/ecdsa/rangeproof.d.ts +1 -2
  60. package/dist/src/tss/ecdsa/rangeproof.d.ts.map +1 -1
  61. package/dist/src/tss/ecdsa/rangeproof.js +124 -133
  62. package/dist/src/tss/ecdsa/types.d.ts +84 -15
  63. package/dist/src/tss/ecdsa/types.d.ts.map +1 -1
  64. package/dist/src/tss/ecdsa/types.js +89 -29
  65. package/dist/src/tss/ecdsa/zkVProof.d.ts +24 -0
  66. package/dist/src/tss/ecdsa/zkVProof.d.ts.map +1 -0
  67. package/dist/src/tss/ecdsa/zkVProof.js +70 -0
  68. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts +42 -0
  69. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts.map +1 -0
  70. package/dist/src/tss/ecdsa-dkls/commsLayer.js +235 -0
  71. package/dist/src/tss/ecdsa-dkls/dkg.d.ts +57 -0
  72. package/dist/src/tss/ecdsa-dkls/dkg.d.ts.map +1 -0
  73. package/dist/src/tss/ecdsa-dkls/dkg.js +321 -0
  74. package/dist/src/tss/ecdsa-dkls/dsg.d.ts +47 -0
  75. package/dist/src/tss/ecdsa-dkls/dsg.d.ts.map +1 -0
  76. package/dist/src/tss/ecdsa-dkls/dsg.js +266 -0
  77. package/dist/src/tss/ecdsa-dkls/index.d.ts +6 -0
  78. package/dist/src/tss/ecdsa-dkls/index.d.ts.map +1 -0
  79. package/dist/src/tss/ecdsa-dkls/index.js +42 -0
  80. package/dist/src/tss/ecdsa-dkls/types.d.ts +118 -0
  81. package/dist/src/tss/ecdsa-dkls/types.d.ts.map +1 -0
  82. package/dist/src/tss/ecdsa-dkls/types.js +165 -0
  83. package/dist/src/tss/ecdsa-dkls/util.d.ts +26 -0
  84. package/dist/src/tss/ecdsa-dkls/util.d.ts.map +1 -0
  85. package/dist/src/tss/ecdsa-dkls/util.js +276 -0
  86. package/dist/src/tss/index.d.ts +1 -0
  87. package/dist/src/tss/index.d.ts.map +1 -1
  88. package/dist/src/tss/index.js +7 -2
  89. package/dist/src/types.d.ts +13 -0
  90. package/dist/src/types.d.ts.map +1 -0
  91. package/dist/src/types.js +3 -0
  92. package/dist/src/util.d.ts +21 -7
  93. package/dist/src/util.d.ts.map +1 -1
  94. package/dist/src/util.js +70 -29
  95. package/dist/tsconfig.tsbuildinfo +1 -3621
  96. package/package.json +31 -8
  97. package/.eslintignore +0 -5
  98. package/CHANGELOG.md +0 -14
  99. package/dist/src/curves/baseCurve.d.ts.map +0 -1
  100. package/dist/src/curves/baseCurve.js +0 -6
  101. package/dist/src/openssl/opensslbytes.d.ts +0 -4
  102. package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
  103. package/dist/src/openssl/opensslbytes.js +0 -20
@@ -1,6 +1,12 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.verifyWithCheck = exports.proveWithCheck = exports.verify = exports.prove = exports.verifyNtildeProof = exports.generateNtildeProof = exports.generateNtilde = exports.generateSafePrimes = void 0;
3
+ exports.generateNtilde = generateNtilde;
4
+ exports.generateNtildeProof = generateNtildeProof;
5
+ exports.verifyNtildeProof = verifyNtildeProof;
6
+ exports.prove = prove;
7
+ exports.verify = verify;
8
+ exports.proveWithCheck = proveWithCheck;
9
+ exports.verifyWithCheck = verifyWithCheck;
4
10
  /**
5
11
  * Zero Knowledge Range Proofs as described in (Two-party generation of DSA signatures)[1].
6
12
  * [1]: https://reitermk.github.io/papers/2004/IJIS.pdf
@@ -9,33 +15,28 @@ const crypto_1 = require("crypto");
9
15
  const bigint_crypto_utils_1 = require("bigint-crypto-utils");
10
16
  const bigint_mod_arith_1 = require("bigint-mod-arith");
11
17
  const util_1 = require("../../util");
12
- const openssl_1 = require("../../openssl");
18
+ const index_1 = require("./index");
19
+ const safePrime_1 = require("../../safePrime");
13
20
  // 128 as recommend by https://blog.verichains.io/p/vsa-2022-120-multichain-key-extraction.
14
21
  const ITERATIONS = 128;
15
- async function generateSafePrimes(bitLengths) {
16
- const openSSL = new openssl_1.OpenSSL();
17
- await openSSL.init();
18
- const promises = bitLengths.map((bitlength) => {
19
- return openSSL.generateSafePrime(bitlength);
20
- });
21
- return await Promise.all(promises);
22
- }
23
- exports.generateSafePrimes = generateSafePrimes;
24
- async function generateModulus(bitlength) {
25
- if (bitlength < 3072) {
22
+ async function generateModulus(openSSLBytes, bitlength = index_1.minModulusBitLength, retry = 10) {
23
+ if (bitlength < index_1.minModulusBitLength) {
26
24
  // https://www.keylength.com/en/6/
25
+ // eslint-disable-next-line no-console
27
26
  console.warn('Generating a modulus with less than 3072 is not recommended!');
28
27
  }
29
28
  const bitlengthP = Math.floor(bitlength / 2);
30
29
  const bitlengthQ = bitlength - bitlengthP;
31
- const [p, q] = await generateSafePrimes([bitlengthP, bitlengthQ]);
32
- const n = p * q;
33
- // We never expect this to happen unless something went wrong with the wasm/openssl module
34
- if (bigint_crypto_utils_1.bitLength(n) !== bitlength) {
35
- throw new Error(`Unable to generate modulus with bit length of ${bitlength}. Expected length ${bitlength}, got
36
- ${bigint_crypto_utils_1.bitLength(n)}. please try again or reach out to support@bitgo.com`);
30
+ for (let i = 0; i < retry; i++) {
31
+ const [p, q] = await (0, safePrime_1.generateSafePrimes)([bitlengthP, bitlengthQ], openSSLBytes);
32
+ const n = p * q;
33
+ // For large bit lengths, the probability of generating a modulus with the wrong bit length is very low.
34
+ if ((0, bigint_crypto_utils_1.bitLength)(n) !== bitlength) {
35
+ continue;
36
+ }
37
+ return { n, q1: (p - BigInt(1)) / BigInt(2), q2: (q - BigInt(1)) / BigInt(2) };
37
38
  }
38
- return { n, q1: (p - BigInt(1)) / BigInt(2), q2: (q - BigInt(1)) / BigInt(2) };
39
+ throw new Error(`Unable to generate modulus with bit length of ${bitlength} after ${retry} tries. Please try again or reach out to support@bitgo.com`);
39
40
  }
40
41
  /**
41
42
  * Generate "challenge" values for range proofs.
@@ -43,12 +44,12 @@ async function generateModulus(bitlength) {
43
44
  * be the same as the bit length of the paillier public keys used for MtA.
44
45
  * @returns {DeserializedNtilde} The generated Ntilde values.
45
46
  */
46
- async function generateNtilde(bitlength) {
47
- const { n: ntilde, q1, q2 } = await generateModulus(bitlength);
48
- const [f1, f2] = await Promise.all([util_1.randomCoPrimeTo(ntilde), util_1.randomCoPrimeTo(ntilde)]);
49
- const h1 = bigint_mod_arith_1.modPow(f1, BigInt(2), ntilde);
50
- const h2 = bigint_mod_arith_1.modPow(h1, f2, ntilde);
51
- const beta = bigint_mod_arith_1.modInv(f2, q1 * q2);
47
+ async function generateNtilde(openSSLBytes, bitlength = index_1.minModulusBitLength) {
48
+ const { n: ntilde, q1, q2 } = await generateModulus(openSSLBytes, bitlength);
49
+ const [f1, f2] = await Promise.all([(0, util_1.randomPositiveCoPrimeTo)(ntilde), (0, util_1.randomPositiveCoPrimeTo)(ntilde)]);
50
+ const h1 = (0, bigint_mod_arith_1.modPow)(f1, BigInt(2), ntilde);
51
+ const h2 = (0, bigint_mod_arith_1.modPow)(h1, f2, ntilde);
52
+ const beta = (0, bigint_mod_arith_1.modInv)(f2, q1 * q2);
52
53
  const [h1wrtH2Proofs, h2wrtH1Proofs] = await Promise.all([
53
54
  generateNtildeProof({
54
55
  h1: h1,
@@ -77,7 +78,6 @@ async function generateNtilde(bitlength) {
77
78
  },
78
79
  };
79
80
  }
80
- exports.generateNtilde = generateNtilde;
81
81
  /**
82
82
  * Generate iterations of Ntilde, h1, h2 discrete log proofs.
83
83
  * @param {DeserializedNtilde} ntilde Ntilde, h1, h2 to generate the proofs for.
@@ -92,16 +92,16 @@ async function generateNtildeProof(ntilde, x, q1, q2) {
92
92
  const a = [];
93
93
  const alpha = [];
94
94
  let msgToHash = Buffer.concat([
95
- util_1.bigIntToBufferBE(ntilde.h1),
96
- util_1.bigIntToBufferBE(ntilde.h2),
97
- util_1.bigIntToBufferBE(ntilde.ntilde),
95
+ (0, util_1.bigIntToBufferBE)(ntilde.h1),
96
+ (0, util_1.bigIntToBufferBE)(ntilde.h2),
97
+ (0, util_1.bigIntToBufferBE)(ntilde.ntilde),
98
98
  ]);
99
99
  for (let i = 0; i < ITERATIONS; i++) {
100
- a.push(bigint_crypto_utils_1.randBetween(q1MulQ2));
101
- alpha.push(bigint_mod_arith_1.modPow(ntilde.h1, a[i], ntilde.ntilde));
102
- msgToHash = Buffer.concat([msgToHash, util_1.bigIntToBufferBE(alpha[i], Math.ceil(bigint_crypto_utils_1.bitLength(ntilde.ntilde) / 8))]);
100
+ a.push((0, bigint_crypto_utils_1.randBetween)(q1MulQ2));
101
+ alpha.push((0, bigint_mod_arith_1.modPow)(ntilde.h1, a[i], ntilde.ntilde));
102
+ msgToHash = Buffer.concat([msgToHash, (0, util_1.bigIntToBufferBE)(alpha[i], Math.ceil((0, bigint_crypto_utils_1.bitLength)(ntilde.ntilde) / 8))]);
103
103
  }
104
- const simulatedResponse = crypto_1.createHash('sha256').update(msgToHash).digest();
104
+ const simulatedResponse = (0, crypto_1.createHash)('sha256').update(msgToHash).digest();
105
105
  const t = [];
106
106
  for (let i = 0; i < ITERATIONS; i++) {
107
107
  // Get the ith bit from a buffer of bytes.
@@ -110,7 +110,6 @@ async function generateNtildeProof(ntilde, x, q1, q2) {
110
110
  }
111
111
  return { alpha, t };
112
112
  }
113
- exports.generateNtildeProof = generateNtildeProof;
114
113
  /**
115
114
  * Verify discrete log proofs of h1 and h2 mod Ntilde.
116
115
  * @param {DeserializedNtilde} ntilde Ntilde, h1, h2 to generate the proofs for.
@@ -135,22 +134,22 @@ async function verifyNtildeProof(ntilde, ntildeProof) {
135
134
  return false;
136
135
  }
137
136
  let msgToHash = Buffer.concat([
138
- util_1.bigIntToBufferBE(ntilde.h1),
139
- util_1.bigIntToBufferBE(ntilde.h2),
140
- util_1.bigIntToBufferBE(ntilde.ntilde),
137
+ (0, util_1.bigIntToBufferBE)(ntilde.h1),
138
+ (0, util_1.bigIntToBufferBE)(ntilde.h2),
139
+ (0, util_1.bigIntToBufferBE)(ntilde.ntilde),
141
140
  ]);
142
141
  for (let i = 0; i < ntildeProof.alpha.length; i++) {
143
142
  msgToHash = Buffer.concat([
144
143
  msgToHash,
145
- util_1.bigIntToBufferBE(ntildeProof.alpha[i], Math.ceil(bigint_crypto_utils_1.bitLength(ntilde.ntilde) / 8)),
144
+ (0, util_1.bigIntToBufferBE)(ntildeProof.alpha[i], Math.ceil((0, bigint_crypto_utils_1.bitLength)(ntilde.ntilde) / 8)),
146
145
  ]);
147
146
  }
148
- const simulatedResponse = crypto_1.createHash('sha256').update(msgToHash).digest();
147
+ const simulatedResponse = (0, crypto_1.createHash)('sha256').update(msgToHash).digest();
149
148
  for (let i = 0; i < ntildeProof.alpha.length; i++) {
150
149
  // Get the ith bit from a buffer of bytes.
151
150
  const ithBit = (simulatedResponse[Math.floor(i / 8)] >> (7 - (i % 8))) & 1;
152
- const h1PowTi = bigint_mod_arith_1.modPow(ntilde.h1, ntildeProof.t[i], ntilde.ntilde);
153
- const h2PowCi = bigint_mod_arith_1.modPow(ntilde.h2, BigInt(ithBit), ntilde.ntilde);
151
+ const h1PowTi = (0, bigint_mod_arith_1.modPow)(ntilde.h1, ntildeProof.t[i], ntilde.ntilde);
152
+ const h2PowCi = (0, bigint_mod_arith_1.modPow)(ntilde.h2, BigInt(ithBit), ntilde.ntilde);
154
153
  const alphaMulh2PowCi = (ntildeProof.alpha[i] * h2PowCi) % ntilde.ntilde;
155
154
  if (h1PowTi !== alphaMulh2PowCi) {
156
155
  return false;
@@ -158,7 +157,6 @@ async function verifyNtildeProof(ntilde, ntildeProof) {
158
157
  }
159
158
  return true;
160
159
  }
161
- exports.verifyNtildeProof = verifyNtildeProof;
162
160
  /**
163
161
  * Generate a zero-knowledge range proof that an encrypted value is "small".
164
162
  * @param {BaseCurve} curve An elliptic curve to use for group operations.
@@ -176,34 +174,33 @@ async function prove(curve, modulusBits, pk, ntilde, c, m, r) {
176
174
  const q3 = q ** BigInt(3);
177
175
  const qntilde = q * ntilde.ntilde;
178
176
  const q3ntilde = q3 * ntilde.ntilde;
179
- const alpha = bigint_crypto_utils_1.randBetween(q3);
180
- const beta = await util_1.randomCoPrimeTo(pk.n);
181
- const gamma = bigint_crypto_utils_1.randBetween(q3ntilde);
182
- const rho = bigint_crypto_utils_1.randBetween(qntilde);
183
- const z = (bigint_mod_arith_1.modPow(ntilde.h1, m, ntilde.ntilde) * bigint_mod_arith_1.modPow(ntilde.h2, rho, ntilde.ntilde)) % ntilde.ntilde;
184
- const u = (bigint_mod_arith_1.modPow(pk.g, alpha, pk._n2) * bigint_mod_arith_1.modPow(beta, pk.n, pk._n2)) % pk._n2;
185
- const w = (bigint_mod_arith_1.modPow(ntilde.h1, alpha, ntilde.ntilde) * bigint_mod_arith_1.modPow(ntilde.h2, gamma, ntilde.ntilde)) % ntilde.ntilde;
186
- const hash = crypto_1.createHash('sha256');
177
+ const alpha = (0, bigint_crypto_utils_1.randBetween)(q3);
178
+ const beta = await (0, util_1.randomPositiveCoPrimeTo)(pk.n);
179
+ const gamma = (0, bigint_crypto_utils_1.randBetween)(q3ntilde);
180
+ const rho = (0, bigint_crypto_utils_1.randBetween)(qntilde);
181
+ const z = ((0, bigint_mod_arith_1.modPow)(ntilde.h1, m, ntilde.ntilde) * (0, bigint_mod_arith_1.modPow)(ntilde.h2, rho, ntilde.ntilde)) % ntilde.ntilde;
182
+ const u = ((0, bigint_mod_arith_1.modPow)(pk.g, alpha, pk._n2) * (0, bigint_mod_arith_1.modPow)(beta, pk.n, pk._n2)) % pk._n2;
183
+ const w = ((0, bigint_mod_arith_1.modPow)(ntilde.h1, alpha, ntilde.ntilde) * (0, bigint_mod_arith_1.modPow)(ntilde.h2, gamma, ntilde.ntilde)) % ntilde.ntilde;
184
+ const hash = (0, crypto_1.createHash)('sha256');
187
185
  hash.update('\x06\x00\x00\x00\x00\x00\x00\x00');
188
- hash.update(util_1.bigIntToBufferBE(pk.n, modulusBytes));
186
+ hash.update((0, util_1.bigIntToBufferBE)(pk.n, modulusBytes));
189
187
  hash.update('$');
190
- hash.update(util_1.bigIntToBufferBE(pk.g, modulusBytes));
188
+ hash.update((0, util_1.bigIntToBufferBE)(pk.g, modulusBytes));
191
189
  hash.update('$');
192
- hash.update(util_1.bigIntToBufferBE(c, 2 * modulusBytes));
190
+ hash.update((0, util_1.bigIntToBufferBE)(c, 2 * modulusBytes));
193
191
  hash.update('$');
194
- hash.update(util_1.bigIntToBufferBE(z, modulusBytes));
192
+ hash.update((0, util_1.bigIntToBufferBE)(z, modulusBytes));
195
193
  hash.update('$');
196
- hash.update(util_1.bigIntToBufferBE(u, 2 * modulusBytes));
194
+ hash.update((0, util_1.bigIntToBufferBE)(u, 2 * modulusBytes));
197
195
  hash.update('$');
198
- hash.update(util_1.bigIntToBufferBE(w, modulusBytes));
196
+ hash.update((0, util_1.bigIntToBufferBE)(w, modulusBytes));
199
197
  hash.update('$');
200
- const e = util_1.bigIntFromBufferBE(hash.digest()) % q;
201
- const s = (bigint_mod_arith_1.modPow(r, e, pk.n) * beta) % pk.n;
198
+ const e = (0, util_1.bigIntFromBufferBE)(hash.digest()) % q;
199
+ const s = ((0, bigint_mod_arith_1.modPow)(r, e, pk.n) * beta) % pk.n;
202
200
  const s1 = e * m + alpha;
203
201
  const s2 = e * rho + gamma;
204
202
  return { z, u, w, s, s1, s2 };
205
203
  }
206
- exports.prove = prove;
207
204
  /**
208
205
  * Verify a zero-knowledge range proof that an encrypted value is "small".
209
206
  * @param {BaseCurve} curve An elliptic curve to use for group operations.
@@ -215,42 +212,41 @@ exports.prove = prove;
215
212
  * @returns {boolean} True if verification succeeds.
216
213
  */
217
214
  function verify(curve, modulusBits, pk, ntilde, proof, c) {
215
+ if (proof.u === BigInt(0) || proof.s === BigInt(0)) {
216
+ return false;
217
+ }
218
218
  const modulusBytes = Math.floor((modulusBits + 7) / 8);
219
219
  const q = curve.order();
220
220
  const q3 = q ** BigInt(3);
221
221
  if (proof.s1 > q3) {
222
222
  return false;
223
223
  }
224
- const hash = crypto_1.createHash('sha256');
224
+ const hash = (0, crypto_1.createHash)('sha256');
225
225
  hash.update('\x06\x00\x00\x00\x00\x00\x00\x00');
226
- hash.update(util_1.bigIntToBufferBE(pk.n, modulusBytes));
226
+ hash.update((0, util_1.bigIntToBufferBE)(pk.n, modulusBytes));
227
227
  hash.update('$');
228
- hash.update(util_1.bigIntToBufferBE(pk.g, modulusBytes));
228
+ hash.update((0, util_1.bigIntToBufferBE)(pk.g, modulusBytes));
229
229
  hash.update('$');
230
- hash.update(util_1.bigIntToBufferBE(c, 2 * modulusBytes));
230
+ hash.update((0, util_1.bigIntToBufferBE)(c, 2 * modulusBytes));
231
231
  hash.update('$');
232
- hash.update(util_1.bigIntToBufferBE(proof.z, modulusBytes));
232
+ hash.update((0, util_1.bigIntToBufferBE)(proof.z, modulusBytes));
233
233
  hash.update('$');
234
- hash.update(util_1.bigIntToBufferBE(proof.u, 2 * modulusBytes));
234
+ hash.update((0, util_1.bigIntToBufferBE)(proof.u, 2 * modulusBytes));
235
235
  hash.update('$');
236
- hash.update(util_1.bigIntToBufferBE(proof.w, modulusBytes));
236
+ hash.update((0, util_1.bigIntToBufferBE)(proof.w, modulusBytes));
237
237
  hash.update('$');
238
- const e = util_1.bigIntFromBufferBE(hash.digest()) % q;
238
+ const e = (0, util_1.bigIntFromBufferBE)(hash.digest()) % q;
239
239
  let products;
240
- products = (bigint_mod_arith_1.modPow(pk.g, proof.s1, pk._n2) * bigint_mod_arith_1.modPow(proof.s, pk.n, pk._n2) * bigint_mod_arith_1.modPow(c, -e, pk._n2)) % pk._n2;
240
+ products = ((0, bigint_mod_arith_1.modPow)(pk.g, proof.s1, pk._n2) * (0, bigint_mod_arith_1.modPow)(proof.s, pk.n, pk._n2) * (0, bigint_mod_arith_1.modPow)(c, -e, pk._n2)) % pk._n2;
241
241
  if (proof.u !== products) {
242
242
  return false;
243
243
  }
244
244
  products =
245
- (((bigint_mod_arith_1.modPow(ntilde.h1, proof.s1, ntilde.ntilde) * bigint_mod_arith_1.modPow(ntilde.h2, proof.s2, ntilde.ntilde)) % ntilde.ntilde) *
246
- bigint_mod_arith_1.modPow(proof.z, -e, ntilde.ntilde)) %
245
+ ((((0, bigint_mod_arith_1.modPow)(ntilde.h1, proof.s1, ntilde.ntilde) * (0, bigint_mod_arith_1.modPow)(ntilde.h2, proof.s2, ntilde.ntilde)) % ntilde.ntilde) *
246
+ (0, bigint_mod_arith_1.modPow)(proof.z, -e, ntilde.ntilde)) %
247
247
  ntilde.ntilde;
248
- if (proof.w !== products) {
249
- return false;
250
- }
251
- return true;
248
+ return proof.w === products;
252
249
  }
253
- exports.verify = verify;
254
250
  /**
255
251
  * Generate a zero-knowledge range proof that a homomorphically manipulated value is "small".
256
252
  * @param {BaseCurve} curve An elliptic curve to use for group operations.
@@ -272,52 +268,51 @@ async function proveWithCheck(curve, modulusBits, pk, ntilde, c1, c2, x, y, r, X
272
268
  const q7 = q ** BigInt(7);
273
269
  const qntilde = q * ntilde.ntilde;
274
270
  const q3ntilde = q3 * ntilde.ntilde;
275
- const alpha = bigint_crypto_utils_1.randBetween(q3);
276
- const rho = bigint_crypto_utils_1.randBetween(qntilde);
277
- const sigma = bigint_crypto_utils_1.randBetween(qntilde);
278
- const tau = bigint_crypto_utils_1.randBetween(q3ntilde);
279
- const rhoprm = bigint_crypto_utils_1.randBetween(q3ntilde);
280
- const beta = await util_1.randomCoPrimeTo(pk.n);
281
- const gamma = bigint_crypto_utils_1.randBetween(q7);
271
+ const alpha = (0, bigint_crypto_utils_1.randBetween)(q3);
272
+ const rho = (0, bigint_crypto_utils_1.randBetween)(qntilde);
273
+ const sigma = (0, bigint_crypto_utils_1.randBetween)(qntilde);
274
+ const tau = (0, bigint_crypto_utils_1.randBetween)(q3ntilde);
275
+ const rhoprm = (0, bigint_crypto_utils_1.randBetween)(q3ntilde);
276
+ const beta = await (0, util_1.randomPositiveCoPrimeTo)(pk.n);
277
+ const gamma = (0, bigint_crypto_utils_1.randBetween)(q7);
282
278
  const u = curve.basePointMult(curve.scalarReduce(alpha));
283
- const z = (bigint_mod_arith_1.modPow(ntilde.h1, x, ntilde.ntilde) * bigint_mod_arith_1.modPow(ntilde.h2, rho, ntilde.ntilde)) % ntilde.ntilde;
284
- const zprm = (bigint_mod_arith_1.modPow(ntilde.h1, alpha, ntilde.ntilde) * bigint_mod_arith_1.modPow(ntilde.h2, rhoprm, ntilde.ntilde)) % ntilde.ntilde;
285
- const t = (bigint_mod_arith_1.modPow(ntilde.h1, y, ntilde.ntilde) * bigint_mod_arith_1.modPow(ntilde.h2, sigma, ntilde.ntilde)) % ntilde.ntilde;
286
- const v = (((bigint_mod_arith_1.modPow(c1, alpha, pk._n2) * bigint_mod_arith_1.modPow(pk.g, gamma, pk._n2)) % pk._n2) * bigint_mod_arith_1.modPow(beta, pk.n, pk._n2)) % pk._n2;
287
- const w = (bigint_mod_arith_1.modPow(ntilde.h1, gamma, ntilde.ntilde) * bigint_mod_arith_1.modPow(ntilde.h2, tau, ntilde.ntilde)) % ntilde.ntilde;
288
- const hash = crypto_1.createHash('sha256');
279
+ const z = ((0, bigint_mod_arith_1.modPow)(ntilde.h1, x, ntilde.ntilde) * (0, bigint_mod_arith_1.modPow)(ntilde.h2, rho, ntilde.ntilde)) % ntilde.ntilde;
280
+ const zprm = ((0, bigint_mod_arith_1.modPow)(ntilde.h1, alpha, ntilde.ntilde) * (0, bigint_mod_arith_1.modPow)(ntilde.h2, rhoprm, ntilde.ntilde)) % ntilde.ntilde;
281
+ const t = ((0, bigint_mod_arith_1.modPow)(ntilde.h1, y, ntilde.ntilde) * (0, bigint_mod_arith_1.modPow)(ntilde.h2, sigma, ntilde.ntilde)) % ntilde.ntilde;
282
+ const v = ((((0, bigint_mod_arith_1.modPow)(c1, alpha, pk._n2) * (0, bigint_mod_arith_1.modPow)(pk.g, gamma, pk._n2)) % pk._n2) * (0, bigint_mod_arith_1.modPow)(beta, pk.n, pk._n2)) % pk._n2;
283
+ const w = ((0, bigint_mod_arith_1.modPow)(ntilde.h1, gamma, ntilde.ntilde) * (0, bigint_mod_arith_1.modPow)(ntilde.h2, tau, ntilde.ntilde)) % ntilde.ntilde;
284
+ const hash = (0, crypto_1.createHash)('sha256');
289
285
  hash.update('\x0d\x00\x00\x00\x00\x00\x00\x00');
290
- hash.update(util_1.bigIntToBufferBE(pk.n, modulusBytes));
286
+ hash.update((0, util_1.bigIntToBufferBE)(pk.n, modulusBytes));
291
287
  hash.update('$');
292
- hash.update(util_1.bigIntToBufferBE(pk.g, modulusBytes));
288
+ hash.update((0, util_1.bigIntToBufferBE)(pk.g, modulusBytes));
293
289
  hash.update('$');
294
- hash.update(util_1.bigIntToBufferBE(X, 33));
290
+ hash.update((0, util_1.bigIntToBufferBE)(X, 33));
295
291
  hash.update('$');
296
- hash.update(util_1.bigIntToBufferBE(c1, 2 * modulusBytes));
292
+ hash.update((0, util_1.bigIntToBufferBE)(c1, 2 * modulusBytes));
297
293
  hash.update('$');
298
- hash.update(util_1.bigIntToBufferBE(c2, 2 * modulusBytes));
294
+ hash.update((0, util_1.bigIntToBufferBE)(c2, 2 * modulusBytes));
299
295
  hash.update('$');
300
- hash.update(util_1.bigIntToBufferBE(u, 33));
296
+ hash.update((0, util_1.bigIntToBufferBE)(u, 33));
301
297
  hash.update('$');
302
- hash.update(util_1.bigIntToBufferBE(z, modulusBytes));
298
+ hash.update((0, util_1.bigIntToBufferBE)(z, modulusBytes));
303
299
  hash.update('$');
304
- hash.update(util_1.bigIntToBufferBE(zprm, modulusBytes));
300
+ hash.update((0, util_1.bigIntToBufferBE)(zprm, modulusBytes));
305
301
  hash.update('$');
306
- hash.update(util_1.bigIntToBufferBE(t, modulusBytes));
302
+ hash.update((0, util_1.bigIntToBufferBE)(t, modulusBytes));
307
303
  hash.update('$');
308
- hash.update(util_1.bigIntToBufferBE(v, 2 * modulusBytes));
304
+ hash.update((0, util_1.bigIntToBufferBE)(v, 2 * modulusBytes));
309
305
  hash.update('$');
310
- hash.update(util_1.bigIntToBufferBE(w, modulusBytes));
306
+ hash.update((0, util_1.bigIntToBufferBE)(w, modulusBytes));
311
307
  hash.update('$');
312
- const e = util_1.bigIntFromBufferBE(hash.digest()) % q;
313
- const s = (bigint_mod_arith_1.modPow(r, e, pk.n) * beta) % pk.n;
308
+ const e = (0, util_1.bigIntFromBufferBE)(hash.digest()) % q;
309
+ const s = ((0, bigint_mod_arith_1.modPow)(r, e, pk.n) * beta) % pk.n;
314
310
  const s1 = e * x + alpha;
315
311
  const s2 = e * rho + rhoprm;
316
312
  const t1 = e * y + gamma;
317
313
  const t2 = e * sigma + tau;
318
314
  return { z, zprm, t, v, w, s, s1, s2, t1, t2, u };
319
315
  }
320
- exports.proveWithCheck = proveWithCheck;
321
316
  /**
322
317
  * Verify a zero-knowledge range proof that a homomorphically manipulated value is "small".
323
318
  * @param {BaseCurve} curve An elliptic curve to use for group operations.
@@ -341,63 +336,59 @@ function verifyWithCheck(curve, modulusBits, pk, ntilde, proof, c1, c2, X) {
341
336
  if (proof.t1 > q7) {
342
337
  return false;
343
338
  }
344
- const hash = crypto_1.createHash('sha256');
339
+ const hash = (0, crypto_1.createHash)('sha256');
345
340
  hash.update('\x0d\x00\x00\x00\x00\x00\x00\x00');
346
- hash.update(util_1.bigIntToBufferBE(pk.n, modulusBytes));
341
+ hash.update((0, util_1.bigIntToBufferBE)(pk.n, modulusBytes));
347
342
  hash.update('$');
348
- hash.update(util_1.bigIntToBufferBE(pk.g, modulusBytes));
343
+ hash.update((0, util_1.bigIntToBufferBE)(pk.g, modulusBytes));
349
344
  hash.update('$');
350
- hash.update(util_1.bigIntToBufferBE(X, 33));
345
+ hash.update((0, util_1.bigIntToBufferBE)(X, 33));
351
346
  hash.update('$');
352
- hash.update(util_1.bigIntToBufferBE(c1, 2 * modulusBytes));
347
+ hash.update((0, util_1.bigIntToBufferBE)(c1, 2 * modulusBytes));
353
348
  hash.update('$');
354
- hash.update(util_1.bigIntToBufferBE(c2, 2 * modulusBytes));
349
+ hash.update((0, util_1.bigIntToBufferBE)(c2, 2 * modulusBytes));
355
350
  hash.update('$');
356
- hash.update(util_1.bigIntToBufferBE(proof.u, 33));
351
+ hash.update((0, util_1.bigIntToBufferBE)(proof.u, 33));
357
352
  hash.update('$');
358
- hash.update(util_1.bigIntToBufferBE(proof.z, modulusBytes));
353
+ hash.update((0, util_1.bigIntToBufferBE)(proof.z, modulusBytes));
359
354
  hash.update('$');
360
- hash.update(util_1.bigIntToBufferBE(proof.zprm, modulusBytes));
355
+ hash.update((0, util_1.bigIntToBufferBE)(proof.zprm, modulusBytes));
361
356
  hash.update('$');
362
- hash.update(util_1.bigIntToBufferBE(proof.t, modulusBytes));
357
+ hash.update((0, util_1.bigIntToBufferBE)(proof.t, modulusBytes));
363
358
  hash.update('$');
364
- hash.update(util_1.bigIntToBufferBE(proof.v, 2 * modulusBytes));
359
+ hash.update((0, util_1.bigIntToBufferBE)(proof.v, 2 * modulusBytes));
365
360
  hash.update('$');
366
- hash.update(util_1.bigIntToBufferBE(proof.w, modulusBytes));
361
+ hash.update((0, util_1.bigIntToBufferBE)(proof.w, modulusBytes));
367
362
  hash.update('$');
368
- const e = util_1.bigIntFromBufferBE(hash.digest()) % q;
363
+ const e = (0, util_1.bigIntFromBufferBE)(hash.digest()) % q;
369
364
  const gS1 = curve.basePointMult(curve.scalarReduce(proof.s1));
370
365
  const xEU = curve.pointAdd(curve.pointMultiply(X, e), proof.u);
371
- if (gS1 != xEU) {
366
+ if (gS1 !== xEU) {
372
367
  return false;
373
368
  }
374
369
  let left, right;
375
- const h1ExpS1 = bigint_mod_arith_1.modPow(ntilde.h1, proof.s1, ntilde.ntilde);
376
- const h2ExpS2 = bigint_mod_arith_1.modPow(ntilde.h2, proof.s2, ntilde.ntilde);
370
+ const h1ExpS1 = (0, bigint_mod_arith_1.modPow)(ntilde.h1, proof.s1, ntilde.ntilde);
371
+ const h2ExpS2 = (0, bigint_mod_arith_1.modPow)(ntilde.h2, proof.s2, ntilde.ntilde);
377
372
  left = (h1ExpS1 * h2ExpS2) % ntilde.ntilde;
378
- const zExpE = bigint_mod_arith_1.modPow(proof.z, e, ntilde.ntilde);
373
+ const zExpE = (0, bigint_mod_arith_1.modPow)(proof.z, e, ntilde.ntilde);
379
374
  right = (zExpE * proof.zprm) % ntilde.ntilde;
380
375
  if (left !== right) {
381
376
  return false;
382
377
  }
383
- const h1ExpT1 = bigint_mod_arith_1.modPow(ntilde.h1, proof.t1, ntilde.ntilde);
384
- const h2ExpT2 = bigint_mod_arith_1.modPow(ntilde.h2, proof.t2, ntilde.ntilde);
378
+ const h1ExpT1 = (0, bigint_mod_arith_1.modPow)(ntilde.h1, proof.t1, ntilde.ntilde);
379
+ const h2ExpT2 = (0, bigint_mod_arith_1.modPow)(ntilde.h2, proof.t2, ntilde.ntilde);
385
380
  left = (h1ExpT1 * h2ExpT2) % ntilde.ntilde;
386
- const tExpE = bigint_mod_arith_1.modPow(proof.t, e, ntilde.ntilde);
381
+ const tExpE = (0, bigint_mod_arith_1.modPow)(proof.t, e, ntilde.ntilde);
387
382
  right = (tExpE * proof.w) % ntilde.ntilde;
388
383
  if (left !== right) {
389
384
  return false;
390
385
  }
391
- const c1ExpS1 = bigint_mod_arith_1.modPow(c1, proof.s1, pk._n2);
392
- const sExpN = bigint_mod_arith_1.modPow(proof.s, pk.n, pk._n2);
393
- const gammaExpT1 = bigint_mod_arith_1.modPow(pk.g, proof.t1, pk._n2);
386
+ const c1ExpS1 = (0, bigint_mod_arith_1.modPow)(c1, proof.s1, pk._n2);
387
+ const sExpN = (0, bigint_mod_arith_1.modPow)(proof.s, pk.n, pk._n2);
388
+ const gammaExpT1 = (0, bigint_mod_arith_1.modPow)(pk.g, proof.t1, pk._n2);
394
389
  left = (((c1ExpS1 * sExpN) % pk._n2) * gammaExpT1) % pk._n2;
395
- const c2ExpE = bigint_mod_arith_1.modPow(c2, e, pk._n2);
390
+ const c2ExpE = (0, bigint_mod_arith_1.modPow)(c2, e, pk._n2);
396
391
  right = (c2ExpE * proof.v) % pk._n2;
397
- if (left !== right) {
398
- return false;
399
- }
400
- return true;
392
+ return left === right;
401
393
  }
402
- exports.verifyWithCheck = verifyWithCheck;
403
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rangeproof.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa/rangeproof.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Zero Knowledge Range Proofs as described in (Two-party generation of DSA signatures)[1].\n * [1]: https://reitermk.github.io/papers/2004/IJIS.pdf\n */\nimport { createHash } from 'crypto';\nimport { BaseCurve } from '../../curves';\nimport { PublicKey } from 'paillier-bigint';\nimport { bitLength, randBetween } from 'bigint-crypto-utils';\nimport { modInv, modPow } from 'bigint-mod-arith';\nimport {\n  DeserializedNtilde,\n  DeserializedNtildeProof,\n  RSAModulus,\n  RangeProof,\n  RangeProofWithCheck,\n  DeserializedNtildeWithProofs,\n} from './types';\nimport { bigIntFromBufferBE, bigIntToBufferBE, randomCoPrimeTo } from '../../util';\nimport { OpenSSL } from '../../openssl';\n\n// 128 as recommend by https://blog.verichains.io/p/vsa-2022-120-multichain-key-extraction.\nconst ITERATIONS = 128;\n\nexport async function generateSafePrimes(bitLengths: number[]): Promise<bigint[]> {\n  const openSSL = new OpenSSL();\n  await openSSL.init();\n  const promises: Promise<bigint>[] = bitLengths.map((bitlength: number) => {\n    return openSSL.generateSafePrime(bitlength);\n  });\n  return await Promise.all(promises);\n}\n\nasync function generateModulus(bitlength: number): Promise<RSAModulus> {\n  if (bitlength < 3072) {\n    // https://www.keylength.com/en/6/\n    console.warn('Generating a modulus with less than 3072 is not recommended!');\n  }\n  const bitlengthP = Math.floor(bitlength / 2);\n  const bitlengthQ = bitlength - bitlengthP;\n  const [p, q] = await generateSafePrimes([bitlengthP, bitlengthQ]);\n  const n = p * q;\n  // We never expect this to happen unless something went wrong with the wasm/openssl module\n  if (bitLength(n) !== bitlength) {\n    throw new Error(\n      `Unable to generate modulus with bit length of ${bitlength}. Expected length ${bitlength}, got \n      ${bitLength(n)}. please try again or reach out to support@bitgo.com`\n    );\n  }\n  return { n, q1: (p - BigInt(1)) / BigInt(2), q2: (q - BigInt(1)) / BigInt(2) };\n}\n\n/**\n * Generate \"challenge\" values for range proofs.\n * @param {number} bitlength The bit length of the modulus to generate. This should\n * be the same as the bit length of the paillier public keys used for MtA.\n * @returns {DeserializedNtilde} The generated Ntilde values.\n */\nexport async function generateNtilde(bitlength: number): Promise<DeserializedNtildeWithProofs> {\n  const { n: ntilde, q1, q2 } = await generateModulus(bitlength);\n  const [f1, f2] = await Promise.all([randomCoPrimeTo(ntilde), randomCoPrimeTo(ntilde)]);\n  const h1 = modPow(f1, BigInt(2), ntilde);\n  const h2 = modPow(h1, f2, ntilde);\n  const beta = modInv(f2, q1 * q2);\n  const [h1wrtH2Proofs, h2wrtH1Proofs] = await Promise.all([\n    generateNtildeProof(\n      {\n        h1: h1,\n        h2: h2,\n        ntilde: ntilde,\n      },\n      f2,\n      q1,\n      q2\n    ),\n    generateNtildeProof(\n      {\n        h1: h2,\n        h2: h1,\n        ntilde: ntilde,\n      },\n      beta,\n      q1,\n      q2\n    ),\n  ]);\n  return {\n    ntilde,\n    h1,\n    h2,\n    ntildeProof: {\n      h1WrtH2: {\n        alpha: h1wrtH2Proofs.alpha,\n        t: h1wrtH2Proofs.t,\n      },\n      h2WrtH1: {\n        alpha: h2wrtH1Proofs.alpha,\n        t: h2wrtH1Proofs.t,\n      },\n    },\n  };\n}\n\n/**\n * Generate iterations of Ntilde, h1, h2 discrete log proofs.\n * @param {DeserializedNtilde} ntilde Ntilde, h1, h2 to generate the proofs for.\n * @param {bigint} x Either alpha or beta depending on whether it is a discrete log proof of\n * h1 w.r.t h2 or h2 w.r.t h1.\n * @param {bigint} q1 The Sophie Germain prime associated with the first safe prime p1 used to generate Ntilde.\n * @param {bigint} q2 The Sophie Germain prime associated with the second safe prime p2 used to generate Ntilde.\n * @returns {NtildeProof} The generated Ntilde Proofs.\n */\nexport async function generateNtildeProof(\n  ntilde: DeserializedNtilde,\n  x: bigint,\n  q1: bigint,\n  q2: bigint\n): Promise<DeserializedNtildeProof> {\n  const q1MulQ2 = q1 * q2;\n  const a: bigint[] = [];\n  const alpha: bigint[] = [];\n  let msgToHash: Buffer = Buffer.concat([\n    bigIntToBufferBE(ntilde.h1),\n    bigIntToBufferBE(ntilde.h2),\n    bigIntToBufferBE(ntilde.ntilde),\n  ]);\n  for (let i = 0; i < ITERATIONS; i++) {\n    a.push(randBetween(q1MulQ2));\n    alpha.push(modPow(ntilde.h1, a[i], ntilde.ntilde));\n    msgToHash = Buffer.concat([msgToHash, bigIntToBufferBE(alpha[i], Math.ceil(bitLength(ntilde.ntilde) / 8))]);\n  }\n  const simulatedResponse = createHash('sha256').update(msgToHash).digest();\n  const t: bigint[] = [];\n  for (let i = 0; i < ITERATIONS; i++) {\n    // Get the ith bit from a buffer of bytes.\n    const ithBit = (simulatedResponse[Math.floor(i / 8)] >> (7 - (i % 8))) & 1;\n    t.push((a[i] + ((BigInt(ithBit) * x) % q1MulQ2)) % q1MulQ2);\n  }\n  return { alpha, t };\n}\n\n/**\n * Verify discrete log proofs of h1 and h2 mod Ntilde.\n * @param {DeserializedNtilde} ntilde Ntilde, h1, h2 to generate the proofs for.\n * @param {DeserializedNtildeProof} ntildeProof Ntilde Proofs\n * @returns {boolean} true if proof is verified, false otherwise.\n */\nexport async function verifyNtildeProof(\n  ntilde: DeserializedNtilde,\n  ntildeProof: DeserializedNtildeProof\n): Promise<boolean> {\n  const h1ModNtilde = ntilde.h1 % ntilde.ntilde;\n  const h2ModNtilde = ntilde.h2 % ntilde.ntilde;\n  if (h1ModNtilde === BigInt(0) || h2ModNtilde === BigInt(0)) {\n    return false;\n  }\n  if (h1ModNtilde === BigInt(1) || h2ModNtilde === BigInt(1)) {\n    return false;\n  }\n  if (h1ModNtilde === h2ModNtilde) {\n    return false;\n  }\n  if (\n    ntildeProof.alpha.length > 256 ||\n    ntildeProof.alpha.length !== ITERATIONS ||\n    ntildeProof.t.length !== ITERATIONS\n  ) {\n    return false;\n  }\n  let msgToHash: Buffer = Buffer.concat([\n    bigIntToBufferBE(ntilde.h1),\n    bigIntToBufferBE(ntilde.h2),\n    bigIntToBufferBE(ntilde.ntilde),\n  ]);\n  for (let i = 0; i < ntildeProof.alpha.length; i++) {\n    msgToHash = Buffer.concat([\n      msgToHash,\n      bigIntToBufferBE(ntildeProof.alpha[i], Math.ceil(bitLength(ntilde.ntilde) / 8)),\n    ]);\n  }\n  const simulatedResponse = createHash('sha256').update(msgToHash).digest();\n  for (let i = 0; i < ntildeProof.alpha.length; i++) {\n    // Get the ith bit from a buffer of bytes.\n    const ithBit = (simulatedResponse[Math.floor(i / 8)] >> (7 - (i % 8))) & 1;\n    const h1PowTi = modPow(ntilde.h1, ntildeProof.t[i], ntilde.ntilde);\n    const h2PowCi = modPow(ntilde.h2, BigInt(ithBit), ntilde.ntilde);\n    const alphaMulh2PowCi = (ntildeProof.alpha[i] * h2PowCi) % ntilde.ntilde;\n    if (h1PowTi !== alphaMulh2PowCi) {\n      return false;\n    }\n  }\n  return true;\n}\n/**\n * Generate a zero-knowledge range proof that an encrypted value is \"small\".\n * @param {BaseCurve} curve An elliptic curve to use for group operations.\n * @param {number} modulusBits The bit count of the prover's public key.\n * @param {PublicKey} pk The prover's public key.\n * @param {DeserializedNtilde} ntilde The verifier's Ntilde values.\n * @param {bigint} c The ciphertext.\n * @param {bigint} m The plaintext.\n * @param {bigint} r The obfuscation value used to encrypt m.\n * @returns {RangeProof} The generated proof.\n */\nexport async function prove(\n  curve: BaseCurve,\n  modulusBits: number,\n  pk: PublicKey,\n  ntilde: DeserializedNtilde,\n  c: bigint,\n  m: bigint,\n  r: bigint\n): Promise<RangeProof> {\n  const modulusBytes = Math.floor((modulusBits + 7) / 8);\n  const q = curve.order();\n  const q3 = q ** BigInt(3);\n  const qntilde = q * ntilde.ntilde;\n  const q3ntilde = q3 * ntilde.ntilde;\n  const alpha = randBetween(q3);\n  const beta = await randomCoPrimeTo(pk.n);\n  const gamma = randBetween(q3ntilde);\n  const rho = randBetween(qntilde);\n  const z = (modPow(ntilde.h1, m, ntilde.ntilde) * modPow(ntilde.h2, rho, ntilde.ntilde)) % ntilde.ntilde;\n  const u = (modPow(pk.g, alpha, pk._n2) * modPow(beta, pk.n, pk._n2)) % pk._n2;\n  const w = (modPow(ntilde.h1, alpha, ntilde.ntilde) * modPow(ntilde.h2, gamma, ntilde.ntilde)) % ntilde.ntilde;\n  const hash = createHash('sha256');\n  hash.update('\\x06\\x00\\x00\\x00\\x00\\x00\\x00\\x00');\n  hash.update(bigIntToBufferBE(pk.n, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(pk.g, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(c, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(z, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(u, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(w, modulusBytes));\n  hash.update('$');\n  const e = bigIntFromBufferBE(hash.digest()) % q;\n  const s = (modPow(r, e, pk.n) * beta) % pk.n;\n  const s1 = e * m + alpha;\n  const s2 = e * rho + gamma;\n  return { z, u, w, s, s1, s2 };\n}\n\n/**\n * Verify a zero-knowledge range proof that an encrypted value is \"small\".\n * @param {BaseCurve} curve An elliptic curve to use for group operations.\n * @param {number} modulusBits The bit count of the prover's public key.\n * @param {PublicKey} pk The prover's public key.\n * @param {DeserializedNtilde} ntilde The verifier's Ntilde values.\n * @param {RangeProof} proof The range proof.\n * @param {bigint} c The ciphertext.\n * @returns {boolean} True if verification succeeds.\n */\nexport function verify(\n  curve: BaseCurve,\n  modulusBits: number,\n  pk: PublicKey,\n  ntilde: DeserializedNtilde,\n  proof: RangeProof,\n  c: bigint\n): boolean {\n  const modulusBytes = Math.floor((modulusBits + 7) / 8);\n  const q = curve.order();\n  const q3 = q ** BigInt(3);\n  if (proof.s1 > q3) {\n    return false;\n  }\n  const hash = createHash('sha256');\n  hash.update('\\x06\\x00\\x00\\x00\\x00\\x00\\x00\\x00');\n  hash.update(bigIntToBufferBE(pk.n, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(pk.g, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(c, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.z, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.u, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.w, modulusBytes));\n  hash.update('$');\n  const e = bigIntFromBufferBE(hash.digest()) % q;\n  let products: bigint;\n  products = (modPow(pk.g, proof.s1, pk._n2) * modPow(proof.s, pk.n, pk._n2) * modPow(c, -e, pk._n2)) % pk._n2;\n  if (proof.u !== products) {\n    return false;\n  }\n  products =\n    (((modPow(ntilde.h1, proof.s1, ntilde.ntilde) * modPow(ntilde.h2, proof.s2, ntilde.ntilde)) % ntilde.ntilde) *\n      modPow(proof.z, -e, ntilde.ntilde)) %\n    ntilde.ntilde;\n  if (proof.w !== products) {\n    return false;\n  }\n  return true;\n}\n\n/**\n * Generate a zero-knowledge range proof that a homomorphically manipulated value is \"small\".\n * @param {BaseCurve} curve An elliptic curve to use for group operations.\n * @param {number} modulusBits The bit count of the prover's public key.\n * @param {PublicKey} pk The prover's public key.\n * @param {DeserializedNtilde} ntilde The verifier's Ntilde values.\n * @param {bigint} c1 The original ciphertext.\n * @param {bigint} c2 The manipulated ciphertext.\n * @param {bigint} x The plaintext value multiplied by the original plaintext.\n * @param {bigint} y The plaintext value that is added to x.\n * @param {bigint} r The obfuscation value used to encrypt x.\n * @param {bigint} X The curve's base point raised to x.\n * @returns {RangeProofWithCheck} The generated proof.\n */\nexport async function proveWithCheck(\n  curve: BaseCurve,\n  modulusBits: number,\n  pk: PublicKey,\n  ntilde: DeserializedNtilde,\n  c1: bigint,\n  c2: bigint,\n  x: bigint,\n  y: bigint,\n  r: bigint,\n  X: bigint\n): Promise<RangeProofWithCheck> {\n  const modulusBytes = Math.floor((modulusBits + 7) / 8);\n  const q = curve.order();\n  const q3 = q ** BigInt(3);\n  const q7 = q ** BigInt(7);\n  const qntilde = q * ntilde.ntilde;\n  const q3ntilde = q3 * ntilde.ntilde;\n  const alpha = randBetween(q3);\n  const rho = randBetween(qntilde);\n  const sigma = randBetween(qntilde);\n  const tau = randBetween(q3ntilde);\n  const rhoprm = randBetween(q3ntilde);\n  const beta = await randomCoPrimeTo(pk.n);\n  const gamma = randBetween(q7);\n  const u = curve.basePointMult(curve.scalarReduce(alpha));\n  const z = (modPow(ntilde.h1, x, ntilde.ntilde) * modPow(ntilde.h2, rho, ntilde.ntilde)) % ntilde.ntilde;\n  const zprm = (modPow(ntilde.h1, alpha, ntilde.ntilde) * modPow(ntilde.h2, rhoprm, ntilde.ntilde)) % ntilde.ntilde;\n  const t = (modPow(ntilde.h1, y, ntilde.ntilde) * modPow(ntilde.h2, sigma, ntilde.ntilde)) % ntilde.ntilde;\n  const v =\n    (((modPow(c1, alpha, pk._n2) * modPow(pk.g, gamma, pk._n2)) % pk._n2) * modPow(beta, pk.n, pk._n2)) % pk._n2;\n  const w = (modPow(ntilde.h1, gamma, ntilde.ntilde) * modPow(ntilde.h2, tau, ntilde.ntilde)) % ntilde.ntilde;\n  const hash = createHash('sha256');\n  hash.update('\\x0d\\x00\\x00\\x00\\x00\\x00\\x00\\x00');\n  hash.update(bigIntToBufferBE(pk.n, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(pk.g, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(X, 33));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(c1, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(c2, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(u, 33));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(z, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(zprm, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(t, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(v, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(w, modulusBytes));\n  hash.update('$');\n  const e = bigIntFromBufferBE(hash.digest()) % q;\n  const s = (modPow(r, e, pk.n) * beta) % pk.n;\n  const s1 = e * x + alpha;\n  const s2 = e * rho + rhoprm;\n  const t1 = e * y + gamma;\n  const t2 = e * sigma + tau;\n  return { z, zprm, t, v, w, s, s1, s2, t1, t2, u };\n}\n\n/**\n * Verify a zero-knowledge range proof that a homomorphically manipulated value is \"small\".\n * @param {BaseCurve} curve An elliptic curve to use for group operations.\n * @param {number} modulusBits The bit count of the prover's public key.\n * @param {PublicKey} pk The prover's public key.\n * @param {DeserializedNtilde} ntilde The verifier's Ntilde values.\n * @param {RangeProofWithCheck} proof The range proof.\n * @param {bigint} c1 The original ciphertext.\n * @param {bigint} c2 The manipulated ciphertext.\n * @param {bigint} X The curve's base point raised to x.\n * @returns {boolean} True if verification succeeds.\n */\nexport function verifyWithCheck(\n  curve: BaseCurve,\n  modulusBits: number,\n  pk: PublicKey,\n  ntilde: DeserializedNtilde,\n  proof: RangeProofWithCheck,\n  c1: bigint,\n  c2: bigint,\n  X: bigint\n): boolean {\n  const modulusBytes = Math.floor((modulusBits + 7) / 8);\n  const q = curve.order();\n  const q3 = q ** BigInt(3);\n  const q7 = q ** BigInt(7);\n  if (proof.s1 > q3) {\n    return false;\n  }\n  if (proof.t1 > q7) {\n    return false;\n  }\n  const hash = createHash('sha256');\n  hash.update('\\x0d\\x00\\x00\\x00\\x00\\x00\\x00\\x00');\n  hash.update(bigIntToBufferBE(pk.n, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(pk.g, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(X, 33));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(c1, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(c2, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.u, 33));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.z, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.zprm, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.t, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.v, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.w, modulusBytes));\n  hash.update('$');\n  const e = bigIntFromBufferBE(hash.digest()) % q;\n  const gS1 = curve.basePointMult(curve.scalarReduce(proof.s1));\n  const xEU = curve.pointAdd(curve.pointMultiply(X, e), proof.u);\n  if (gS1 != xEU) {\n    return false;\n  }\n  let left, right;\n  const h1ExpS1 = modPow(ntilde.h1, proof.s1, ntilde.ntilde);\n  const h2ExpS2 = modPow(ntilde.h2, proof.s2, ntilde.ntilde);\n  left = (h1ExpS1 * h2ExpS2) % ntilde.ntilde;\n  const zExpE = modPow(proof.z, e, ntilde.ntilde);\n  right = (zExpE * proof.zprm) % ntilde.ntilde;\n  if (left !== right) {\n    return false;\n  }\n  const h1ExpT1 = modPow(ntilde.h1, proof.t1, ntilde.ntilde);\n  const h2ExpT2 = modPow(ntilde.h2, proof.t2, ntilde.ntilde);\n  left = (h1ExpT1 * h2ExpT2) % ntilde.ntilde;\n  const tExpE = modPow(proof.t, e, ntilde.ntilde);\n  right = (tExpE * proof.w) % ntilde.ntilde;\n  if (left !== right) {\n    return false;\n  }\n  const c1ExpS1 = modPow(c1, proof.s1, pk._n2);\n  const sExpN = modPow(proof.s, pk.n, pk._n2);\n  const gammaExpT1 = modPow(pk.g, proof.t1, pk._n2);\n  left = (((c1ExpS1 * sExpN) % pk._n2) * gammaExpT1) % pk._n2;\n  const c2ExpE = modPow(c2, e, pk._n2);\n  right = (c2ExpE * proof.v) % pk._n2;\n  if (left !== right) {\n    return false;\n  }\n  return true;\n}\n"]}
394
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rangeproof.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa/rangeproof.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Zero Knowledge Range Proofs as described in (Two-party generation of DSA signatures)[1].\n * [1]: https://reitermk.github.io/papers/2004/IJIS.pdf\n */\nimport { createHash } from 'crypto';\nimport { BaseCurve } from '../../curves';\nimport { PublicKey } from 'paillier-bigint';\nimport { bitLength, randBetween } from 'bigint-crypto-utils';\nimport { modInv, modPow } from 'bigint-mod-arith';\nimport {\n  DeserializedNtilde,\n  DeserializedNtildeProof,\n  RSAModulus,\n  RangeProof,\n  RangeProofWithCheck,\n  DeserializedNtildeWithProofs,\n} from './types';\nimport { bigIntFromBufferBE, bigIntToBufferBE, randomPositiveCoPrimeTo } from '../../util';\nimport { minModulusBitLength } from './index';\nimport { generateSafePrimes } from '../../safePrime';\n\n// 128 as recommend by https://blog.verichains.io/p/vsa-2022-120-multichain-key-extraction.\nconst ITERATIONS = 128;\n\nasync function generateModulus(\n  openSSLBytes: Uint8Array,\n  bitlength = minModulusBitLength,\n  retry = 10\n): Promise<RSAModulus> {\n  if (bitlength < minModulusBitLength) {\n    // https://www.keylength.com/en/6/\n    // eslint-disable-next-line no-console\n    console.warn('Generating a modulus with less than 3072 is not recommended!');\n  }\n  const bitlengthP = Math.floor(bitlength / 2);\n  const bitlengthQ = bitlength - bitlengthP;\n  for (let i = 0; i < retry; i++) {\n    const [p, q] = await generateSafePrimes([bitlengthP, bitlengthQ], openSSLBytes);\n    const n = p * q;\n    // For large bit lengths, the probability of generating a modulus with the wrong bit length is very low.\n    if (bitLength(n) !== bitlength) {\n      continue;\n    }\n    return { n, q1: (p - BigInt(1)) / BigInt(2), q2: (q - BigInt(1)) / BigInt(2) };\n  }\n  throw new Error(\n    `Unable to generate modulus with bit length of ${bitlength} after ${retry} tries. Please try again or reach out to support@bitgo.com`\n  );\n}\n\n/**\n * Generate \"challenge\" values for range proofs.\n * @param {number} bitlength The bit length of the modulus to generate. This should\n * be the same as the bit length of the paillier public keys used for MtA.\n * @returns {DeserializedNtilde} The generated Ntilde values.\n */\nexport async function generateNtilde(\n  openSSLBytes: Uint8Array,\n  bitlength = minModulusBitLength\n): Promise<DeserializedNtildeWithProofs> {\n  const { n: ntilde, q1, q2 } = await generateModulus(openSSLBytes, bitlength);\n  const [f1, f2] = await Promise.all([randomPositiveCoPrimeTo(ntilde), randomPositiveCoPrimeTo(ntilde)]);\n  const h1 = modPow(f1, BigInt(2), ntilde);\n  const h2 = modPow(h1, f2, ntilde);\n  const beta = modInv(f2, q1 * q2);\n  const [h1wrtH2Proofs, h2wrtH1Proofs] = await Promise.all([\n    generateNtildeProof(\n      {\n        h1: h1,\n        h2: h2,\n        ntilde: ntilde,\n      },\n      f2,\n      q1,\n      q2\n    ),\n    generateNtildeProof(\n      {\n        h1: h2,\n        h2: h1,\n        ntilde: ntilde,\n      },\n      beta,\n      q1,\n      q2\n    ),\n  ]);\n  return {\n    ntilde,\n    h1,\n    h2,\n    ntildeProof: {\n      h1WrtH2: {\n        alpha: h1wrtH2Proofs.alpha,\n        t: h1wrtH2Proofs.t,\n      },\n      h2WrtH1: {\n        alpha: h2wrtH1Proofs.alpha,\n        t: h2wrtH1Proofs.t,\n      },\n    },\n  };\n}\n\n/**\n * Generate iterations of Ntilde, h1, h2 discrete log proofs.\n * @param {DeserializedNtilde} ntilde Ntilde, h1, h2 to generate the proofs for.\n * @param {bigint} x Either alpha or beta depending on whether it is a discrete log proof of\n * h1 w.r.t h2 or h2 w.r.t h1.\n * @param {bigint} q1 The Sophie Germain prime associated with the first safe prime p1 used to generate Ntilde.\n * @param {bigint} q2 The Sophie Germain prime associated with the second safe prime p2 used to generate Ntilde.\n * @returns {NtildeProof} The generated Ntilde Proofs.\n */\nexport async function generateNtildeProof(\n  ntilde: DeserializedNtilde,\n  x: bigint,\n  q1: bigint,\n  q2: bigint\n): Promise<DeserializedNtildeProof> {\n  const q1MulQ2 = q1 * q2;\n  const a: bigint[] = [];\n  const alpha: bigint[] = [];\n  let msgToHash: Buffer = Buffer.concat([\n    bigIntToBufferBE(ntilde.h1),\n    bigIntToBufferBE(ntilde.h2),\n    bigIntToBufferBE(ntilde.ntilde),\n  ]);\n  for (let i = 0; i < ITERATIONS; i++) {\n    a.push(randBetween(q1MulQ2));\n    alpha.push(modPow(ntilde.h1, a[i], ntilde.ntilde));\n    msgToHash = Buffer.concat([msgToHash, bigIntToBufferBE(alpha[i], Math.ceil(bitLength(ntilde.ntilde) / 8))]);\n  }\n  const simulatedResponse = createHash('sha256').update(msgToHash).digest();\n  const t: bigint[] = [];\n  for (let i = 0; i < ITERATIONS; i++) {\n    // Get the ith bit from a buffer of bytes.\n    const ithBit = (simulatedResponse[Math.floor(i / 8)] >> (7 - (i % 8))) & 1;\n    t.push((a[i] + ((BigInt(ithBit) * x) % q1MulQ2)) % q1MulQ2);\n  }\n  return { alpha, t };\n}\n\n/**\n * Verify discrete log proofs of h1 and h2 mod Ntilde.\n * @param {DeserializedNtilde} ntilde Ntilde, h1, h2 to generate the proofs for.\n * @param {DeserializedNtildeProof} ntildeProof Ntilde Proofs\n * @returns {boolean} true if proof is verified, false otherwise.\n */\nexport async function verifyNtildeProof(\n  ntilde: DeserializedNtilde,\n  ntildeProof: DeserializedNtildeProof\n): Promise<boolean> {\n  const h1ModNtilde = ntilde.h1 % ntilde.ntilde;\n  const h2ModNtilde = ntilde.h2 % ntilde.ntilde;\n  if (h1ModNtilde === BigInt(0) || h2ModNtilde === BigInt(0)) {\n    return false;\n  }\n  if (h1ModNtilde === BigInt(1) || h2ModNtilde === BigInt(1)) {\n    return false;\n  }\n  if (h1ModNtilde === h2ModNtilde) {\n    return false;\n  }\n  if (\n    ntildeProof.alpha.length > 256 ||\n    ntildeProof.alpha.length !== ITERATIONS ||\n    ntildeProof.t.length !== ITERATIONS\n  ) {\n    return false;\n  }\n  let msgToHash: Buffer = Buffer.concat([\n    bigIntToBufferBE(ntilde.h1),\n    bigIntToBufferBE(ntilde.h2),\n    bigIntToBufferBE(ntilde.ntilde),\n  ]);\n  for (let i = 0; i < ntildeProof.alpha.length; i++) {\n    msgToHash = Buffer.concat([\n      msgToHash,\n      bigIntToBufferBE(ntildeProof.alpha[i], Math.ceil(bitLength(ntilde.ntilde) / 8)),\n    ]);\n  }\n  const simulatedResponse = createHash('sha256').update(msgToHash).digest();\n  for (let i = 0; i < ntildeProof.alpha.length; i++) {\n    // Get the ith bit from a buffer of bytes.\n    const ithBit = (simulatedResponse[Math.floor(i / 8)] >> (7 - (i % 8))) & 1;\n    const h1PowTi = modPow(ntilde.h1, ntildeProof.t[i], ntilde.ntilde);\n    const h2PowCi = modPow(ntilde.h2, BigInt(ithBit), ntilde.ntilde);\n    const alphaMulh2PowCi = (ntildeProof.alpha[i] * h2PowCi) % ntilde.ntilde;\n    if (h1PowTi !== alphaMulh2PowCi) {\n      return false;\n    }\n  }\n  return true;\n}\n/**\n * Generate a zero-knowledge range proof that an encrypted value is \"small\".\n * @param {BaseCurve} curve An elliptic curve to use for group operations.\n * @param {number} modulusBits The bit count of the prover's public key.\n * @param {PublicKey} pk The prover's public key.\n * @param {DeserializedNtilde} ntilde The verifier's Ntilde values.\n * @param {bigint} c The ciphertext.\n * @param {bigint} m The plaintext.\n * @param {bigint} r The obfuscation value used to encrypt m.\n * @returns {RangeProof} The generated proof.\n */\nexport async function prove(\n  curve: BaseCurve,\n  modulusBits: number,\n  pk: PublicKey,\n  ntilde: DeserializedNtilde,\n  c: bigint,\n  m: bigint,\n  r: bigint\n): Promise<RangeProof> {\n  const modulusBytes = Math.floor((modulusBits + 7) / 8);\n  const q = curve.order();\n  const q3 = q ** BigInt(3);\n  const qntilde = q * ntilde.ntilde;\n  const q3ntilde = q3 * ntilde.ntilde;\n  const alpha = randBetween(q3);\n  const beta = await randomPositiveCoPrimeTo(pk.n);\n  const gamma = randBetween(q3ntilde);\n  const rho = randBetween(qntilde);\n  const z = (modPow(ntilde.h1, m, ntilde.ntilde) * modPow(ntilde.h2, rho, ntilde.ntilde)) % ntilde.ntilde;\n  const u = (modPow(pk.g, alpha, pk._n2) * modPow(beta, pk.n, pk._n2)) % pk._n2;\n  const w = (modPow(ntilde.h1, alpha, ntilde.ntilde) * modPow(ntilde.h2, gamma, ntilde.ntilde)) % ntilde.ntilde;\n  const hash = createHash('sha256');\n  hash.update('\\x06\\x00\\x00\\x00\\x00\\x00\\x00\\x00');\n  hash.update(bigIntToBufferBE(pk.n, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(pk.g, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(c, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(z, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(u, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(w, modulusBytes));\n  hash.update('$');\n  const e = bigIntFromBufferBE(hash.digest()) % q;\n  const s = (modPow(r, e, pk.n) * beta) % pk.n;\n  const s1 = e * m + alpha;\n  const s2 = e * rho + gamma;\n  return { z, u, w, s, s1, s2 };\n}\n\n/**\n * Verify a zero-knowledge range proof that an encrypted value is \"small\".\n * @param {BaseCurve} curve An elliptic curve to use for group operations.\n * @param {number} modulusBits The bit count of the prover's public key.\n * @param {PublicKey} pk The prover's public key.\n * @param {DeserializedNtilde} ntilde The verifier's Ntilde values.\n * @param {RangeProof} proof The range proof.\n * @param {bigint} c The ciphertext.\n * @returns {boolean} True if verification succeeds.\n */\nexport function verify(\n  curve: BaseCurve,\n  modulusBits: number,\n  pk: PublicKey,\n  ntilde: DeserializedNtilde,\n  proof: RangeProof,\n  c: bigint\n): boolean {\n  if (proof.u === BigInt(0) || proof.s === BigInt(0)) {\n    return false;\n  }\n  const modulusBytes = Math.floor((modulusBits + 7) / 8);\n  const q = curve.order();\n  const q3 = q ** BigInt(3);\n  if (proof.s1 > q3) {\n    return false;\n  }\n  const hash = createHash('sha256');\n  hash.update('\\x06\\x00\\x00\\x00\\x00\\x00\\x00\\x00');\n  hash.update(bigIntToBufferBE(pk.n, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(pk.g, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(c, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.z, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.u, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.w, modulusBytes));\n  hash.update('$');\n  const e = bigIntFromBufferBE(hash.digest()) % q;\n  let products: bigint;\n  products = (modPow(pk.g, proof.s1, pk._n2) * modPow(proof.s, pk.n, pk._n2) * modPow(c, -e, pk._n2)) % pk._n2;\n  if (proof.u !== products) {\n    return false;\n  }\n  products =\n    (((modPow(ntilde.h1, proof.s1, ntilde.ntilde) * modPow(ntilde.h2, proof.s2, ntilde.ntilde)) % ntilde.ntilde) *\n      modPow(proof.z, -e, ntilde.ntilde)) %\n    ntilde.ntilde;\n  return proof.w === products;\n}\n\n/**\n * Generate a zero-knowledge range proof that a homomorphically manipulated value is \"small\".\n * @param {BaseCurve} curve An elliptic curve to use for group operations.\n * @param {number} modulusBits The bit count of the prover's public key.\n * @param {PublicKey} pk The prover's public key.\n * @param {DeserializedNtilde} ntilde The verifier's Ntilde values.\n * @param {bigint} c1 The original ciphertext.\n * @param {bigint} c2 The manipulated ciphertext.\n * @param {bigint} x The plaintext value multiplied by the original plaintext.\n * @param {bigint} y The plaintext value that is added to x.\n * @param {bigint} r The obfuscation value used to encrypt x.\n * @param {bigint} X The curve's base point raised to x.\n * @returns {RangeProofWithCheck} The generated proof.\n */\nexport async function proveWithCheck(\n  curve: BaseCurve,\n  modulusBits: number,\n  pk: PublicKey,\n  ntilde: DeserializedNtilde,\n  c1: bigint,\n  c2: bigint,\n  x: bigint,\n  y: bigint,\n  r: bigint,\n  X: bigint\n): Promise<RangeProofWithCheck> {\n  const modulusBytes = Math.floor((modulusBits + 7) / 8);\n  const q = curve.order();\n  const q3 = q ** BigInt(3);\n  const q7 = q ** BigInt(7);\n  const qntilde = q * ntilde.ntilde;\n  const q3ntilde = q3 * ntilde.ntilde;\n  const alpha = randBetween(q3);\n  const rho = randBetween(qntilde);\n  const sigma = randBetween(qntilde);\n  const tau = randBetween(q3ntilde);\n  const rhoprm = randBetween(q3ntilde);\n  const beta = await randomPositiveCoPrimeTo(pk.n);\n  const gamma = randBetween(q7);\n  const u = curve.basePointMult(curve.scalarReduce(alpha));\n  const z = (modPow(ntilde.h1, x, ntilde.ntilde) * modPow(ntilde.h2, rho, ntilde.ntilde)) % ntilde.ntilde;\n  const zprm = (modPow(ntilde.h1, alpha, ntilde.ntilde) * modPow(ntilde.h2, rhoprm, ntilde.ntilde)) % ntilde.ntilde;\n  const t = (modPow(ntilde.h1, y, ntilde.ntilde) * modPow(ntilde.h2, sigma, ntilde.ntilde)) % ntilde.ntilde;\n  const v =\n    (((modPow(c1, alpha, pk._n2) * modPow(pk.g, gamma, pk._n2)) % pk._n2) * modPow(beta, pk.n, pk._n2)) % pk._n2;\n  const w = (modPow(ntilde.h1, gamma, ntilde.ntilde) * modPow(ntilde.h2, tau, ntilde.ntilde)) % ntilde.ntilde;\n  const hash = createHash('sha256');\n  hash.update('\\x0d\\x00\\x00\\x00\\x00\\x00\\x00\\x00');\n  hash.update(bigIntToBufferBE(pk.n, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(pk.g, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(X, 33));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(c1, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(c2, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(u, 33));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(z, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(zprm, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(t, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(v, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(w, modulusBytes));\n  hash.update('$');\n  const e = bigIntFromBufferBE(hash.digest()) % q;\n  const s = (modPow(r, e, pk.n) * beta) % pk.n;\n  const s1 = e * x + alpha;\n  const s2 = e * rho + rhoprm;\n  const t1 = e * y + gamma;\n  const t2 = e * sigma + tau;\n  return { z, zprm, t, v, w, s, s1, s2, t1, t2, u };\n}\n\n/**\n * Verify a zero-knowledge range proof that a homomorphically manipulated value is \"small\".\n * @param {BaseCurve} curve An elliptic curve to use for group operations.\n * @param {number} modulusBits The bit count of the prover's public key.\n * @param {PublicKey} pk The prover's public key.\n * @param {DeserializedNtilde} ntilde The verifier's Ntilde values.\n * @param {RangeProofWithCheck} proof The range proof.\n * @param {bigint} c1 The original ciphertext.\n * @param {bigint} c2 The manipulated ciphertext.\n * @param {bigint} X The curve's base point raised to x.\n * @returns {boolean} True if verification succeeds.\n */\nexport function verifyWithCheck(\n  curve: BaseCurve,\n  modulusBits: number,\n  pk: PublicKey,\n  ntilde: DeserializedNtilde,\n  proof: RangeProofWithCheck,\n  c1: bigint,\n  c2: bigint,\n  X: bigint\n): boolean {\n  const modulusBytes = Math.floor((modulusBits + 7) / 8);\n  const q = curve.order();\n  const q3 = q ** BigInt(3);\n  const q7 = q ** BigInt(7);\n  if (proof.s1 > q3) {\n    return false;\n  }\n  if (proof.t1 > q7) {\n    return false;\n  }\n  const hash = createHash('sha256');\n  hash.update('\\x0d\\x00\\x00\\x00\\x00\\x00\\x00\\x00');\n  hash.update(bigIntToBufferBE(pk.n, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(pk.g, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(X, 33));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(c1, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(c2, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.u, 33));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.z, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.zprm, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.t, modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.v, 2 * modulusBytes));\n  hash.update('$');\n  hash.update(bigIntToBufferBE(proof.w, modulusBytes));\n  hash.update('$');\n  const e = bigIntFromBufferBE(hash.digest()) % q;\n  const gS1 = curve.basePointMult(curve.scalarReduce(proof.s1));\n  const xEU = curve.pointAdd(curve.pointMultiply(X, e), proof.u);\n  if (gS1 !== xEU) {\n    return false;\n  }\n  let left, right;\n  const h1ExpS1 = modPow(ntilde.h1, proof.s1, ntilde.ntilde);\n  const h2ExpS2 = modPow(ntilde.h2, proof.s2, ntilde.ntilde);\n  left = (h1ExpS1 * h2ExpS2) % ntilde.ntilde;\n  const zExpE = modPow(proof.z, e, ntilde.ntilde);\n  right = (zExpE * proof.zprm) % ntilde.ntilde;\n  if (left !== right) {\n    return false;\n  }\n  const h1ExpT1 = modPow(ntilde.h1, proof.t1, ntilde.ntilde);\n  const h2ExpT2 = modPow(ntilde.h2, proof.t2, ntilde.ntilde);\n  left = (h1ExpT1 * h2ExpT2) % ntilde.ntilde;\n  const tExpE = modPow(proof.t, e, ntilde.ntilde);\n  right = (tExpE * proof.w) % ntilde.ntilde;\n  if (left !== right) {\n    return false;\n  }\n  const c1ExpS1 = modPow(c1, proof.s1, pk._n2);\n  const sExpN = modPow(proof.s, pk.n, pk._n2);\n  const gammaExpT1 = modPow(pk.g, proof.t1, pk._n2);\n  left = (((c1ExpS1 * sExpN) % pk._n2) * gammaExpT1) % pk._n2;\n  const c2ExpE = modPow(c2, e, pk._n2);\n  right = (c2ExpE * proof.v) % pk._n2;\n  return left === right;\n}\n"]}