@noble/curves 0.8.0 → 0.8.2

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 (90) hide show
  1. package/README.md +12 -17
  2. package/_shortw_utils.js +13 -8
  3. package/_shortw_utils.js.map +1 -1
  4. package/abstract/bls.js +16 -12
  5. package/abstract/bls.js.map +1 -1
  6. package/abstract/curve.js +12 -7
  7. package/abstract/curve.js.map +1 -1
  8. package/abstract/edwards.js +20 -16
  9. package/abstract/edwards.js.map +1 -1
  10. package/abstract/hash-to-curve.js +26 -18
  11. package/abstract/hash-to-curve.js.map +1 -1
  12. package/abstract/modular.js +44 -24
  13. package/abstract/modular.js.map +1 -1
  14. package/abstract/montgomery.js +15 -11
  15. package/abstract/montgomery.js.map +1 -1
  16. package/abstract/poseidon.js +12 -6
  17. package/abstract/poseidon.js.map +1 -1
  18. package/abstract/utils.js +41 -19
  19. package/abstract/utils.js.map +1 -1
  20. package/abstract/weierstrass.js +28 -21
  21. package/abstract/weierstrass.js.map +1 -1
  22. package/bls12-381.js +66 -63
  23. package/bls12-381.js.map +1 -1
  24. package/bn.js +10 -7
  25. package/bn.js.map +1 -1
  26. package/ed25519.js +78 -72
  27. package/ed25519.js.map +1 -1
  28. package/ed448.js +41 -37
  29. package/ed448.js.map +1 -1
  30. package/esm/_shortw_utils.js +17 -0
  31. package/esm/_shortw_utils.js.map +1 -0
  32. package/esm/abstract/bls.js +226 -0
  33. package/esm/abstract/bls.js.map +1 -0
  34. package/esm/abstract/curve.js +152 -0
  35. package/esm/abstract/curve.js.map +1 -0
  36. package/esm/abstract/edwards.js +409 -0
  37. package/esm/abstract/edwards.js.map +1 -0
  38. package/esm/abstract/hash-to-curve.js +166 -0
  39. package/esm/abstract/hash-to-curve.js.map +1 -0
  40. package/esm/abstract/modular.js +346 -0
  41. package/esm/abstract/modular.js.map +1 -0
  42. package/esm/abstract/montgomery.js +157 -0
  43. package/esm/abstract/montgomery.js.map +1 -0
  44. package/esm/abstract/poseidon.js +110 -0
  45. package/esm/abstract/poseidon.js.map +1 -0
  46. package/esm/abstract/utils.js +222 -0
  47. package/esm/abstract/utils.js.map +1 -0
  48. package/esm/abstract/weierstrass.js +1011 -0
  49. package/esm/abstract/weierstrass.js.map +1 -0
  50. package/esm/bls12-381.js +1173 -0
  51. package/esm/bls12-381.js.map +1 -0
  52. package/esm/bn.js +22 -0
  53. package/esm/bn.js.map +1 -0
  54. package/esm/ed25519.js +397 -0
  55. package/esm/ed25519.js.map +1 -0
  56. package/esm/ed448.js +213 -0
  57. package/esm/ed448.js.map +1 -0
  58. package/esm/index.js +3 -0
  59. package/esm/index.js.map +1 -0
  60. package/esm/jubjub.js +54 -0
  61. package/esm/jubjub.js.map +1 -0
  62. package/esm/p256.js +42 -0
  63. package/esm/p256.js.map +1 -0
  64. package/esm/p384.js +47 -0
  65. package/esm/p384.js.map +1 -0
  66. package/esm/p521.js +48 -0
  67. package/esm/p521.js.map +1 -0
  68. package/esm/package.json +7 -0
  69. package/esm/pasta.js +30 -0
  70. package/esm/pasta.js.map +1 -0
  71. package/esm/secp256k1.js +252 -0
  72. package/esm/secp256k1.js.map +1 -0
  73. package/jubjub.js +22 -17
  74. package/jubjub.js.map +1 -1
  75. package/p256.js +17 -13
  76. package/p256.js.map +1 -1
  77. package/p384.js +17 -13
  78. package/p384.js.map +1 -1
  79. package/p521.js +17 -13
  80. package/p521.js.map +1 -1
  81. package/package.json +27 -9
  82. package/pasta.js +19 -16
  83. package/pasta.js.map +1 -1
  84. package/secp256k1.js +57 -53
  85. package/secp256k1.js.map +1 -1
  86. package/src/stark.ts +0 -341
  87. package/stark.d.ts +0 -81
  88. package/stark.d.ts.map +0 -1
  89. package/stark.js +0 -277
  90. package/stark.js.map +0 -1
