@noble/curves 0.8.2 → 0.9.0
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/README.md +232 -176
- package/_shortw_utils.d.ts +3 -2
- package/_shortw_utils.d.ts.map +1 -1
- package/abstract/bls.d.ts +15 -15
- package/abstract/bls.d.ts.map +1 -1
- package/abstract/bls.js.map +1 -1
- package/abstract/curve.d.ts +9 -7
- package/abstract/curve.d.ts.map +1 -1
- package/abstract/curve.js +5 -1
- package/abstract/curve.js.map +1 -1
- package/abstract/edwards.d.ts +4 -3
- package/abstract/edwards.d.ts.map +1 -1
- package/abstract/hash-to-curve.d.ts +6 -6
- package/abstract/hash-to-curve.d.ts.map +1 -1
- package/abstract/hash-to-curve.js.map +1 -1
- package/abstract/modular.d.ts +24 -12
- package/abstract/modular.d.ts.map +1 -1
- package/abstract/modular.js +16 -3
- package/abstract/modular.js.map +1 -1
- package/abstract/montgomery.d.ts +3 -3
- package/abstract/montgomery.d.ts.map +1 -1
- package/abstract/poseidon.d.ts +4 -4
- package/abstract/poseidon.d.ts.map +1 -1
- package/abstract/poseidon.js.map +1 -1
- package/abstract/utils.d.ts +7 -7
- package/abstract/utils.d.ts.map +1 -1
- package/abstract/weierstrass.d.ts +40 -18
- package/abstract/weierstrass.d.ts.map +1 -1
- package/abstract/weierstrass.js +20 -6
- package/abstract/weierstrass.js.map +1 -1
- package/bls12-381.d.ts +14 -14
- package/bls12-381.d.ts.map +1 -1
- package/bls12-381.js +2 -2
- package/bls12-381.js.map +1 -1
- package/bn.js +1 -1
- package/bn.js.map +1 -1
- package/ed25519.d.ts +1 -1
- package/ed25519.d.ts.map +1 -1
- package/ed25519.js +2 -2
- package/ed25519.js.map +1 -1
- package/ed448.js +1 -1
- package/ed448.js.map +1 -1
- package/esm/abstract/bls.js.map +1 -1
- package/esm/abstract/curve.js +5 -1
- package/esm/abstract/curve.js.map +1 -1
- package/esm/abstract/hash-to-curve.js.map +1 -1
- package/esm/abstract/modular.js +14 -1
- package/esm/abstract/modular.js.map +1 -1
- package/esm/abstract/poseidon.js.map +1 -1
- package/esm/abstract/weierstrass.js +20 -6
- package/esm/abstract/weierstrass.js.map +1 -1
- package/esm/bls12-381.js +2 -2
- package/esm/bls12-381.js.map +1 -1
- package/esm/bn.js +2 -2
- package/esm/bn.js.map +1 -1
- package/esm/ed25519.js +3 -2
- package/esm/ed25519.js.map +1 -1
- package/esm/ed448.js +1 -1
- package/esm/ed448.js.map +1 -1
- package/esm/jubjub.js +2 -2
- package/esm/jubjub.js.map +1 -1
- package/esm/p256.js +1 -1
- package/esm/p256.js.map +1 -1
- package/esm/p384.js +1 -1
- package/esm/p384.js.map +1 -1
- package/esm/p521.js +1 -1
- package/esm/p521.js.map +1 -1
- package/esm/pasta.js +2 -2
- package/esm/pasta.js.map +1 -1
- package/esm/secp256k1.js +1 -1
- package/esm/secp256k1.js.map +1 -1
- package/jubjub.js +1 -1
- package/jubjub.js.map +1 -1
- package/p256.d.ts +4 -2
- package/p256.d.ts.map +1 -1
- package/p256.js +1 -1
- package/p256.js.map +1 -1
- package/p384.d.ts +4 -2
- package/p384.d.ts.map +1 -1
- package/p384.js +1 -1
- package/p384.js.map +1 -1
- package/p521.d.ts +4 -2
- package/p521.d.ts.map +1 -1
- package/p521.js +1 -1
- package/p521.js.map +1 -1
- package/package.json +9 -9
- package/pasta.js +2 -2
- package/pasta.js.map +1 -1
- package/secp256k1.d.ts +2 -1
- package/secp256k1.d.ts.map +1 -1
- package/secp256k1.js +1 -1
- package/secp256k1.js.map +1 -1
- package/src/abstract/bls.ts +11 -11
- package/src/abstract/curve.ts +7 -3
- package/src/abstract/hash-to-curve.ts +2 -2
- package/src/abstract/modular.ts +28 -19
- package/src/abstract/poseidon.ts +2 -2
- package/src/abstract/weierstrass.ts +27 -11
- package/src/bls12-381.ts +5 -5
- package/src/bn.ts +2 -2
- package/src/ed25519.ts +1 -1
- package/src/ed448.ts +1 -1
- package/src/jubjub.ts +2 -2
- package/src/p256.ts +1 -1
- package/src/p384.ts +1 -1
- package/src/p521.ts +1 -1
- package/src/pasta.ts +2 -2
- package/src/secp256k1.ts +2 -3
package/src/pasta.ts
CHANGED
|
@@ -11,7 +11,7 @@ export const q = BigInt('0x40000000000000000000000000000000224698fc0994a8dd8c46e
|
|
|
11
11
|
export const pallas = weierstrass({
|
|
12
12
|
a: BigInt(0),
|
|
13
13
|
b: BigInt(5),
|
|
14
|
-
Fp: mod.
|
|
14
|
+
Fp: mod.Field(p),
|
|
15
15
|
n: q,
|
|
16
16
|
Gx: mod.mod(BigInt(-1), p),
|
|
17
17
|
Gy: BigInt(2),
|
|
@@ -22,7 +22,7 @@ export const pallas = weierstrass({
|
|
|
22
22
|
export const vesta = weierstrass({
|
|
23
23
|
a: BigInt(0),
|
|
24
24
|
b: BigInt(5),
|
|
25
|
-
Fp: mod.
|
|
25
|
+
Fp: mod.Field(q),
|
|
26
26
|
n: p,
|
|
27
27
|
Gx: mod.mod(BigInt(-1), q),
|
|
28
28
|
Gy: BigInt(2),
|
package/src/secp256k1.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */
|
|
2
2
|
import { sha256 } from '@noble/hashes/sha256';
|
|
3
3
|
import { randomBytes } from '@noble/hashes/utils';
|
|
4
|
-
import {
|
|
4
|
+
import { Field, mod, pow2 } from './abstract/modular.js';
|
|
5
5
|
import { ProjPointType as PointType, mapToCurveSimpleSWU } from './abstract/weierstrass.js';
|
|
6
6
|
import type { Hex, PrivKey } from './abstract/utils.js';
|
|
7
7
|
import { bytesToNumberBE, concatBytes, ensureBytes, numberToBytesBE } from './abstract/utils.js';
|
|
@@ -43,7 +43,6 @@ function sqrtMod(y: bigint): bigint {
|
|
|
43
43
|
}
|
|
44
44
|
|
|
45
45
|
const Fp = Field(secp256k1P, undefined, undefined, { sqrt: sqrtMod });
|
|
46
|
-
type Fp = bigint;
|
|
47
46
|
|
|
48
47
|
export const secp256k1 = createCurve(
|
|
49
48
|
{
|
|
@@ -245,7 +244,7 @@ const isoMap = htf.isogenyMap(
|
|
|
245
244
|
'0x6484aa716545ca2cf3a70c3fa8fe337e0a3d21162f0d6299a7bf8192bfd2a76f',
|
|
246
245
|
'0x0000000000000000000000000000000000000000000000000000000000000001', // LAST 1
|
|
247
246
|
],
|
|
248
|
-
].map((i) => i.map((j) => BigInt(j))) as [
|
|
247
|
+
].map((i) => i.map((j) => BigInt(j))) as [bigint[], bigint[], bigint[], bigint[]]
|
|
249
248
|
);
|
|
250
249
|
const mapSWU = mapToCurveSimpleSWU(Fp, {
|
|
251
250
|
A: BigInt('0x3f8731abdd661adca08a5558f0f5d272e953d363cb6f0e5d405447c01a444533'),
|