@noble/curves 1.9.7 → 2.0.0-beta.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.
- package/README.md +520 -505
- package/abstract/bls.d.ts +58 -120
- package/abstract/bls.d.ts.map +1 -1
- package/abstract/bls.js +108 -152
- package/abstract/bls.js.map +1 -1
- package/abstract/curve.d.ts +18 -54
- package/abstract/curve.d.ts.map +1 -1
- package/abstract/curve.js +30 -49
- package/abstract/curve.js.map +1 -1
- package/abstract/edwards.d.ts +18 -77
- package/abstract/edwards.d.ts.map +1 -1
- package/abstract/edwards.js +68 -144
- package/abstract/edwards.js.map +1 -1
- package/abstract/fft.js +14 -27
- package/abstract/fft.js.map +1 -1
- package/abstract/hash-to-curve.d.ts +35 -47
- package/abstract/hash-to-curve.d.ts.map +1 -1
- package/abstract/hash-to-curve.js +42 -46
- package/abstract/hash-to-curve.js.map +1 -1
- package/abstract/modular.d.ts +5 -17
- package/abstract/modular.d.ts.map +1 -1
- package/abstract/modular.js +170 -169
- package/abstract/modular.js.map +1 -1
- package/abstract/montgomery.d.ts +7 -12
- package/abstract/montgomery.d.ts.map +1 -1
- package/abstract/montgomery.js +22 -29
- package/abstract/montgomery.js.map +1 -1
- package/abstract/oprf.d.ts +282 -0
- package/abstract/oprf.d.ts.map +1 -0
- package/abstract/oprf.js +297 -0
- package/abstract/oprf.js.map +1 -0
- package/abstract/poseidon.d.ts.map +1 -1
- package/abstract/poseidon.js +26 -31
- package/abstract/poseidon.js.map +1 -1
- package/abstract/tower.d.ts.map +1 -1
- package/abstract/tower.js +43 -19
- package/abstract/tower.js.map +1 -1
- package/abstract/weierstrass.d.ts +77 -168
- package/abstract/weierstrass.d.ts.map +1 -1
- package/abstract/weierstrass.js +184 -389
- package/abstract/weierstrass.js.map +1 -1
- package/bls12-381.d.ts +5 -11
- package/bls12-381.d.ts.map +1 -1
- package/bls12-381.js +161 -181
- package/bls12-381.js.map +1 -1
- package/bn254.d.ts +59 -11
- package/bn254.d.ts.map +1 -1
- package/bn254.js +69 -97
- package/bn254.js.map +1 -1
- package/ed25519.d.ts +33 -48
- package/ed25519.d.ts.map +1 -1
- package/ed25519.js +147 -161
- package/ed25519.js.map +1 -1
- package/ed448.d.ts +27 -36
- package/ed448.d.ts.map +1 -1
- package/ed448.js +143 -164
- package/ed448.js.map +1 -1
- package/index.d.ts +1 -0
- package/index.js +20 -4
- package/index.js.map +1 -1
- package/misc.d.ts +10 -14
- package/misc.d.ts.map +1 -1
- package/misc.js +53 -62
- package/misc.js.map +1 -1
- package/nist.d.ts +31 -16
- package/nist.d.ts.map +1 -1
- package/nist.js +75 -64
- package/nist.js.map +1 -1
- package/package.json +20 -234
- package/secp256k1.d.ts +17 -30
- package/secp256k1.d.ts.map +1 -1
- package/secp256k1.js +59 -73
- package/secp256k1.js.map +1 -1
- package/src/abstract/bls.ts +207 -354
- package/src/abstract/curve.ts +25 -84
- package/src/abstract/edwards.ts +68 -193
- package/src/abstract/hash-to-curve.ts +71 -85
- package/src/abstract/modular.ts +150 -134
- package/src/abstract/montgomery.ts +28 -35
- package/src/abstract/oprf.ts +600 -0
- package/src/abstract/poseidon.ts +6 -8
- package/src/abstract/tower.ts +0 -3
- package/src/abstract/weierstrass.ts +203 -525
- package/src/bls12-381.ts +133 -139
- package/src/bn254.ts +69 -93
- package/src/ed25519.ts +106 -133
- package/src/ed448.ts +111 -138
- package/src/index.ts +19 -3
- package/src/misc.ts +68 -51
- package/src/nist.ts +77 -70
- package/src/secp256k1.ts +46 -81
- package/src/utils.ts +67 -137
- package/src/webcrypto.ts +403 -0
- package/utils.d.ts +31 -38
- package/utils.d.ts.map +1 -1
- package/utils.js +66 -185
- package/utils.js.map +1 -1
- package/webcrypto.d.ts +99 -0
- package/webcrypto.d.ts.map +1 -0
- package/webcrypto.js +256 -0
- package/webcrypto.js.map +1 -0
- package/_shortw_utils.d.ts +0 -19
- package/_shortw_utils.d.ts.map +0 -1
- package/_shortw_utils.js +0 -20
- package/_shortw_utils.js.map +0 -1
- package/abstract/utils.d.ts +0 -78
- package/abstract/utils.d.ts.map +0 -1
- package/abstract/utils.js +0 -73
- package/abstract/utils.js.map +0 -1
- package/esm/_shortw_utils.d.ts +0 -19
- package/esm/_shortw_utils.d.ts.map +0 -1
- package/esm/_shortw_utils.js +0 -16
- package/esm/_shortw_utils.js.map +0 -1
- package/esm/abstract/bls.d.ts +0 -190
- package/esm/abstract/bls.d.ts.map +0 -1
- package/esm/abstract/bls.js +0 -408
- package/esm/abstract/bls.js.map +0 -1
- package/esm/abstract/curve.d.ts +0 -231
- package/esm/abstract/curve.d.ts.map +0 -1
- package/esm/abstract/curve.js +0 -465
- package/esm/abstract/curve.js.map +0 -1
- package/esm/abstract/edwards.d.ts +0 -243
- package/esm/abstract/edwards.d.ts.map +0 -1
- package/esm/abstract/edwards.js +0 -627
- package/esm/abstract/edwards.js.map +0 -1
- package/esm/abstract/fft.d.ts +0 -122
- package/esm/abstract/fft.d.ts.map +0 -1
- package/esm/abstract/fft.js +0 -425
- package/esm/abstract/fft.js.map +0 -1
- package/esm/abstract/hash-to-curve.d.ts +0 -102
- package/esm/abstract/hash-to-curve.d.ts.map +0 -1
- package/esm/abstract/hash-to-curve.js +0 -203
- package/esm/abstract/hash-to-curve.js.map +0 -1
- package/esm/abstract/modular.d.ts +0 -171
- package/esm/abstract/modular.d.ts.map +0 -1
- package/esm/abstract/modular.js +0 -530
- package/esm/abstract/modular.js.map +0 -1
- package/esm/abstract/montgomery.d.ts +0 -30
- package/esm/abstract/montgomery.d.ts.map +0 -1
- package/esm/abstract/montgomery.js +0 -157
- package/esm/abstract/montgomery.js.map +0 -1
- package/esm/abstract/poseidon.d.ts +0 -68
- package/esm/abstract/poseidon.d.ts.map +0 -1
- package/esm/abstract/poseidon.js +0 -296
- package/esm/abstract/poseidon.js.map +0 -1
- package/esm/abstract/tower.d.ts +0 -95
- package/esm/abstract/tower.d.ts.map +0 -1
- package/esm/abstract/tower.js +0 -714
- package/esm/abstract/tower.js.map +0 -1
- package/esm/abstract/utils.d.ts +0 -78
- package/esm/abstract/utils.d.ts.map +0 -1
- package/esm/abstract/utils.js +0 -70
- package/esm/abstract/utils.js.map +0 -1
- package/esm/abstract/weierstrass.d.ts +0 -416
- package/esm/abstract/weierstrass.d.ts.map +0 -1
- package/esm/abstract/weierstrass.js +0 -1413
- package/esm/abstract/weierstrass.js.map +0 -1
- package/esm/bls12-381.d.ts +0 -16
- package/esm/bls12-381.d.ts.map +0 -1
- package/esm/bls12-381.js +0 -705
- package/esm/bls12-381.js.map +0 -1
- package/esm/bn254.d.ts +0 -18
- package/esm/bn254.d.ts.map +0 -1
- package/esm/bn254.js +0 -214
- package/esm/bn254.js.map +0 -1
- package/esm/ed25519.d.ts +0 -106
- package/esm/ed25519.d.ts.map +0 -1
- package/esm/ed25519.js +0 -467
- package/esm/ed25519.js.map +0 -1
- package/esm/ed448.d.ts +0 -100
- package/esm/ed448.d.ts.map +0 -1
- package/esm/ed448.js +0 -459
- package/esm/ed448.js.map +0 -1
- package/esm/index.d.ts +0 -2
- package/esm/index.d.ts.map +0 -1
- package/esm/index.js +0 -17
- package/esm/index.js.map +0 -1
- package/esm/jubjub.d.ts +0 -12
- package/esm/jubjub.d.ts.map +0 -1
- package/esm/jubjub.js +0 -12
- package/esm/jubjub.js.map +0 -1
- package/esm/misc.d.ts +0 -19
- package/esm/misc.d.ts.map +0 -1
- package/esm/misc.js +0 -109
- package/esm/misc.js.map +0 -1
- package/esm/nist.d.ts +0 -21
- package/esm/nist.d.ts.map +0 -1
- package/esm/nist.js +0 -132
- package/esm/nist.js.map +0 -1
- package/esm/p256.d.ts +0 -16
- package/esm/p256.d.ts.map +0 -1
- package/esm/p256.js +0 -16
- package/esm/p256.js.map +0 -1
- package/esm/p384.d.ts +0 -16
- package/esm/p384.d.ts.map +0 -1
- package/esm/p384.js +0 -16
- package/esm/p384.js.map +0 -1
- package/esm/p521.d.ts +0 -16
- package/esm/p521.d.ts.map +0 -1
- package/esm/p521.js +0 -16
- package/esm/p521.js.map +0 -1
- package/esm/package.json +0 -4
- package/esm/pasta.d.ts +0 -10
- package/esm/pasta.d.ts.map +0 -1
- package/esm/pasta.js +0 -10
- package/esm/pasta.js.map +0 -1
- package/esm/secp256k1.d.ts +0 -89
- package/esm/secp256k1.d.ts.map +0 -1
- package/esm/secp256k1.js +0 -294
- package/esm/secp256k1.js.map +0 -1
- package/esm/utils.d.ts +0 -110
- package/esm/utils.d.ts.map +0 -1
- package/esm/utils.js +0 -322
- package/esm/utils.js.map +0 -1
- package/jubjub.d.ts +0 -12
- package/jubjub.d.ts.map +0 -1
- package/jubjub.js +0 -15
- package/jubjub.js.map +0 -1
- package/p256.d.ts +0 -16
- package/p256.d.ts.map +0 -1
- package/p256.js +0 -13
- package/p256.js.map +0 -1
- package/p384.d.ts +0 -16
- package/p384.d.ts.map +0 -1
- package/p384.js +0 -13
- package/p384.js.map +0 -1
- package/p521.d.ts +0 -16
- package/p521.d.ts.map +0 -1
- package/p521.js +0 -13
- package/p521.js.map +0 -1
- package/pasta.d.ts +0 -10
- package/pasta.d.ts.map +0 -1
- package/pasta.js +0 -13
- package/pasta.js.map +0 -1
- package/src/_shortw_utils.ts +0 -21
- package/src/abstract/utils.ts +0 -80
- package/src/jubjub.ts +0 -12
- package/src/p256.ts +0 -15
- package/src/p384.ts +0 -15
- package/src/p521.ts +0 -15
- package/src/package.json +0 -3
- package/src/pasta.ts +0 -9
package/abstract/bls.d.ts
CHANGED
|
@@ -1,42 +1,21 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
* The file implements BLS (Boneh-Lynn-Shacham) signatures.
|
|
4
|
-
* Used in both BLS (Barreto-Lynn-Scott) and BN (Barreto-Naehrig)
|
|
5
|
-
* families of pairing-friendly curves.
|
|
6
|
-
* Consists of two curves: G1 and G2:
|
|
7
|
-
* - G1 is a subgroup of (x, y) E(Fq) over y² = x³ + 4.
|
|
8
|
-
* - G2 is a subgroup of ((x₁, x₂+i), (y₁, y₂+i)) E(Fq²) over y² = x³ + 4(1 + i) where i is √-1
|
|
9
|
-
* - Gt, created by bilinear (ate) pairing e(G1, G2), consists of p-th roots of unity in
|
|
10
|
-
* Fq^k where k is embedding degree. Only degree 12 is currently supported, 24 is not.
|
|
11
|
-
* Pairing is used to aggregate and verify signatures.
|
|
12
|
-
* There are two modes of operation:
|
|
13
|
-
* - Long signatures: X-byte keys + 2X-byte sigs (G1 keys + G2 sigs).
|
|
14
|
-
* - Short signatures: 2X-byte keys + X-byte sigs (G2 keys + G1 sigs).
|
|
15
|
-
* @module
|
|
16
|
-
**/
|
|
17
|
-
/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */
|
|
18
|
-
import { type CHash, type Hex, type PrivKey } from '../utils.ts';
|
|
19
|
-
import { type H2CHasher, type H2CHashOpts, type H2COpts, type htfBasicOpts, type MapToCurve } from './hash-to-curve.ts';
|
|
1
|
+
import { type CurveLengths } from './curve.ts';
|
|
2
|
+
import { type H2CHasher, type H2CHashOpts, type H2COpts, type MapToCurve } from './hash-to-curve.ts';
|
|
20
3
|
import { type IField } from './modular.ts';
|
|
21
4
|
import type { Fp12, Fp12Bls, Fp2, Fp2Bls, Fp6Bls } from './tower.ts';
|
|
22
|
-
import { type
|
|
5
|
+
import { type WeierstrassPoint, type WeierstrassPointCons } from './weierstrass.ts';
|
|
23
6
|
type Fp = bigint;
|
|
24
|
-
export type
|
|
25
|
-
export type
|
|
7
|
+
export type BlsTwistType = 'multiplicative' | 'divisive';
|
|
8
|
+
export type BlsShortSignatureCoder<Fp> = {
|
|
26
9
|
fromBytes(bytes: Uint8Array): WeierstrassPoint<Fp>;
|
|
27
|
-
fromHex(hex:
|
|
10
|
+
fromHex(hex: string): WeierstrassPoint<Fp>;
|
|
28
11
|
toBytes(point: WeierstrassPoint<Fp>): Uint8Array;
|
|
29
12
|
toHex(point: WeierstrassPoint<Fp>): string;
|
|
30
|
-
/** @deprecated use `toBytes` */
|
|
31
|
-
toRawBytes(point: WeierstrassPoint<Fp>): Uint8Array;
|
|
32
13
|
};
|
|
33
|
-
export type
|
|
14
|
+
export type BlsLongSignatureCoder<Fp> = {
|
|
34
15
|
fromBytes(bytes: Uint8Array): WeierstrassPoint<Fp>;
|
|
35
|
-
fromHex(hex:
|
|
16
|
+
fromHex(hex: string): WeierstrassPoint<Fp>;
|
|
36
17
|
toBytes(point: WeierstrassPoint<Fp>): Uint8Array;
|
|
37
18
|
toHex(point: WeierstrassPoint<Fp>): string;
|
|
38
|
-
/** @deprecated use `toBytes` */
|
|
39
|
-
toRawBytes(point: WeierstrassPoint<Fp>): Uint8Array;
|
|
40
19
|
};
|
|
41
20
|
export type BlsFields = {
|
|
42
21
|
Fp: IField<Fp>;
|
|
@@ -45,13 +24,15 @@ export type BlsFields = {
|
|
|
45
24
|
Fp6: Fp6Bls;
|
|
46
25
|
Fp12: Fp12Bls;
|
|
47
26
|
};
|
|
48
|
-
export type
|
|
27
|
+
export type BlsPostPrecomputePointAddFn = (Rx: Fp2, Ry: Fp2, Rz: Fp2, Qx: Fp2, Qy: Fp2) => {
|
|
49
28
|
Rx: Fp2;
|
|
50
29
|
Ry: Fp2;
|
|
51
30
|
Rz: Fp2;
|
|
52
31
|
};
|
|
53
|
-
export type
|
|
32
|
+
export type BlsPostPrecomputeFn = (Rx: Fp2, Ry: Fp2, Rz: Fp2, Qx: Fp2, Qy: Fp2, pointAdd: BlsPostPrecomputePointAddFn) => void;
|
|
54
33
|
export type BlsPairing = {
|
|
34
|
+
lengths: CurveLengths;
|
|
35
|
+
Fr: IField<bigint>;
|
|
55
36
|
Fp12: Fp12Bls;
|
|
56
37
|
calcPairingPrecomputes: (p: WeierstrassPoint<Fp2>) => Precompute;
|
|
57
38
|
millerLoopBatch: (pairs: [Precompute, Fp, Fp][]) => Fp12;
|
|
@@ -60,35 +41,21 @@ export type BlsPairing = {
|
|
|
60
41
|
g1: WeierstrassPoint<Fp>;
|
|
61
42
|
g2: WeierstrassPoint<Fp2>;
|
|
62
43
|
}[], withFinalExponent?: boolean) => Fp12;
|
|
44
|
+
randomSecretKey: (seed?: Uint8Array) => Uint8Array;
|
|
63
45
|
};
|
|
64
46
|
export type BlsPairingParams = {
|
|
65
47
|
ateLoopSize: bigint;
|
|
66
48
|
xNegative: boolean;
|
|
67
|
-
twistType:
|
|
68
|
-
|
|
49
|
+
twistType: BlsTwistType;
|
|
50
|
+
randomBytes?: (len?: number) => Uint8Array;
|
|
51
|
+
postPrecompute?: BlsPostPrecomputeFn;
|
|
69
52
|
};
|
|
70
|
-
export type
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
G2: CurvePointsType<Fp2> & {
|
|
77
|
-
Signature: SignatureCoder<Fp2>;
|
|
78
|
-
mapToCurve: MapToCurve<Fp2>;
|
|
79
|
-
htfDefaults: H2COpts;
|
|
80
|
-
};
|
|
81
|
-
fields: BlsFields;
|
|
82
|
-
params: {
|
|
83
|
-
ateLoopSize: BlsPairingParams['ateLoopSize'];
|
|
84
|
-
xNegative: BlsPairingParams['xNegative'];
|
|
85
|
-
r: bigint;
|
|
86
|
-
twistType: BlsPairingParams['twistType'];
|
|
87
|
-
};
|
|
88
|
-
htfDefaults: H2COpts;
|
|
89
|
-
hash: CHash;
|
|
90
|
-
randomBytes?: (bytesLength?: number) => Uint8Array;
|
|
91
|
-
postPrecompute?: PostPrecomputeFn;
|
|
53
|
+
export type BlsHasherParams = {
|
|
54
|
+
mapToG1?: MapToCurve<Fp>;
|
|
55
|
+
mapToG2?: MapToCurve<Fp2>;
|
|
56
|
+
hasherOpts: H2COpts;
|
|
57
|
+
hasherOptsG1: H2COpts;
|
|
58
|
+
hasherOptsG2: H2COpts;
|
|
92
59
|
};
|
|
93
60
|
type PrecomputeSingle = [Fp2, Fp2, Fp2][];
|
|
94
61
|
type Precompute = PrecomputeSingle[];
|
|
@@ -97,18 +64,17 @@ type Precompute = PrecomputeSingle[];
|
|
|
97
64
|
* - G1 is a subgroup of (x, y) E(Fq) over y² = x³ + 4.
|
|
98
65
|
* - G2 is a subgroup of ((x₁, x₂+i), (y₁, y₂+i)) E(Fq²) over y² = x³ + 4(1 + i) where i is √-1
|
|
99
66
|
*/
|
|
100
|
-
export interface
|
|
101
|
-
|
|
102
|
-
shortSignatures: BLSSigs<Fp2, bigint>;
|
|
67
|
+
export interface BlsCurvePair {
|
|
68
|
+
lengths: CurveLengths;
|
|
103
69
|
millerLoopBatch: BlsPairing['millerLoopBatch'];
|
|
104
70
|
pairing: BlsPairing['pairing'];
|
|
105
71
|
pairingBatch: BlsPairing['pairingBatch'];
|
|
106
72
|
G1: {
|
|
107
|
-
Point: WeierstrassPointCons<
|
|
108
|
-
}
|
|
73
|
+
Point: WeierstrassPointCons<Fp>;
|
|
74
|
+
};
|
|
109
75
|
G2: {
|
|
110
76
|
Point: WeierstrassPointCons<Fp2>;
|
|
111
|
-
}
|
|
77
|
+
};
|
|
112
78
|
fields: {
|
|
113
79
|
Fp: IField<Fp>;
|
|
114
80
|
Fp2: Fp2Bls;
|
|
@@ -117,74 +83,46 @@ export interface BLSCurvePair {
|
|
|
117
83
|
Fr: IField<bigint>;
|
|
118
84
|
};
|
|
119
85
|
utils: {
|
|
120
|
-
randomSecretKey: () => Uint8Array;
|
|
121
|
-
/** @deprecated use randomSecretKey */
|
|
122
|
-
randomPrivateKey: () => Uint8Array;
|
|
86
|
+
randomSecretKey: (seed?: Uint8Array) => Uint8Array;
|
|
123
87
|
calcPairingPrecomputes: BlsPairing['calcPairingPrecomputes'];
|
|
124
88
|
};
|
|
125
|
-
}
|
|
126
|
-
export type CurveFn = BLSCurvePair & {
|
|
127
|
-
/** @deprecated use `longSignatures.getPublicKey` */
|
|
128
|
-
getPublicKey: (secretKey: PrivKey) => Uint8Array;
|
|
129
|
-
/** @deprecated use `shortSignatures.getPublicKey` */
|
|
130
|
-
getPublicKeyForShortSignatures: (secretKey: PrivKey) => Uint8Array;
|
|
131
|
-
/** @deprecated use `longSignatures.sign` */
|
|
132
|
-
sign: {
|
|
133
|
-
(message: Hex, secretKey: PrivKey, htfOpts?: htfBasicOpts): Uint8Array;
|
|
134
|
-
(message: WeierstrassPoint<Fp2>, secretKey: PrivKey, htfOpts?: htfBasicOpts): WeierstrassPoint<Fp2>;
|
|
135
|
-
};
|
|
136
|
-
/** @deprecated use `shortSignatures.sign` */
|
|
137
|
-
signShortSignature: {
|
|
138
|
-
(message: Hex, secretKey: PrivKey, htfOpts?: htfBasicOpts): Uint8Array;
|
|
139
|
-
(message: WeierstrassPoint<Fp>, secretKey: PrivKey, htfOpts?: htfBasicOpts): WeierstrassPoint<Fp>;
|
|
140
|
-
};
|
|
141
|
-
/** @deprecated use `longSignatures.verify` */
|
|
142
|
-
verify: (signature: Hex | WeierstrassPoint<Fp2>, message: Hex | WeierstrassPoint<Fp2>, publicKey: Hex | WeierstrassPoint<Fp>, htfOpts?: htfBasicOpts) => boolean;
|
|
143
|
-
/** @deprecated use `shortSignatures.verify` */
|
|
144
|
-
verifyShortSignature: (signature: Hex | WeierstrassPoint<Fp>, message: Hex | WeierstrassPoint<Fp>, publicKey: Hex | WeierstrassPoint<Fp2>, htfOpts?: htfBasicOpts) => boolean;
|
|
145
|
-
verifyBatch: (signature: Hex | WeierstrassPoint<Fp2>, messages: (Hex | WeierstrassPoint<Fp2>)[], publicKeys: (Hex | WeierstrassPoint<Fp>)[], htfOpts?: htfBasicOpts) => boolean;
|
|
146
|
-
/** @deprecated use `longSignatures.aggregatePublicKeys` */
|
|
147
|
-
aggregatePublicKeys: {
|
|
148
|
-
(publicKeys: Hex[]): Uint8Array;
|
|
149
|
-
(publicKeys: WeierstrassPoint<Fp>[]): WeierstrassPoint<Fp>;
|
|
150
|
-
};
|
|
151
|
-
/** @deprecated use `longSignatures.aggregateSignatures` */
|
|
152
|
-
aggregateSignatures: {
|
|
153
|
-
(signatures: Hex[]): Uint8Array;
|
|
154
|
-
(signatures: WeierstrassPoint<Fp2>[]): WeierstrassPoint<Fp2>;
|
|
155
|
-
};
|
|
156
|
-
/** @deprecated use `shortSignatures.aggregateSignatures` */
|
|
157
|
-
aggregateShortSignatures: {
|
|
158
|
-
(signatures: Hex[]): Uint8Array;
|
|
159
|
-
(signatures: WeierstrassPoint<Fp>[]): WeierstrassPoint<Fp>;
|
|
160
|
-
};
|
|
161
|
-
G1: CurvePointsRes<Fp> & H2CHasher<Fp>;
|
|
162
|
-
G2: CurvePointsRes<Fp2> & H2CHasher<Fp2>;
|
|
163
|
-
/** @deprecated use `longSignatures.Signature` */
|
|
164
|
-
Signature: SignatureCoder<Fp2>;
|
|
165
|
-
/** @deprecated use `shortSignatures.Signature` */
|
|
166
|
-
ShortSignature: ShortSignatureCoder<Fp>;
|
|
167
89
|
params: {
|
|
168
90
|
ateLoopSize: bigint;
|
|
169
|
-
|
|
170
|
-
twistType: TwistType;
|
|
171
|
-
/** @deprecated */
|
|
172
|
-
G1b: bigint;
|
|
173
|
-
/** @deprecated */
|
|
174
|
-
G2b: Fp2;
|
|
91
|
+
twistType: BlsTwistType;
|
|
175
92
|
};
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
93
|
+
}
|
|
94
|
+
export interface BlsCurvePairWithHashers extends BlsCurvePair {
|
|
95
|
+
G1: H2CHasher<WeierstrassPointCons<Fp>>;
|
|
96
|
+
G2: H2CHasher<WeierstrassPointCons<Fp2>>;
|
|
97
|
+
}
|
|
98
|
+
export interface BlsCurvePairWithSignatures extends BlsCurvePairWithHashers {
|
|
99
|
+
longSignatures: BlsSigs<bigint, Fp2>;
|
|
100
|
+
shortSignatures: BlsSigs<Fp2, bigint>;
|
|
101
|
+
}
|
|
102
|
+
type BLSInput = Uint8Array;
|
|
103
|
+
export interface BlsSigs<P, S> {
|
|
104
|
+
lengths: CurveLengths;
|
|
105
|
+
keygen(seed?: Uint8Array): {
|
|
106
|
+
secretKey: Uint8Array;
|
|
107
|
+
publicKey: WeierstrassPoint<P>;
|
|
108
|
+
};
|
|
109
|
+
getPublicKey(secretKey: Uint8Array): WeierstrassPoint<P>;
|
|
110
|
+
sign(hashedMessage: WeierstrassPoint<S>, secretKey: Uint8Array): WeierstrassPoint<S>;
|
|
181
111
|
verify(signature: WeierstrassPoint<S> | BLSInput, message: WeierstrassPoint<S>, publicKey: WeierstrassPoint<P> | BLSInput): boolean;
|
|
182
|
-
verifyBatch: (signature: WeierstrassPoint<S> | BLSInput,
|
|
112
|
+
verifyBatch: (signature: WeierstrassPoint<S> | BLSInput, items: {
|
|
113
|
+
message: WeierstrassPoint<S>;
|
|
114
|
+
publicKey: WeierstrassPoint<P> | BLSInput;
|
|
115
|
+
}[]) => boolean;
|
|
183
116
|
aggregatePublicKeys(publicKeys: (WeierstrassPoint<P> | BLSInput)[]): WeierstrassPoint<P>;
|
|
184
117
|
aggregateSignatures(signatures: (WeierstrassPoint<S> | BLSInput)[]): WeierstrassPoint<S>;
|
|
185
118
|
hash(message: Uint8Array, DST?: string | Uint8Array, hashOpts?: H2CHashOpts): WeierstrassPoint<S>;
|
|
186
|
-
Signature:
|
|
119
|
+
Signature: BlsLongSignatureCoder<S>;
|
|
187
120
|
}
|
|
188
|
-
|
|
121
|
+
type BlsSignatureCoders = Partial<{
|
|
122
|
+
LongSignature: BlsLongSignatureCoder<Fp2>;
|
|
123
|
+
ShortSignature: BlsShortSignatureCoder<Fp>;
|
|
124
|
+
}>;
|
|
125
|
+
export declare function blsBasic(fields: BlsFields, G1_Point: WeierstrassPointCons<Fp>, G2_Point: WeierstrassPointCons<Fp2>, params: BlsPairingParams): BlsCurvePair;
|
|
126
|
+
export declare function bls(fields: BlsFields, G1_Point: WeierstrassPointCons<Fp>, G2_Point: WeierstrassPointCons<Fp2>, params: BlsPairingParams, hasherParams: BlsHasherParams, signatureCoders: BlsSignatureCoders): BlsCurvePairWithSignatures;
|
|
189
127
|
export {};
|
|
190
128
|
//# sourceMappingURL=bls.d.ts.map
|
package/abstract/bls.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bls.d.ts","sourceRoot":"","sources":["../src/abstract/bls.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"bls.d.ts","sourceRoot":"","sources":["../src/abstract/bls.ts"],"names":[],"mappings":"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"}
|