@coinbase/cdp-hooks 0.0.93 → 0.0.95

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 (270) hide show
  1. package/dist/esm/index.js +16 -16
  2. package/dist/esm/index100.js +42 -35
  3. package/dist/esm/index101.js +88 -9
  4. package/dist/esm/index102.js +40 -31
  5. package/dist/esm/index103.js +7 -35
  6. package/dist/esm/index104.js +4 -7
  7. package/dist/esm/index105.js +16 -29
  8. package/dist/esm/index106.js +8 -46
  9. package/dist/esm/index107.js +13 -88
  10. package/dist/esm/index108.js +7 -40
  11. package/dist/esm/index109.js +9 -8
  12. package/dist/esm/index110.js +15 -5
  13. package/dist/esm/index111.js +46 -16
  14. package/dist/esm/index112.js +13 -8
  15. package/dist/esm/index113.js +16 -13
  16. package/dist/esm/index114.js +13 -7
  17. package/dist/esm/index115.js +6 -9
  18. package/dist/esm/index116.js +34 -15
  19. package/dist/esm/index117.js +9 -46
  20. package/dist/esm/index118.js +8 -13
  21. package/dist/esm/index119.js +25 -16
  22. package/dist/esm/index120.js +10 -13
  23. package/dist/esm/index121.js +13 -5
  24. package/dist/esm/index122.js +11 -35
  25. package/dist/esm/index123.js +116 -9
  26. package/dist/esm/index124.js +32 -7
  27. package/dist/esm/index125.js +79 -25
  28. package/dist/esm/index126.js +177 -10
  29. package/dist/esm/index127.js +44 -14
  30. package/dist/esm/index128.js +6 -11
  31. package/dist/esm/index129.js +13 -116
  32. package/dist/esm/index130.js +12 -32
  33. package/dist/esm/index131.js +97 -77
  34. package/dist/esm/index132.js +67 -172
  35. package/dist/esm/index133.js +86 -43
  36. package/dist/esm/index134.js +148 -6
  37. package/dist/esm/index135.js +136 -13
  38. package/dist/esm/index136.js +68 -13
  39. package/dist/esm/index137.js +23 -99
  40. package/dist/esm/index138.js +104 -71
  41. package/dist/esm/index139.js +6 -87
  42. package/dist/esm/index140.js +128 -145
  43. package/dist/esm/index141.js +270 -131
  44. package/dist/esm/index142.js +3 -69
  45. package/dist/esm/index143.js +4 -24
  46. package/dist/esm/index144.js +9 -106
  47. package/dist/esm/index145.js +2 -7
  48. package/dist/esm/index146.js +2 -132
  49. package/dist/esm/index147.js +3 -276
  50. package/dist/esm/index148.js +327 -3
  51. package/dist/esm/index149.js +14 -4
  52. package/dist/esm/index150.js +5 -9
  53. package/dist/esm/index151.js +56 -2
  54. package/dist/esm/index152.js +2 -2
  55. package/dist/esm/index153.js +8 -3
  56. package/dist/esm/index154.js +166 -278
  57. package/dist/esm/index155.js +32 -14
  58. package/dist/esm/index156.js +21 -4
  59. package/dist/esm/index157.js +5 -55
  60. package/dist/esm/index158.js +74 -2
  61. package/dist/esm/index159.js +5 -7
  62. package/dist/esm/index160.js +5 -214
  63. package/dist/esm/index161.js +36 -32
  64. package/dist/esm/index162.js +74 -20
  65. package/dist/esm/index163.js +3 -6
  66. package/dist/esm/index164.js +18 -68
  67. package/dist/esm/index165.js +451 -5
  68. package/dist/esm/index166.js +30 -5
  69. package/dist/esm/index167.js +20 -29
  70. package/dist/esm/index168.js +21 -63
  71. package/dist/esm/index169.js +35 -3
  72. package/dist/esm/index170.js +186 -16
  73. package/dist/esm/index171.js +6 -449
  74. package/dist/esm/index172.js +2 -31
  75. package/dist/esm/index173.js +10 -24
  76. package/dist/esm/index174.js +13 -28
  77. package/dist/esm/index175.js +25 -32
  78. package/dist/esm/index176.js +8 -193
  79. package/dist/esm/index177.js +54 -7
  80. package/dist/esm/index178.js +46 -2
  81. package/dist/esm/index179.js +8 -12
  82. package/dist/esm/index180.js +7 -18
  83. package/dist/esm/index181.js +15 -26
  84. package/dist/esm/index182.js +18 -8
  85. package/dist/esm/index183.js +24 -55
  86. package/dist/esm/index184.js +16 -45
  87. package/dist/esm/index185.js +54 -8
  88. package/dist/esm/index186.js +11 -7
  89. package/dist/esm/index187.js +160 -16
  90. package/dist/esm/index188.js +20 -17
  91. package/dist/esm/index189.js +127 -24
  92. package/dist/esm/index190.js +37 -15
  93. package/dist/esm/index191.js +6 -54
  94. package/dist/esm/index192.js +27 -11
  95. package/dist/esm/index193.js +168 -137
  96. package/dist/esm/index194.js +4 -22
  97. package/dist/esm/index195.js +61 -124
  98. package/dist/esm/index196.js +3 -39
  99. package/dist/esm/index197.js +20 -6
  100. package/dist/esm/index198.js +16 -27
  101. package/dist/esm/index199.js +22 -190
  102. package/dist/esm/index200.js +12 -4
  103. package/dist/esm/index201.js +32 -62
  104. package/dist/esm/index202.js +3 -3
  105. package/dist/esm/index203.js +18 -20
  106. package/dist/esm/index204.js +27 -16
  107. package/dist/esm/index205.js +34 -22
  108. package/dist/esm/index206.js +7 -11
  109. package/dist/esm/index207.js +23 -32
  110. package/dist/esm/index208.js +29 -3
  111. package/dist/esm/index209.js +64 -18
  112. package/dist/esm/index210.js +9 -27
  113. package/dist/esm/index211.js +32 -34
  114. package/dist/esm/index212.js +27 -7
  115. package/dist/esm/index213.js +24 -25
  116. package/dist/esm/index214.js +3 -28
  117. package/dist/esm/index215.js +14 -64
  118. package/dist/esm/index216.js +103 -9
  119. package/dist/esm/index217.js +62 -31
  120. package/dist/esm/index218.js +5 -27
  121. package/dist/esm/index219.js +6 -24
  122. package/dist/esm/index220.js +27 -3
  123. package/dist/esm/index221.js +38 -14
  124. package/dist/esm/index222.js +13 -103
  125. package/dist/esm/index223.js +38 -60
  126. package/dist/esm/index224.js +5 -5
  127. package/dist/esm/index225.js +11 -6
  128. package/dist/esm/index226.js +19 -27
  129. package/dist/esm/index227.js +76 -36
  130. package/dist/esm/index228.js +2 -14
  131. package/dist/esm/index229.js +34 -39
  132. package/dist/esm/index230.js +110 -5
  133. package/dist/esm/index231.js +48 -11
  134. package/dist/esm/index232.js +32 -19
  135. package/dist/esm/index233.js +8 -78
  136. package/dist/esm/index234.js +7 -2
  137. package/dist/esm/index235.js +6 -37
  138. package/dist/esm/index236.js +11 -110
  139. package/dist/esm/index237.js +9 -47
  140. package/dist/esm/index238.js +13 -32
  141. package/dist/esm/index239.js +32 -8
  142. package/dist/esm/index240.js +5 -7
  143. package/dist/esm/index241.js +8 -6
  144. package/dist/esm/index242.js +19 -11
  145. package/dist/esm/index243.js +30 -9
  146. package/dist/esm/index244.js +20 -13
  147. package/dist/esm/index245.js +3 -32
  148. package/dist/esm/index246.js +18 -5
  149. package/dist/esm/index247.js +10 -8
  150. package/dist/esm/index248.js +21 -19
  151. package/dist/esm/index249.js +22 -31
  152. package/dist/esm/index250.js +5 -20
  153. package/dist/esm/index251.js +5 -3
  154. package/dist/esm/index252.js +8 -17
  155. package/dist/esm/index253.js +104 -10
  156. package/dist/esm/index254.js +3 -22
  157. package/dist/esm/index255.js +18 -22
  158. package/dist/esm/index256.js +171 -5
  159. package/dist/esm/index257.js +17 -5
  160. package/dist/esm/index258.js +10 -9
  161. package/dist/esm/index259.js +38 -104
  162. package/dist/esm/index260.js +2 -3
  163. package/dist/esm/index261.js +69 -18
  164. package/dist/esm/index262.js +33 -170
  165. package/dist/esm/index263.js +13 -16
  166. package/dist/esm/index264.js +41 -10
  167. package/dist/esm/index265.js +2 -41
  168. package/dist/esm/index266.js +5 -2
  169. package/dist/esm/index267.js +10 -4
  170. package/dist/esm/index268.js +18 -9
  171. package/dist/esm/index269.js +7 -19
  172. package/dist/esm/index270.js +11 -7
  173. package/dist/esm/index271.js +66 -11
  174. package/dist/esm/index272.js +64 -65
  175. package/dist/esm/index273.js +180 -60
  176. package/dist/esm/index274.js +20 -183
  177. package/dist/esm/index275.js +41 -21
  178. package/dist/esm/index276.js +54 -20
  179. package/dist/esm/index277.js +18 -54
  180. package/dist/esm/index278.js +10 -34
  181. package/dist/esm/index279.js +7 -10
  182. package/dist/esm/index280.js +7 -13
  183. package/dist/esm/index281.js +6 -7
  184. package/dist/esm/index282.js +36 -6
  185. package/dist/esm/index283.js +14 -35
  186. package/dist/esm/index284.js +8 -15
  187. package/dist/esm/index285.js +11 -7
  188. package/dist/esm/index286.js +9 -12
  189. package/dist/esm/index287.js +16 -9
  190. package/dist/esm/index288.js +21 -15
  191. package/dist/esm/index289.js +30 -22
  192. package/dist/esm/index290.js +2 -31
  193. package/dist/esm/index291.js +14 -2
  194. package/dist/esm/index292.js +12 -13
  195. package/dist/esm/index293.js +45 -10
  196. package/dist/esm/index294.js +9 -47
  197. package/dist/esm/index295.js +12 -8
  198. package/dist/esm/index296.js +14 -13
  199. package/dist/esm/index297.js +8 -14
  200. package/dist/esm/index298.js +13 -6
  201. package/dist/esm/index299.js +24 -15
  202. package/dist/esm/index3.js +1 -1
  203. package/dist/esm/index300.js +11 -24
  204. package/dist/esm/index301.js +23 -10
  205. package/dist/esm/index302.js +51 -24
  206. package/dist/esm/index303.js +17 -51
  207. package/dist/esm/index304.js +14 -17
  208. package/dist/esm/index305.js +11 -14
  209. package/dist/esm/index306.js +103 -11
  210. package/dist/esm/index307.js +5 -103
  211. package/dist/esm/index308.js +223 -5
  212. package/dist/esm/index309.js +6 -223
  213. package/dist/esm/index310.js +7 -7
  214. package/dist/esm/index311.js +27 -7
  215. package/dist/esm/index312.js +18 -25
  216. package/dist/esm/index313.js +144 -18
  217. package/dist/esm/index314.js +12 -145
  218. package/dist/esm/index315.js +35 -12
  219. package/dist/esm/index316.js +41 -35
  220. package/dist/esm/index317.js +2 -42
  221. package/dist/esm/index318.js +68 -3
  222. package/dist/esm/index319.js +3 -68
  223. package/dist/esm/index320.js +2 -2
  224. package/dist/esm/index321.js +155 -3
  225. package/dist/esm/index322.js +9 -155
  226. package/dist/esm/index323.js +16 -9
  227. package/dist/esm/index324.js +113 -16
  228. package/dist/esm/index325.js +116 -95
  229. package/dist/esm/index326.js +70 -126
  230. package/dist/esm/index327.js +2 -79
  231. package/dist/esm/index328.js +698 -2
  232. package/dist/esm/index329.js +126 -685
  233. package/dist/esm/index330.js +41 -137
  234. package/dist/esm/index331.js +198 -40
  235. package/dist/esm/index332.js +3 -200
  236. package/dist/esm/index335.js +1 -1
  237. package/dist/esm/index336.js +2 -2
  238. package/dist/esm/index340.js +2 -2
  239. package/dist/esm/index341.js +1 -1
  240. package/dist/esm/index37.js +24 -25
  241. package/dist/esm/index49.js +17 -18
  242. package/dist/esm/index50.js +5 -5
  243. package/dist/esm/index73.js +2 -2
  244. package/dist/esm/index74.js +2 -2
  245. package/dist/esm/index75.js +5 -5
  246. package/dist/esm/index76.js +2 -2
  247. package/dist/esm/index77.js +2 -2
  248. package/dist/esm/index79.js +31 -37
  249. package/dist/esm/index80.js +4 -2
  250. package/dist/esm/index81.js +9 -69
  251. package/dist/esm/index82.js +68 -34
  252. package/dist/esm/index83.js +8 -13
  253. package/dist/esm/index84.js +29 -2
  254. package/dist/esm/index85.js +69 -31
  255. package/dist/esm/index86.js +19 -3
  256. package/dist/esm/index87.js +110 -9
  257. package/dist/esm/index88.js +58 -66
  258. package/dist/esm/index89.js +22 -7
  259. package/dist/esm/index90.js +39 -27
  260. package/dist/esm/index91.js +36 -69
  261. package/dist/esm/index92.js +58 -19
  262. package/dist/esm/index93.js +163 -110
  263. package/dist/esm/index94.js +36 -57
  264. package/dist/esm/index95.js +8 -23
  265. package/dist/esm/index96.js +31 -40
  266. package/dist/esm/index97.js +33 -34
  267. package/dist/esm/index98.js +9 -58
  268. package/dist/esm/index99.js +25 -159
  269. package/dist/types/index.d.ts +12 -11
  270. package/package.json +3 -3