package/stark.js DELETED
@@ -1,277 +0,0 @@
1
- /*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */
2
- import { keccak_256 } from '@noble/hashes/sha3';
3
- import { sha256 } from '@noble/hashes/sha256';
4
- import { utf8ToBytes } from '@noble/hashes/utils';
5
- import { Fp, mod, validateField } from './abstract/modular.js';
6
- import { poseidon } from './abstract/poseidon.js';
7
- import { weierstrass } from './abstract/weierstrass.js';
8
- import * as u from './abstract/utils.js';
9
- import { getHash } from './_shortw_utils.js';
10
- const CURVE_ORDER = BigInt('3618502788666131213697322783095070105526743751716087489154079457884512865583');
11
- const nBitLength = 252;
12
- function bits2int(bytes) {
13
- while (bytes[0] === 0)
14
- bytes = bytes.subarray(1); // strip leading 0s
15
- // Copy-pasted from weierstrass.ts
16
- const delta = bytes.length * 8 - nBitLength;
17
- const num = u.bytesToNumberBE(bytes);
18
- return delta > 0 ? num >> BigInt(delta) : num;
19
- }
20
- function hex0xToBytes(hex) {
21
- if (typeof hex === 'string') {
22
- hex = strip0x(hex); // allow 0x prefix
23
- if (hex.length & 1)
24
- hex = '0' + hex; // allow unpadded hex
25
- }
26
- return u.hexToBytes(hex);
27
- }
28
- const curve = weierstrass({
29
- a: BigInt(1),
30
- b: BigInt('3141592653589793238462643383279502884197169399375105820974944592307816406665'),
31
- // Field over which we'll do calculations; 2n**251n + 17n * 2n**192n + 1n
32
- // There is no efficient sqrt for field (P%4==1)
33
- Fp: Fp(BigInt('0x800000000000011000000000000000000000000000000000000000000000001')),
34
- n: CURVE_ORDER,
35
- nBitLength,
36
- // Base point (x, y) aka generator point
37
- Gx: BigInt('874739451078007766457464989774322083649278607533249481151382481072868806602'),
38
- Gy: BigInt('152666792071518830868575557812948353041420400780739481342941381225525861407'),
39
- h: BigInt(1),
40
- lowS: false,
41
- ...getHash(sha256),
42
- // Custom truncation routines for stark curve
43
- bits2int,
44
- bits2int_modN: (bytes) => {
45
- // 2102820b232636d200cb21f1d330f20d096cae09d1bf3edb1cc333ddee11318 =>
46
- // 2102820b232636d200cb21f1d330f20d096cae09d1bf3edb1cc333ddee113180
47
- const hex = u.bytesToNumberBE(bytes).toString(16); // toHex unpadded
48
- if (hex.length === 63)
49
- bytes = hex0xToBytes(hex + '0'); // append trailing 0
50
- return mod(bits2int(bytes), CURVE_ORDER);
51
- },
52
- });
53
- export const _starkCurve = curve;
54
- function ensureBytes(hex) {
55
- return u.ensureBytes('', typeof hex === 'string' ? hex0xToBytes(hex) : hex);
56
- }
57
- function normPrivKey(privKey) {
58
- return u.bytesToHex(ensureBytes(privKey)).padStart(64, '0');
59
- }
60
- export function getPublicKey(privKey, isCompressed = false) {
61
- return curve.getPublicKey(normPrivKey(privKey), isCompressed);
62
- }
63
- export function getSharedSecret(privKeyA, pubKeyB) {
64
- return curve.getSharedSecret(normPrivKey(privKeyA), pubKeyB);
65
- }
66
- export function sign(msgHash, privKey, opts) {
67
- return curve.sign(ensureBytes(msgHash), normPrivKey(privKey), opts);
68
- }
69
- export function verify(signature, msgHash, pubKey) {
70
- const sig = signature instanceof Signature ? signature : ensureBytes(signature);
71
- return curve.verify(sig, ensureBytes(msgHash), ensureBytes(pubKey));
72
- }
73
- const { CURVE, ProjectivePoint, Signature, utils } = curve;
74
- export { CURVE, ProjectivePoint, Signature, utils };
75
- function extractX(bytes) {
76
- const hex = u.bytesToHex(bytes.subarray(1));
77
- const stripped = hex.replace(/^0+/gm, ''); // strip leading 0s
78
- return `0x${stripped}`;
79
- }
80
- function strip0x(hex) {
81
- return hex.replace(/^0x/i, '');
82
- }
83
- function numberTo0x16(num) {
84
- // can't use utils.numberToHexUnpadded: adds leading 0 for even byte length
85
- return `0x${num.toString(16)}`;
86
- }
87
- // seed generation
88
- export function grindKey(seed) {
89
- const _seed = ensureBytes(seed);
90
- const sha256mask = 2n ** 256n;
91
- const limit = sha256mask - mod(sha256mask, CURVE_ORDER);
92
- for (let i = 0;; i++) {
93
- const key = sha256Num(u.concatBytes(_seed, u.numberToVarBytesBE(BigInt(i))));
94
- if (key < limit)
95
- return mod(key, CURVE_ORDER).toString(16); // key should be in [0, limit)
96
- if (i === 100000)
97
- throw new Error('grindKey is broken: tried 100k vals'); // prevent dos
98
- }
99
- }
100
- export function getStarkKey(privateKey) {
101
- return extractX(getPublicKey(privateKey, true));
102
- }
103
- export function ethSigToPrivate(signature) {
104
- signature = strip0x(signature);
105
- if (signature.length !== 130)
106
- throw new Error('Wrong ethereum signature');
107
- return grindKey(signature.substring(0, 64));
108
- }
109
- const MASK_31 = 2n ** 31n - 1n;
110
- const int31 = (n) => Number(n & MASK_31);
111
- export function getAccountPath(layer, application, ethereumAddress, index) {
112
- const layerNum = int31(sha256Num(layer));
113
- const applicationNum = int31(sha256Num(application));
114
- const eth = u.hexToNumber(strip0x(ethereumAddress));
115
- return `m/2645'/${layerNum}'/${applicationNum}'/${int31(eth)}'/${int31(eth >> 31n)}'/${index}`;
116
- }
117
- // https://docs.starkware.co/starkex/pedersen-hash-function.html
118
- const PEDERSEN_POINTS = [
119
- new ProjectivePoint(2089986280348253421170679821480865132823066470938446095505822317253594081284n, 1713931329540660377023406109199410414810705867260802078187082345529207694986n, 1n),
120
- new ProjectivePoint(996781205833008774514500082376783249102396023663454813447423147977397232763n, 1668503676786377725805489344771023921079126552019160156920634619255970485781n, 1n),
121
- new ProjectivePoint(2251563274489750535117886426533222435294046428347329203627021249169616184184n, 1798716007562728905295480679789526322175868328062420237419143593021674992973n, 1n),
122
- new ProjectivePoint(2138414695194151160943305727036575959195309218611738193261179310511854807447n, 113410276730064486255102093846540133784865286929052426931474106396135072156n, 1n),
123
- new ProjectivePoint(2379962749567351885752724891227938183011949129833673362440656643086021394946n, 776496453633298175483985398648758586525933812536653089401905292063708816422n, 1n),
124
- ];
125
- function pedersenPrecompute(p1, p2) {
126
- const out = [];
127
- let p = p1;
128
- for (let i = 0; i < 248; i++) {
129
- out.push(p);
130
- p = p.double();
131
- }
132
- // NOTE: we cannot use wNAF here, because last 4 bits will require full 248 bits multiplication
133
- // We can add support for this to wNAF, but it will complicate wNAF.
134
- p = p2;
135
- for (let i = 0; i < 4; i++) {
136
- out.push(p);
137
- p = p.double();
138
- }
139
- return out;
140
- }
141
- const PEDERSEN_POINTS1 = pedersenPrecompute(PEDERSEN_POINTS[1], PEDERSEN_POINTS[2]);
142
- const PEDERSEN_POINTS2 = pedersenPrecompute(PEDERSEN_POINTS[3], PEDERSEN_POINTS[4]);
143
- function pedersenArg(arg) {
144
- let value;
145
- if (typeof arg === 'bigint') {
146
- value = arg;
147
- }
148
- else if (typeof arg === 'number') {
149
- if (!Number.isSafeInteger(arg))
150
- throw new Error(`Invalid pedersenArg: ${arg}`);
151
- value = BigInt(arg);
152
- }
153
- else {
154
- value = u.bytesToNumberBE(ensureBytes(arg));
155
- }
156
- if (!(0n <= value && value < curve.CURVE.Fp.ORDER))
157
- throw new Error(`PedersenArg should be 0 <= value < CURVE.P: ${value}`); // [0..Fp)
158
- return value;
159
- }
160
- function pedersenSingle(point, value, constants) {
161
- let x = pedersenArg(value);
162
- for (let j = 0; j < 252; j++) {
163
- const pt = constants[j];
164
- if (pt.equals(point))
165
- throw new Error('Same point');
166
- if ((x & 1n) !== 0n)
167
- point = point.add(pt);
168
- x >>= 1n;
169
- }
170
- return point;
171
- }
172
- // shift_point + x_low * P_0 + x_high * P1 + y_low * P2 + y_high * P3
173
- export function pedersen(x, y) {
174
- let point = PEDERSEN_POINTS[0];
175
- point = pedersenSingle(point, x, PEDERSEN_POINTS1);
176
- point = pedersenSingle(point, y, PEDERSEN_POINTS2);
177
- return extractX(point.toRawBytes(true));
178
- }
179
- export function hashChain(data, fn = pedersen) {
180
- if (!Array.isArray(data) || data.length < 1)
181
- throw new Error('data should be array of at least 1 element');
182
- if (data.length === 1)
183
- return numberTo0x16(pedersenArg(data[0]));
184
- return Array.from(data)
185
- .reverse()
186
- .reduce((acc, i) => fn(i, acc));
187
- }
188
- // Same as hashChain, but computes hash even for single element and order is not revesed
189
- export const computeHashOnElements = (data, fn = pedersen) => [0, ...data, data.length].reduce((x, y) => fn(x, y));
190
- const MASK_250 = u.bitMask(250);
191
- export const keccak = (data) => u.bytesToNumberBE(keccak_256(data)) & MASK_250;
192
- const sha256Num = (data) => u.bytesToNumberBE(sha256(data));
193
- // Poseidon hash
194
- export const Fp253 = Fp(BigInt('14474011154664525231415395255581126252639794253786371766033694892385558855681')); // 2^253 + 2^199 + 1
195
- export const Fp251 = Fp(BigInt('3618502788666131213697322783095070105623107215331596699973092056135872020481')); // 2^251 + 17 * 2^192 + 1
196
- function poseidonRoundConstant(Fp, name, idx) {
197
- const val = Fp.fromBytes(sha256(utf8ToBytes(`${name}${idx}`)));
198
- return Fp.create(val);
199
- }
200
- // NOTE: doesn't check eiginvalues and possible can create unsafe matrix. But any filtration here will break compatibility with starknet
201
- // Please use only if you really know what you doing.
202
- // https://eprint.iacr.org/2019/458.pdf Section 2.3 (Avoiding Insecure Matrices)
203
- export function _poseidonMDS(Fp, name, m, attempt = 0) {
204
- const x_values = [];
205
- const y_values = [];
206
- for (let i = 0; i < m; i++) {
207
- x_values.push(poseidonRoundConstant(Fp, `${name}x`, attempt * m + i));
208
- y_values.push(poseidonRoundConstant(Fp, `${name}y`, attempt * m + i));
209
- }
210
- if (new Set([...x_values, ...y_values]).size !== 2 * m)
211
- throw new Error('X and Y values are not distinct');
212
- return x_values.map((x) => y_values.map((y) => Fp.inv(Fp.sub(x, y))));
213
- }
214
- const MDS_SMALL = [
215
- [3, 1, 1],
216
- [1, -1, 1],
217
- [1, 1, -2],
218
- ].map((i) => i.map(BigInt));
219
- export function poseidonBasic(opts, mds) {
220
- validateField(opts.Fp);
221
- if (!Number.isSafeInteger(opts.rate) || !Number.isSafeInteger(opts.capacity))
222
- throw new Error(`Wrong poseidon opts: ${opts}`);
223
- const m = opts.rate + opts.capacity;
224
- const rounds = opts.roundsFull + opts.roundsPartial;
225
- const roundConstants = [];
226
- for (let i = 0; i < rounds; i++) {
227
- const row = [];
228
- for (let j = 0; j < m; j++)
229
- row.push(poseidonRoundConstant(opts.Fp, 'Hades', m * i + j));
230
- roundConstants.push(row);
231
- }
232
- const res = poseidon({
233
- ...opts,
234
- t: m,
235
- sboxPower: 3,
236
- reversePartialPowIdx: true,
237
- mds,
238
- roundConstants,
239
- });
240
- res.m = m;
241
- res.rate = opts.rate;
242
- res.capacity = opts.capacity;
243
- return res;
244
- }
245
- export function poseidonCreate(opts, mdsAttempt = 0) {
246
- const m = opts.rate + opts.capacity;
247
- if (!Number.isSafeInteger(mdsAttempt))
248
- throw new Error(`Wrong mdsAttempt=${mdsAttempt}`);
249
- return poseidonBasic(opts, _poseidonMDS(opts.Fp, 'HadesMDS', m, mdsAttempt));
250
- }
251
- export const poseidonSmall = poseidonBasic({ Fp: Fp251, rate: 2, capacity: 1, roundsFull: 8, roundsPartial: 83 }, MDS_SMALL);
252
- export function poseidonHash(x, y, fn = poseidonSmall) {
253
- return fn([x, y, 2n])[0];
254
- }
255
- export function poseidonHashFunc(x, y, fn = poseidonSmall) {
256
- return u.numberToVarBytesBE(poseidonHash(u.bytesToNumberBE(x), u.bytesToNumberBE(y), fn));
257
- }
258
- export function poseidonHashSingle(x, fn = poseidonSmall) {
259
- return fn([x, 0n, 1n])[0];
260
- }
261
- export function poseidonHashMany(values, fn = poseidonSmall) {
262
- const { m, rate } = fn;
263
- if (!Array.isArray(values))
264
- throw new Error('bigint array expected in values');
265
- const padded = Array.from(values); // copy
266
- padded.push(1n);
267
- while (padded.length % rate !== 0)
268
- padded.push(0n);
269
- let state = new Array(m).fill(0n);
270
- for (let i = 0; i < padded.length; i += rate) {
271
- for (let j = 0; j < rate; j++)
272
- state[j] += padded[i + j];
273
- state = fn(state);
274
- }
275
- return state[0];
276
- }
277
- //# sourceMappingURL=stark.js.map
package/stark.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"stark.js","sourceRoot":"","sources":["src/stark.ts"],"names":[],"mappings":"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"}