@@ -1,17 +1,14 @@
1
- import { isAddress as f } from "./index206.js";
2
- import { isAddressEqual as o } from "./index216.js";
3
- function l(n) {
4
- const { address: r, domain: s, message: e, nonce: t, scheme: a, time: i = /* @__PURE__ */ new Date() } = n;
5
- if (s && e.domain !== s || t && e.nonce !== t || a && e.scheme !== a || e.expirationTime && i >= e.expirationTime || e.notBefore && i < e.notBefore)
6
- return !1;
7
- try {
8
- if (!e.address || !f(e.address, { strict: !1 }) || r && !o(e.address, r))
9
- return !1;
10
- } catch {
11
- return !1;
12
- }
13
- return !0;
1
+ import { LruMap as u } from "./index248.js";
2
+ const t = /* @__PURE__ */ new u(8192);
3
+ function s(r, { enabled: o = !0, id: e }) {
4
+ if (!o || !e)
5
+ return r();
6
+ if (t.get(e))
7
+ return t.get(e);
8
+ const n = r().finally(() => t.delete(e));
9
+ return t.set(e, n), n;
14
10
  }
15
11
  export {
16
- l as validateSiweMessage
12
+ t as promiseCache,
13
+ s as withDedupe
17
14
  };
@@ -1,14 +1,106 @@
1
- import { LruMap as u } from "./index254.js";
2
- const t = /* @__PURE__ */ new u(8192);
3
- function s(r, { enabled: o = !0, id: e }) {
4
- if (!o || !e)
5
- return r();
6
- if (t.get(e))
7
- return t.get(e);
8
- const n = r().finally(() => t.delete(e));
9
- return t.set(e, n), n;
1
+ import { HashMD as D, SHA256_IV as b, Chi as g, Maj as p } from "./index326.js";
2
+ import { createHasher as u, clean as C, rotr as i } from "./index313.js";
3
+ const B = /* @__PURE__ */ Uint32Array.from([
4
+ 1116352408,
5
+ 1899447441,
6
+ 3049323471,
7
+ 3921009573,
8
+ 961987163,
9
+ 1508970993,
10
+ 2453635748,
11
+ 2870763221,
12
+ 3624381080,
13
+ 310598401,
14
+ 607225278,
15
+ 1426881987,
16
+ 1925078388,
17
+ 2162078206,
18
+ 2614888103,
19
+ 3248222580,
20
+ 3835390401,
21
+ 4022224774,
22
+ 264347078,
23
+ 604807628,
24
+ 770255983,
25
+ 1249150122,
26
+ 1555081692,
27
+ 1996064986,
28
+ 2554220882,
29
+ 2821834349,
30
+ 2952996808,
31
+ 3210313671,
32
+ 3336571891,
33
+ 3584528711,
34
+ 113926993,
35
+ 338241895,
36
+ 666307205,
37
+ 773529912,
38
+ 1294757372,
39
+ 1396182291,
40
+ 1695183700,
41
+ 1986661051,
42
+ 2177026350,
43
+ 2456956037,
44
+ 2730485921,
45
+ 2820302411,
46
+ 3259730800,
47
+ 3345764771,
48
+ 3516065817,
49
+ 3600352804,
50
+ 4094571909,
51
+ 275423344,
52
+ 430227734,
53
+ 506948616,
54
+ 659060556,
55
+ 883997877,
56
+ 958139571,
57
+ 1322822218,
58
+ 1537002063,
59
+ 1747873779,
60
+ 1955562222,
61
+ 2024104815,
62
+ 2227730452,
63
+ 2361852424,
64
+ 2428436474,
65
+ 2756734187,
66
+ 3204031479,
67
+ 3329325298
68
+ ]), h = /* @__PURE__ */ new Uint32Array(64);
69
+ class E extends D {
70
+ constructor(o = 32) {
71
+ super(64, o, 8, !1), this.A = b[0] | 0, this.B = b[1] | 0, this.C = b[2] | 0, this.D = b[3] | 0, this.E = b[4] | 0, this.F = b[5] | 0, this.G = b[6] | 0, this.H = b[7] | 0;
72
+ }
73
+ get() {
74
+ const { A: o, B: r, C: t, D: s, E: a, F: f, G: c, H: e } = this;
75
+ return [o, r, t, s, a, f, c, e];
76
+ }
77
+ // prettier-ignore
78
+ set(o, r, t, s, a, f, c, e) {
79
+ this.A = o | 0, this.B = r | 0, this.C = t | 0, this.D = s | 0, this.E = a | 0, this.F = f | 0, this.G = c | 0, this.H = e | 0;
80
+ }
81
+ process(o, r) {
82
+ for (let x = 0; x < 16; x++, r += 4)
83
+ h[x] = o.getUint32(r, !1);
84
+ for (let x = 16; x < 64; x++) {
85
+ const H = h[x - 15], d = h[x - 2], m = i(H, 7) ^ i(H, 18) ^ H >>> 3, l = i(d, 17) ^ i(d, 19) ^ d >>> 10;
86
+ h[x] = l + h[x - 7] + m + h[x - 16] | 0;
87
+ }
88
+ let { A: t, B: s, C: a, D: f, E: c, F: e, G: n, H: A } = this;
89
+ for (let x = 0; x < 64; x++) {
90
+ const H = i(c, 6) ^ i(c, 11) ^ i(c, 25), d = A + H + g(c, e, n) + B[x] + h[x] | 0, l = (i(t, 2) ^ i(t, 13) ^ i(t, 22)) + p(t, s, a) | 0;
91
+ A = n, n = e, e = c, c = f + d | 0, f = a, a = s, s = t, t = d + l | 0;
92
+ }
93
+ t = t + this.A | 0, s = s + this.B | 0, a = a + this.C | 0, f = f + this.D | 0, c = c + this.E | 0, e = e + this.F | 0, n = n + this.G | 0, A = A + this.H | 0, this.set(t, s, a, f, c, e, n, A);
94
+ }
95
+ roundClean() {
96
+ C(h);
97
+ }
98
+ destroy() {
99
+ this.set(0, 0, 0, 0, 0, 0, 0, 0), C(this.buffer);
100
+ }
10
101
  }
102
+ const y = /* @__PURE__ */ u(() => new E());
11
103
  export {
12
- t as promiseCache,
13
- s as withDedupe
104
+ E as SHA256,
105
+ y as sha256
14
106
  };
@@ -1,106 +1,8 @@
1
- import { HashMD as D, SHA256_IV as b, Chi as g, Maj as p } from "./index327.js";
2
- import { createHasher as u, clean as C, rotr as i } from "./index314.js";
3
- const B = /* @__PURE__ */ Uint32Array.from([
4
- 1116352408,
5
- 1899447441,
6
- 3049323471,
7
- 3921009573,
8
- 961987163,
9
- 1508970993,
10
- 2453635748,
11
- 2870763221,
12
- 3624381080,
13
- 310598401,
14
- 607225278,
15
- 1426881987,
16
- 1925078388,
17
- 2162078206,
18
- 2614888103,
19
- 3248222580,
20
- 3835390401,
21
- 4022224774,
22
- 264347078,
23
- 604807628,
24
- 770255983,
25
- 1249150122,
26
- 1555081692,
27
- 1996064986,
28
- 2554220882,
29
- 2821834349,
30
- 2952996808,
31
- 3210313671,
32
- 3336571891,
33
- 3584528711,
34
- 113926993,
35
- 338241895,
36
- 666307205,
37
- 773529912,
38
- 1294757372,
39
- 1396182291,
40
- 1695183700,
41
- 1986661051,
42
- 2177026350,
43
- 2456956037,
44
- 2730485921,
45
- 2820302411,
46
- 3259730800,
47
- 3345764771,
48
- 3516065817,
49
- 3600352804,
50
- 4094571909,
51
- 275423344,
52
- 430227734,
53
- 506948616,
54
- 659060556,
55
- 883997877,
56
- 958139571,
57
- 1322822218,
58
- 1537002063,
59
- 1747873779,
60
- 1955562222,
61
- 2024104815,
62
- 2227730452,
63
- 2361852424,
64
- 2428436474,
65
- 2756734187,
66
- 3204031479,
67
- 3329325298
68
- ]), h = /* @__PURE__ */ new Uint32Array(64);
69
- class E extends D {
70
- constructor(o = 32) {
71
- super(64, o, 8, !1), this.A = b[0] | 0, this.B = b[1] | 0, this.C = b[2] | 0, this.D = b[3] | 0, this.E = b[4] | 0, this.F = b[5] | 0, this.G = b[6] | 0, this.H = b[7] | 0;
72
- }
73
- get() {
74
- const { A: o, B: r, C: t, D: s, E: a, F: f, G: c, H: e } = this;
75
- return [o, r, t, s, a, f, c, e];
76
- }
77
- // prettier-ignore
78
- set(o, r, t, s, a, f, c, e) {
79
- this.A = o | 0, this.B = r | 0, this.C = t | 0, this.D = s | 0, this.E = a | 0, this.F = f | 0, this.G = c | 0, this.H = e | 0;
80
- }
81
- process(o, r) {
82
- for (let x = 0; x < 16; x++, r += 4)
83
- h[x] = o.getUint32(r, !1);
84
- for (let x = 16; x < 64; x++) {
85
- const H = h[x - 15], d = h[x - 2], m = i(H, 7) ^ i(H, 18) ^ H >>> 3, l = i(d, 17) ^ i(d, 19) ^ d >>> 10;
86
- h[x] = l + h[x - 7] + m + h[x - 16] | 0;
87
- }
88
- let { A: t, B: s, C: a, D: f, E: c, F: e, G: n, H: A } = this;
89
- for (let x = 0; x < 64; x++) {
90
- const H = i(c, 6) ^ i(c, 11) ^ i(c, 25), d = A + H + g(c, e, n) + B[x] + h[x] | 0, l = (i(t, 2) ^ i(t, 13) ^ i(t, 22)) + p(t, s, a) | 0;
91
- A = n, n = e, e = c, c = f + d | 0, f = a, a = s, s = t, t = d + l | 0;
92
- }
93
- t = t + this.A | 0, s = s + this.B | 0, a = a + this.C | 0, f = f + this.D | 0, c = c + this.E | 0, e = e + this.F | 0, n = n + this.G | 0, A = A + this.H | 0, this.set(t, s, a, f, c, e, n, A);
94
- }
95
- roundClean() {
96
- C(h);
97
- }
98
- destroy() {
99
- this.set(0, 0, 0, 0, 0, 0, 0, 0), C(this.buffer);
100
- }
1
+ import { weierstrass as s } from "./index328.js";
2
+ function c(e, t) {
3
+ const r = (o) => s({ ...e, hash: o });
4
+ return { ...r(t), create: r };
101
5
  }
102
- const y = /* @__PURE__ */ u(() => new E());
103
6
  export {
104
- E as SHA256,
105
- y as sha256
7
+ c as createCurve
106
8
  };
@@ -1,8 +1,226 @@
1
- import { weierstrass as s } from "./index329.js";
2
- function c(e, t) {
3
- const r = (o) => s({ ...e, hash: o });
4
- return { ...r(t), create: r };
1
+ import { numberToBytesLE as y, numberToBytesBE as I, bitMask as Z, bytesToNumberLE as S, bytesToNumberBE as _, _validateObject as j } from "./index329.js";
2
+ import { anumber as z } from "./index313.js";
3
+ const g = BigInt(0), d = BigInt(1), q = /* @__PURE__ */ BigInt(2), V = /* @__PURE__ */ BigInt(3), x = /* @__PURE__ */ BigInt(4), T = /* @__PURE__ */ BigInt(5), L = /* @__PURE__ */ BigInt(8);
4
+ function h(t, n) {
5
+ const o = t % n;
6
+ return o >= g ? o : n + o;
7
+ }
8
+ function O(t, n, o) {
9
+ let r = t;
10
+ for (; n-- > g; )
11
+ r *= r, r %= o;
12
+ return r;
13
+ }
14
+ function B(t, n) {
15
+ if (t === g)
16
+ throw new Error("invert: expected non-zero number");
17
+ if (n <= g)
18
+ throw new Error("invert: expected positive modulus, got " + n);
19
+ let o = h(t, n), r = n, s = g, f = d;
20
+ for (; o !== g; ) {
21
+ const u = r / o, i = r % o, w = s - f * u;
22
+ r = o, o = i, s = f, f = w;
23
+ }
24
+ if (r !== d)
25
+ throw new Error("invert: does not exist");
26
+ return h(s, n);
27
+ }
28
+ function M(t, n) {
29
+ const o = (t.ORDER + d) / x, r = t.pow(n, o);
30
+ if (!t.eql(t.sqr(r), n))
31
+ throw new Error("Cannot find square root");
32
+ return r;
33
+ }
34
+ function H(t, n) {
35
+ const o = (t.ORDER - T) / L, r = t.mul(n, q), s = t.pow(r, o), f = t.mul(n, s), c = t.mul(t.mul(f, q), s), u = t.mul(f, t.sub(c, t.ONE));
36
+ if (!t.eql(t.sqr(u), n))
37
+ throw new Error("Cannot find square root");
38
+ return u;
39
+ }
40
+ function K(t) {
41
+ if (t < BigInt(3))
42
+ throw new Error("sqrt is not defined for small field");
43
+ let n = t - d, o = 0;
44
+ for (; n % q === g; )
45
+ n /= q, o++;
46
+ let r = q;
47
+ const s = U(t);
48
+ for (; N(s, r) === 1; )
49
+ if (r++ > 1e3)
50
+ throw new Error("Cannot find square root: probably non-prime P");
51
+ if (o === 1)
52
+ return M;
53
+ let f = s.pow(r, n);
54
+ const c = (n + d) / q;
55
+ return function(i, w) {
56
+ if (i.is0(w))
57
+ return w;
58
+ if (N(i, w) !== 1)
59
+ throw new Error("Cannot find square root");
60
+ let e = o, l = i.mul(i.ONE, f), a = i.pow(w, n), b = i.pow(w, c);
61
+ for (; !i.eql(a, i.ONE); ) {
62
+ if (i.is0(a))
63
+ return i.ZERO;
64
+ let m = 1, E = i.sqr(a);
65
+ for (; !i.eql(E, i.ONE); )
66
+ if (m++, E = i.sqr(E), m === e)
67
+ throw new Error("Cannot find square root");
68
+ const C = d << BigInt(e - m - 1), v = i.pow(l, C);
69
+ e = m, l = i.sqr(v), a = i.mul(a, l), b = i.mul(b, v);
70
+ }
71
+ return b;
72
+ };
73
+ }
74
+ function Q(t) {
75
+ return t % x === V ? M : t % L === T ? H : K(t);
76
+ }
77
+ const Y = [
78
+ "create",
79
+ "isValid",
80
+ "is0",
81
+ "neg",
82
+ "inv",
83
+ "sqrt",
84
+ "sqr",
85
+ "eql",
86
+ "add",
87
+ "sub",
88
+ "mul",
89
+ "pow",
90
+ "div",
91
+ "addN",
92
+ "subN",
93
+ "mulN",
94
+ "sqrN"
95
+ ];
96
+ function P(t) {
97
+ const n = {
98
+ ORDER: "bigint",
99
+ MASK: "bigint",
100
+ BYTES: "number",
101
+ BITS: "number"
102
+ }, o = Y.reduce((r, s) => (r[s] = "function", r), n);
103
+ return j(t, o), t;
104
+ }
105
+ function k(t, n, o) {
106
+ if (o < g)
107
+ throw new Error("invalid exponent, negatives unsupported");
108
+ if (o === g)
109
+ return t.ONE;
110
+ if (o === d)
111
+ return n;
112
+ let r = t.ONE, s = n;
113
+ for (; o > g; )
114
+ o & d && (r = t.mul(r, s)), s = t.sqr(s), o >>= d;
115
+ return r;
116
+ }
117
+ function G(t, n, o = !1) {
118
+ const r = new Array(n.length).fill(o ? t.ZERO : void 0), s = n.reduce((c, u, i) => t.is0(u) ? c : (r[i] = c, t.mul(c, u)), t.ONE), f = t.inv(s);
119
+ return n.reduceRight((c, u, i) => t.is0(u) ? c : (r[i] = t.mul(c, r[i]), t.mul(c, u)), f), r;
120
+ }
121
+ function N(t, n) {
122
+ const o = (t.ORDER - d) / q, r = t.pow(n, o), s = t.eql(r, t.ONE), f = t.eql(r, t.ZERO), c = t.eql(r, t.neg(t.ONE));
123
+ if (!s && !f && !c)
124
+ throw new Error("invalid Legendre symbol result");
125
+ return s ? 1 : f ? 0 : -1;
126
+ }
127
+ function J(t, n) {
128
+ n !== void 0 && z(n);
129
+ const o = n !== void 0 ? n : t.toString(2).length, r = Math.ceil(o / 8);
130
+ return { nBitLength: o, nByteLength: r };
131
+ }
132
+ function U(t, n, o = !1, r = {}) {
133
+ if (t <= g)
134
+ throw new Error("invalid field: expected ORDER > 0, got " + t);
135
+ let s, f;
136
+ if (typeof n == "object" && n != null) {
137
+ if (r.sqrt || o)
138
+ throw new Error("cannot specify opts in two arguments");
139
+ const e = n;
140
+ e.BITS && (s = e.BITS), e.sqrt && (f = e.sqrt), typeof e.isLE == "boolean" && (o = e.isLE);
141
+ } else
142
+ typeof n == "number" && (s = n), r.sqrt && (f = r.sqrt);
143
+ const { nBitLength: c, nByteLength: u } = J(t, s);
144
+ if (u > 2048)
145
+ throw new Error("invalid field: expected ORDER of <= 2048 bytes");
146
+ let i;
147
+ const w = Object.freeze({
148
+ ORDER: t,
149
+ isLE: o,
150
+ BITS: c,
151
+ BYTES: u,
152
+ MASK: Z(c),
153
+ ZERO: g,
154
+ ONE: d,
155
+ create: (e) => h(e, t),
156
+ isValid: (e) => {
157
+ if (typeof e != "bigint")
158
+ throw new Error("invalid field element: expected bigint, got " + typeof e);
159
+ return g <= e && e < t;
160
+ },
161
+ is0: (e) => e === g,
162
+ // is valid and invertible
163
+ isValidNot0: (e) => !w.is0(e) && w.isValid(e),
164
+ isOdd: (e) => (e & d) === d,
165
+ neg: (e) => h(-e, t),
166
+ eql: (e, l) => e === l,
167
+ sqr: (e) => h(e * e, t),
168
+ add: (e, l) => h(e + l, t),
169
+ sub: (e, l) => h(e - l, t),
170
+ mul: (e, l) => h(e * l, t),
171
+ pow: (e, l) => k(w, e, l),
172
+ div: (e, l) => h(e * B(l, t), t),
173
+ // Same as above, but doesn't normalize
174
+ sqrN: (e) => e * e,
175
+ addN: (e, l) => e + l,
176
+ subN: (e, l) => e - l,
177
+ mulN: (e, l) => e * l,
178
+ inv: (e) => B(e, t),
179
+ sqrt: f || ((e) => (i || (i = Q(t)), i(w, e))),
180
+ toBytes: (e) => o ? y(e, u) : I(e, u),
181
+ fromBytes: (e) => {
182
+ if (e.length !== u)
183
+ throw new Error("Field.fromBytes: expected " + u + " bytes, got " + e.length);
184
+ return o ? S(e) : _(e);
185
+ },
186
+ // TODO: we don't need it here, move out to separate fn
187
+ invertBatch: (e) => G(w, e),
188
+ // We can't move this out because Fp6, Fp12 implement it
189
+ // and it's unclear what to return in there.
190
+ cmov: (e, l, a) => a ? l : e
191
+ });
192
+ return Object.freeze(w);
193
+ }
194
+ function A(t) {
195
+ if (typeof t != "bigint")
196
+ throw new Error("field order must be bigint");
197
+ const n = t.toString(2).length;
198
+ return Math.ceil(n / 8);
199
+ }
200
+ function W(t) {
201
+ const n = A(t);
202
+ return n + Math.ceil(n / 2);
203
+ }
204
+ function D(t, n, o = !1) {
205
+ const r = t.length, s = A(n), f = W(n);
206
+ if (r < 16 || r < f || r > 1024)
207
+ throw new Error("expected " + f + "-1024 bytes of input, got " + r);
208
+ const c = o ? S(t) : _(t), u = h(c, n - d) + d;
209
+ return o ? y(u, s) : I(u, s);
5
210
  }
6
211
  export {
7
- c as createCurve
212
+ U as Field,
213
+ G as FpInvertBatch,
214
+ N as FpLegendre,
215
+ k as FpPow,
216
+ Q as FpSqrt,
217
+ A as getFieldBytesLength,
218
+ W as getMinHashLength,
219
+ B as invert,
220
+ D as mapHashToField,
221
+ h as mod,
222
+ J as nLength,
223
+ O as pow2,
224
+ K as tonelliShanks,
225
+ P as validateField
8
226
  };