@openclaw/nostr 2026.5.20-beta.2 → 2026.5.22

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 (1336) hide show
  1. package/node_modules/@noble/ciphers/LICENSE +22 -0
  2. package/node_modules/@noble/ciphers/README.md +608 -0
  3. package/node_modules/@noble/ciphers/_arx.d.ts +81 -0
  4. package/node_modules/@noble/ciphers/_arx.d.ts.map +1 -0
  5. package/node_modules/@noble/ciphers/_arx.js +258 -0
  6. package/node_modules/@noble/ciphers/_arx.js.map +1 -0
  7. package/node_modules/@noble/ciphers/_poly1305.d.ts +48 -0
  8. package/node_modules/@noble/ciphers/_poly1305.d.ts.map +1 -0
  9. package/node_modules/@noble/ciphers/_poly1305.js +319 -0
  10. package/node_modules/@noble/ciphers/_poly1305.js.map +1 -0
  11. package/node_modules/@noble/ciphers/_polyval.d.ts +62 -0
  12. package/node_modules/@noble/ciphers/_polyval.d.ts.map +1 -0
  13. package/node_modules/@noble/ciphers/_polyval.js +231 -0
  14. package/node_modules/@noble/ciphers/_polyval.js.map +1 -0
  15. package/node_modules/@noble/ciphers/aes.d.ts +231 -0
  16. package/node_modules/@noble/ciphers/aes.d.ts.map +1 -0
  17. package/node_modules/@noble/ciphers/aes.js +1281 -0
  18. package/node_modules/@noble/ciphers/aes.js.map +1 -0
  19. package/node_modules/@noble/ciphers/chacha.d.ts +75 -0
  20. package/node_modules/@noble/ciphers/chacha.d.ts.map +1 -0
  21. package/node_modules/@noble/ciphers/chacha.js +385 -0
  22. package/node_modules/@noble/ciphers/chacha.js.map +1 -0
  23. package/node_modules/@noble/ciphers/ff1.d.ts +9 -0
  24. package/node_modules/@noble/ciphers/ff1.d.ts.map +1 -0
  25. package/node_modules/@noble/ciphers/ff1.js +160 -0
  26. package/node_modules/@noble/ciphers/ff1.js.map +1 -0
  27. package/node_modules/@noble/ciphers/index.d.ts +2 -0
  28. package/node_modules/@noble/ciphers/index.d.ts.map +1 -0
  29. package/node_modules/@noble/ciphers/index.js +27 -0
  30. package/node_modules/@noble/ciphers/index.js.map +1 -0
  31. package/node_modules/@noble/ciphers/package.json +81 -0
  32. package/node_modules/@noble/ciphers/salsa.d.ts +30 -0
  33. package/node_modules/@noble/ciphers/salsa.d.ts.map +1 -0
  34. package/node_modules/@noble/ciphers/salsa.js +260 -0
  35. package/node_modules/@noble/ciphers/salsa.js.map +1 -0
  36. package/node_modules/@noble/ciphers/src/_arx.ts +338 -0
  37. package/node_modules/@noble/ciphers/src/_poly1305.ts +360 -0
  38. package/node_modules/@noble/ciphers/src/_polyval.ts +272 -0
  39. package/node_modules/@noble/ciphers/src/aes.ts +1439 -0
  40. package/node_modules/@noble/ciphers/src/chacha.ts +367 -0
  41. package/node_modules/@noble/ciphers/src/ff1.ts +162 -0
  42. package/node_modules/@noble/ciphers/src/index.ts +25 -0
  43. package/node_modules/@noble/ciphers/src/salsa.ts +255 -0
  44. package/node_modules/@noble/ciphers/src/utils.ts +497 -0
  45. package/node_modules/@noble/ciphers/src/webcrypto.ts +125 -0
  46. package/node_modules/@noble/ciphers/utils.d.ts +171 -0
  47. package/node_modules/@noble/ciphers/utils.d.ts.map +1 -0
  48. package/node_modules/@noble/ciphers/utils.js +343 -0
  49. package/node_modules/@noble/ciphers/utils.js.map +1 -0
  50. package/node_modules/@noble/ciphers/webcrypto.d.ts +30 -0
  51. package/node_modules/@noble/ciphers/webcrypto.d.ts.map +1 -0
  52. package/node_modules/@noble/ciphers/webcrypto.js +99 -0
  53. package/node_modules/@noble/ciphers/webcrypto.js.map +1 -0
  54. package/node_modules/@noble/curves/LICENSE +21 -0
  55. package/node_modules/@noble/curves/README.md +1037 -0
  56. package/node_modules/@noble/curves/abstract/bls.d.ts +128 -0
  57. package/node_modules/@noble/curves/abstract/bls.d.ts.map +1 -0
  58. package/node_modules/@noble/curves/abstract/bls.js +372 -0
  59. package/node_modules/@noble/curves/abstract/bls.js.map +1 -0
  60. package/node_modules/@noble/curves/abstract/curve.d.ts +195 -0
  61. package/node_modules/@noble/curves/abstract/curve.d.ts.map +1 -0
  62. package/node_modules/@noble/curves/abstract/curve.js +457 -0
  63. package/node_modules/@noble/curves/abstract/curve.js.map +1 -0
  64. package/node_modules/@noble/curves/abstract/edwards.d.ts +184 -0
  65. package/node_modules/@noble/curves/abstract/edwards.d.ts.map +1 -0
  66. package/node_modules/@noble/curves/abstract/edwards.js +558 -0
  67. package/node_modules/@noble/curves/abstract/edwards.js.map +1 -0
  68. package/node_modules/@noble/curves/abstract/fft.d.ts +127 -0
  69. package/node_modules/@noble/curves/abstract/fft.d.ts.map +1 -0
  70. package/node_modules/@noble/curves/abstract/fft.js +426 -0
  71. package/node_modules/@noble/curves/abstract/fft.js.map +1 -0
  72. package/node_modules/@noble/curves/abstract/hash-to-curve.d.ts +90 -0
  73. package/node_modules/@noble/curves/abstract/hash-to-curve.d.ts.map +1 -0
  74. package/node_modules/@noble/curves/abstract/hash-to-curve.js +207 -0
  75. package/node_modules/@noble/curves/abstract/hash-to-curve.js.map +1 -0
  76. package/node_modules/@noble/curves/abstract/modular.d.ts +159 -0
  77. package/node_modules/@noble/curves/abstract/modular.d.ts.map +1 -0
  78. package/node_modules/@noble/curves/abstract/modular.js +555 -0
  79. package/node_modules/@noble/curves/abstract/modular.js.map +1 -0
  80. package/node_modules/@noble/curves/abstract/montgomery.d.ts +25 -0
  81. package/node_modules/@noble/curves/abstract/montgomery.d.ts.map +1 -0
  82. package/node_modules/@noble/curves/abstract/montgomery.js +153 -0
  83. package/node_modules/@noble/curves/abstract/montgomery.js.map +1 -0
  84. package/node_modules/@noble/curves/abstract/oprf.d.ts +282 -0
  85. package/node_modules/@noble/curves/abstract/oprf.d.ts.map +1 -0
  86. package/node_modules/@noble/curves/abstract/oprf.js +297 -0
  87. package/node_modules/@noble/curves/abstract/oprf.js.map +1 -0
  88. package/node_modules/@noble/curves/abstract/poseidon.d.ts +68 -0
  89. package/node_modules/@noble/curves/abstract/poseidon.d.ts.map +1 -0
  90. package/node_modules/@noble/curves/abstract/poseidon.js +300 -0
  91. package/node_modules/@noble/curves/abstract/poseidon.js.map +1 -0
  92. package/node_modules/@noble/curves/abstract/tower.d.ts +95 -0
  93. package/node_modules/@noble/curves/abstract/tower.d.ts.map +1 -0
  94. package/node_modules/@noble/curves/abstract/tower.js +742 -0
  95. package/node_modules/@noble/curves/abstract/tower.js.map +1 -0
  96. package/node_modules/@noble/curves/abstract/weierstrass.d.ts +325 -0
  97. package/node_modules/@noble/curves/abstract/weierstrass.d.ts.map +1 -0
  98. package/node_modules/@noble/curves/abstract/weierstrass.js +1222 -0
  99. package/node_modules/@noble/curves/abstract/weierstrass.js.map +1 -0
  100. package/node_modules/@noble/curves/bls12-381.d.ts +10 -0
  101. package/node_modules/@noble/curves/bls12-381.d.ts.map +1 -0
  102. package/node_modules/@noble/curves/bls12-381.js +688 -0
  103. package/node_modules/@noble/curves/bls12-381.js.map +1 -0
  104. package/node_modules/@noble/curves/bn254.d.ts +66 -0
  105. package/node_modules/@noble/curves/bn254.d.ts.map +1 -0
  106. package/node_modules/@noble/curves/bn254.js +190 -0
  107. package/node_modules/@noble/curves/bn254.js.map +1 -0
  108. package/node_modules/@noble/curves/ed25519.d.ts +101 -0
  109. package/node_modules/@noble/curves/ed25519.d.ts.map +1 -0
  110. package/node_modules/@noble/curves/ed25519.js +462 -0
  111. package/node_modules/@noble/curves/ed25519.js.map +1 -0
  112. package/node_modules/@noble/curves/ed448.d.ts +91 -0
  113. package/node_modules/@noble/curves/ed448.d.ts.map +1 -0
  114. package/node_modules/@noble/curves/ed448.js +442 -0
  115. package/node_modules/@noble/curves/ed448.js.map +1 -0
  116. package/node_modules/@noble/curves/index.d.ts +2 -0
  117. package/node_modules/@noble/curves/index.d.ts.map +1 -0
  118. package/node_modules/@noble/curves/index.js +33 -0
  119. package/node_modules/@noble/curves/index.js.map +1 -0
  120. package/node_modules/@noble/curves/misc.d.ts +15 -0
  121. package/node_modules/@noble/curves/misc.d.ts.map +1 -0
  122. package/node_modules/@noble/curves/misc.js +103 -0
  123. package/node_modules/@noble/curves/misc.js.map +1 -0
  124. package/node_modules/@noble/curves/nist.d.ts +36 -0
  125. package/node_modules/@noble/curves/nist.d.ts.map +1 -0
  126. package/node_modules/@noble/curves/nist.js +146 -0
  127. package/node_modules/@noble/curves/nist.js.map +1 -0
  128. package/node_modules/@noble/curves/package.json +98 -0
  129. package/node_modules/@noble/curves/secp256k1.d.ts +76 -0
  130. package/node_modules/@noble/curves/secp256k1.d.ts.map +1 -0
  131. package/node_modules/@noble/curves/secp256k1.js +283 -0
  132. package/node_modules/@noble/curves/secp256k1.js.map +1 -0
  133. package/node_modules/@noble/curves/src/abstract/bls.ts +604 -0
  134. package/node_modules/@noble/curves/src/abstract/curve.ts +633 -0
  135. package/node_modules/@noble/curves/src/abstract/edwards.ts +789 -0
  136. package/node_modules/@noble/curves/src/abstract/fft.ts +521 -0
  137. package/node_modules/@noble/curves/src/abstract/hash-to-curve.ts +292 -0
  138. package/node_modules/@noble/curves/src/abstract/modular.ts +621 -0
  139. package/node_modules/@noble/curves/src/abstract/montgomery.ts +187 -0
  140. package/node_modules/@noble/curves/src/abstract/oprf.ts +600 -0
  141. package/node_modules/@noble/curves/src/abstract/poseidon.ts +333 -0
  142. package/node_modules/@noble/curves/src/abstract/tower.ts +864 -0
  143. package/node_modules/@noble/curves/src/abstract/weierstrass.ts +1562 -0
  144. package/node_modules/@noble/curves/src/bls12-381.ts +775 -0
  145. package/node_modules/@noble/curves/src/bn254.ts +219 -0
  146. package/node_modules/@noble/curves/src/ed25519.ts +533 -0
  147. package/node_modules/@noble/curves/src/ed448.ts +525 -0
  148. package/node_modules/@noble/curves/src/index.ts +31 -0
  149. package/node_modules/@noble/curves/src/misc.ts +140 -0
  150. package/node_modules/@noble/curves/src/nist.ts +204 -0
  151. package/node_modules/@noble/curves/src/secp256k1.ts +327 -0
  152. package/node_modules/@noble/curves/src/utils.ts +306 -0
  153. package/node_modules/@noble/curves/src/webcrypto.ts +403 -0
  154. package/node_modules/@noble/curves/utils.d.ts +103 -0
  155. package/node_modules/@noble/curves/utils.d.ts.map +1 -0
  156. package/node_modules/@noble/curves/utils.js +241 -0
  157. package/node_modules/@noble/curves/utils.js.map +1 -0
  158. package/node_modules/@noble/curves/webcrypto.d.ts +99 -0
  159. package/node_modules/@noble/curves/webcrypto.d.ts.map +1 -0
  160. package/node_modules/@noble/curves/webcrypto.js +256 -0
  161. package/node_modules/@noble/curves/webcrypto.js.map +1 -0
  162. package/node_modules/@noble/hashes/LICENSE +21 -0
  163. package/node_modules/@noble/hashes/README.md +575 -0
  164. package/node_modules/@noble/hashes/_blake.d.ts +14 -0
  165. package/node_modules/@noble/hashes/_blake.d.ts.map +1 -0
  166. package/node_modules/@noble/hashes/_blake.js +45 -0
  167. package/node_modules/@noble/hashes/_blake.js.map +1 -0
  168. package/node_modules/@noble/hashes/_md.d.ts +49 -0
  169. package/node_modules/@noble/hashes/_md.d.ts.map +1 -0
  170. package/node_modules/@noble/hashes/_md.js +147 -0
  171. package/node_modules/@noble/hashes/_md.js.map +1 -0
  172. package/node_modules/@noble/hashes/_u64.d.ts +55 -0
  173. package/node_modules/@noble/hashes/_u64.d.ts.map +1 -0
  174. package/node_modules/@noble/hashes/_u64.js +67 -0
  175. package/node_modules/@noble/hashes/_u64.js.map +1 -0
  176. package/node_modules/@noble/hashes/argon2.d.ts +32 -0
  177. package/node_modules/@noble/hashes/argon2.d.ts.map +1 -0
  178. package/node_modules/@noble/hashes/argon2.js +391 -0
  179. package/node_modules/@noble/hashes/argon2.js.map +1 -0
  180. package/node_modules/@noble/hashes/blake1.d.ts +110 -0
  181. package/node_modules/@noble/hashes/blake1.d.ts.map +1 -0
  182. package/node_modules/@noble/hashes/blake1.js +485 -0
  183. package/node_modules/@noble/hashes/blake1.js.map +1 -0
  184. package/node_modules/@noble/hashes/blake2.d.ts +120 -0
  185. package/node_modules/@noble/hashes/blake2.d.ts.map +1 -0
  186. package/node_modules/@noble/hashes/blake2.js +417 -0
  187. package/node_modules/@noble/hashes/blake2.js.map +1 -0
  188. package/node_modules/@noble/hashes/blake3.d.ts +54 -0
  189. package/node_modules/@noble/hashes/blake3.d.ts.map +1 -0
  190. package/node_modules/@noble/hashes/blake3.js +255 -0
  191. package/node_modules/@noble/hashes/blake3.js.map +1 -0
  192. package/node_modules/@noble/hashes/eskdf.d.ts +50 -0
  193. package/node_modules/@noble/hashes/eskdf.d.ts.map +1 -0
  194. package/node_modules/@noble/hashes/eskdf.js +161 -0
  195. package/node_modules/@noble/hashes/eskdf.js.map +1 -0
  196. package/node_modules/@noble/hashes/hkdf.d.ts +36 -0
  197. package/node_modules/@noble/hashes/hkdf.d.ts.map +1 -0
  198. package/node_modules/@noble/hashes/hkdf.js +84 -0
  199. package/node_modules/@noble/hashes/hkdf.js.map +1 -0
  200. package/node_modules/@noble/hashes/hmac.d.ts +36 -0
  201. package/node_modules/@noble/hashes/hmac.d.ts.map +1 -0
  202. package/node_modules/@noble/hashes/hmac.js +90 -0
  203. package/node_modules/@noble/hashes/hmac.js.map +1 -0
  204. package/node_modules/@noble/hashes/index.d.ts +2 -0
  205. package/node_modules/@noble/hashes/index.d.ts.map +1 -0
  206. package/node_modules/@noble/hashes/index.js +34 -0
  207. package/node_modules/@noble/hashes/index.js.map +1 -0
  208. package/node_modules/@noble/hashes/legacy.d.ts +71 -0
  209. package/node_modules/@noble/hashes/legacy.d.ts.map +1 -0
  210. package/node_modules/@noble/hashes/legacy.js +281 -0
  211. package/node_modules/@noble/hashes/legacy.js.map +1 -0
  212. package/node_modules/@noble/hashes/package.json +93 -0
  213. package/node_modules/@noble/hashes/pbkdf2.d.ts +29 -0
  214. package/node_modules/@noble/hashes/pbkdf2.d.ts.map +1 -0
  215. package/node_modules/@noble/hashes/pbkdf2.js +97 -0
  216. package/node_modules/@noble/hashes/pbkdf2.js.map +1 -0
  217. package/node_modules/@noble/hashes/scrypt.d.ts +33 -0
  218. package/node_modules/@noble/hashes/scrypt.d.ts.map +1 -0
  219. package/node_modules/@noble/hashes/scrypt.js +216 -0
  220. package/node_modules/@noble/hashes/scrypt.js.map +1 -0
  221. package/node_modules/@noble/hashes/sha2.d.ts +199 -0
  222. package/node_modules/@noble/hashes/sha2.d.ts.map +1 -0
  223. package/node_modules/@noble/hashes/sha2.js +397 -0
  224. package/node_modules/@noble/hashes/sha2.js.map +1 -0
  225. package/node_modules/@noble/hashes/sha3-addons.d.ts +149 -0
  226. package/node_modules/@noble/hashes/sha3-addons.d.ts.map +1 -0
  227. package/node_modules/@noble/hashes/sha3-addons.js +420 -0
  228. package/node_modules/@noble/hashes/sha3-addons.js.map +1 -0
  229. package/node_modules/@noble/hashes/sha3.d.ts +58 -0
  230. package/node_modules/@noble/hashes/sha3.d.ts.map +1 -0
  231. package/node_modules/@noble/hashes/sha3.js +254 -0
  232. package/node_modules/@noble/hashes/sha3.js.map +1 -0
  233. package/node_modules/@noble/hashes/src/_blake.ts +50 -0
  234. package/node_modules/@noble/hashes/src/_md.ts +156 -0
  235. package/node_modules/@noble/hashes/src/_u64.ts +91 -0
  236. package/node_modules/@noble/hashes/src/argon2.ts +493 -0
  237. package/node_modules/@noble/hashes/src/blake1.ts +536 -0
  238. package/node_modules/@noble/hashes/src/blake2.ts +489 -0
  239. package/node_modules/@noble/hashes/src/blake3.ts +275 -0
  240. package/node_modules/@noble/hashes/src/eskdf.ts +188 -0
  241. package/node_modules/@noble/hashes/src/hkdf.ts +94 -0
  242. package/node_modules/@noble/hashes/src/hmac.ts +94 -0
  243. package/node_modules/@noble/hashes/src/index.ts +32 -0
  244. package/node_modules/@noble/hashes/src/legacy.ts +293 -0
  245. package/node_modules/@noble/hashes/src/pbkdf2.ts +129 -0
  246. package/node_modules/@noble/hashes/src/scrypt.ts +249 -0
  247. package/node_modules/@noble/hashes/src/sha2.ts +469 -0
  248. package/node_modules/@noble/hashes/src/sha3-addons.ts +530 -0
  249. package/node_modules/@noble/hashes/src/sha3.ts +295 -0
  250. package/node_modules/@noble/hashes/src/utils.ts +338 -0
  251. package/node_modules/@noble/hashes/src/webcrypto.ts +168 -0
  252. package/node_modules/@noble/hashes/utils.d.ts +130 -0
  253. package/node_modules/@noble/hashes/utils.d.ts.map +1 -0
  254. package/node_modules/@noble/hashes/utils.js +242 -0
  255. package/node_modules/@noble/hashes/utils.js.map +1 -0
  256. package/node_modules/@noble/hashes/webcrypto.d.ts +62 -0
  257. package/node_modules/@noble/hashes/webcrypto.d.ts.map +1 -0
  258. package/node_modules/@noble/hashes/webcrypto.js +126 -0
  259. package/node_modules/@noble/hashes/webcrypto.js.map +1 -0
  260. package/node_modules/@scure/base/LICENSE +21 -0
  261. package/node_modules/@scure/base/README.md +226 -0
  262. package/node_modules/@scure/base/index.d.ts +294 -0
  263. package/node_modules/@scure/base/index.d.ts.map +1 -0
  264. package/node_modules/@scure/base/index.js +704 -0
  265. package/node_modules/@scure/base/index.js.map +1 -0
  266. package/node_modules/@scure/base/index.ts +857 -0
  267. package/node_modules/@scure/base/package.json +58 -0
  268. package/node_modules/@scure/bip32/LICENSE +21 -0
  269. package/node_modules/@scure/bip32/README.md +158 -0
  270. package/node_modules/@scure/bip32/index.d.ts +60 -0
  271. package/node_modules/@scure/bip32/index.d.ts.map +1 -0
  272. package/node_modules/@scure/bip32/index.js +283 -0
  273. package/node_modules/@scure/bip32/index.js.map +1 -0
  274. package/node_modules/@scure/bip32/index.ts +317 -0
  275. package/node_modules/@scure/bip32/package.json +57 -0
  276. package/node_modules/@scure/bip39/LICENSE +21 -0
  277. package/node_modules/@scure/bip39/README.md +134 -0
  278. package/node_modules/@scure/bip39/index.d.ts +75 -0
  279. package/node_modules/@scure/bip39/index.js +149 -0
  280. package/node_modules/@scure/bip39/package.json +70 -0
  281. package/node_modules/@scure/bip39/src/index.ts +161 -0
  282. package/node_modules/@scure/bip39/wordlists/czech.d.ts +1 -0
  283. package/node_modules/@scure/bip39/wordlists/czech.js +2048 -0
  284. package/node_modules/@scure/bip39/wordlists/english.d.ts +1 -0
  285. package/node_modules/@scure/bip39/wordlists/english.js +2048 -0
  286. package/node_modules/@scure/bip39/wordlists/french.d.ts +1 -0
  287. package/node_modules/@scure/bip39/wordlists/french.js +2048 -0
  288. package/node_modules/@scure/bip39/wordlists/italian.d.ts +1 -0
  289. package/node_modules/@scure/bip39/wordlists/italian.js +2048 -0
  290. package/node_modules/@scure/bip39/wordlists/japanese.d.ts +1 -0
  291. package/node_modules/@scure/bip39/wordlists/japanese.js +2048 -0
  292. package/node_modules/@scure/bip39/wordlists/korean.d.ts +1 -0
  293. package/node_modules/@scure/bip39/wordlists/korean.js +2048 -0
  294. package/node_modules/@scure/bip39/wordlists/portuguese.d.ts +1 -0
  295. package/node_modules/@scure/bip39/wordlists/portuguese.js +2048 -0
  296. package/node_modules/@scure/bip39/wordlists/simplified-chinese.d.ts +1 -0
  297. package/node_modules/@scure/bip39/wordlists/simplified-chinese.js +2048 -0
  298. package/node_modules/@scure/bip39/wordlists/spanish.d.ts +1 -0
  299. package/node_modules/@scure/bip39/wordlists/spanish.js +2048 -0
  300. package/node_modules/@scure/bip39/wordlists/traditional-chinese.d.ts +1 -0
  301. package/node_modules/@scure/bip39/wordlists/traditional-chinese.js +2048 -0
  302. package/node_modules/nostr-tools/LICENSE +24 -0
  303. package/node_modules/nostr-tools/README.md +454 -0
  304. package/node_modules/nostr-tools/lib/cjs/abstract-pool.js +889 -0
  305. package/node_modules/nostr-tools/lib/cjs/abstract-pool.js.map +7 -0
  306. package/node_modules/nostr-tools/lib/cjs/abstract-relay.js +596 -0
  307. package/node_modules/nostr-tools/lib/cjs/abstract-relay.js.map +7 -0
  308. package/node_modules/nostr-tools/lib/cjs/core.js +63 -0
  309. package/node_modules/nostr-tools/lib/cjs/core.js.map +7 -0
  310. package/node_modules/nostr-tools/lib/cjs/fakejson.js +66 -0
  311. package/node_modules/nostr-tools/lib/cjs/fakejson.js.map +7 -0
  312. package/node_modules/nostr-tools/lib/cjs/filter.js +111 -0
  313. package/node_modules/nostr-tools/lib/cjs/filter.js.map +7 -0
  314. package/node_modules/nostr-tools/lib/cjs/index.js +3666 -0
  315. package/node_modules/nostr-tools/lib/cjs/index.js.map +7 -0
  316. package/node_modules/nostr-tools/lib/cjs/kinds.js +273 -0
  317. package/node_modules/nostr-tools/lib/cjs/kinds.js.map +7 -0
  318. package/node_modules/nostr-tools/lib/cjs/nip04.js +61 -0
  319. package/node_modules/nostr-tools/lib/cjs/nip04.js.map +7 -0
  320. package/node_modules/nostr-tools/lib/cjs/nip05.js +76 -0
  321. package/node_modules/nostr-tools/lib/cjs/nip05.js.map +7 -0
  322. package/node_modules/nostr-tools/lib/cjs/nip06.js +82 -0
  323. package/node_modules/nostr-tools/lib/cjs/nip06.js.map +7 -0
  324. package/node_modules/nostr-tools/lib/cjs/nip07.js +18 -0
  325. package/node_modules/nostr-tools/lib/cjs/nip07.js.map +7 -0
  326. package/node_modules/nostr-tools/lib/cjs/nip10.js +124 -0
  327. package/node_modules/nostr-tools/lib/cjs/nip10.js.map +7 -0
  328. package/node_modules/nostr-tools/lib/cjs/nip11.js +39 -0
  329. package/node_modules/nostr-tools/lib/cjs/nip11.js.map +7 -0
  330. package/node_modules/nostr-tools/lib/cjs/nip13.js +83 -0
  331. package/node_modules/nostr-tools/lib/cjs/nip13.js.map +7 -0
  332. package/node_modules/nostr-tools/lib/cjs/nip17.js +343 -0
  333. package/node_modules/nostr-tools/lib/cjs/nip17.js.map +7 -0
  334. package/node_modules/nostr-tools/lib/cjs/nip18.js +188 -0
  335. package/node_modules/nostr-tools/lib/cjs/nip18.js.map +7 -0
  336. package/node_modules/nostr-tools/lib/cjs/nip19.js +217 -0
  337. package/node_modules/nostr-tools/lib/cjs/nip19.js.map +7 -0
  338. package/node_modules/nostr-tools/lib/cjs/nip21.js +140 -0
  339. package/node_modules/nostr-tools/lib/cjs/nip21.js.map +7 -0
  340. package/node_modules/nostr-tools/lib/cjs/nip22.js +154 -0
  341. package/node_modules/nostr-tools/lib/cjs/nip22.js.map +7 -0
  342. package/node_modules/nostr-tools/lib/cjs/nip25.js +159 -0
  343. package/node_modules/nostr-tools/lib/cjs/nip25.js.map +7 -0
  344. package/node_modules/nostr-tools/lib/cjs/nip27.js +269 -0
  345. package/node_modules/nostr-tools/lib/cjs/nip27.js.map +7 -0
  346. package/node_modules/nostr-tools/lib/cjs/nip28.js +220 -0
  347. package/node_modules/nostr-tools/lib/cjs/nip28.js.map +7 -0
  348. package/node_modules/nostr-tools/lib/cjs/nip29.js +499 -0
  349. package/node_modules/nostr-tools/lib/cjs/nip29.js.map +7 -0
  350. package/node_modules/nostr-tools/lib/cjs/nip30.js +53 -0
  351. package/node_modules/nostr-tools/lib/cjs/nip30.js.map +7 -0
  352. package/node_modules/nostr-tools/lib/cjs/nip39.js +42 -0
  353. package/node_modules/nostr-tools/lib/cjs/nip39.js.map +7 -0
  354. package/node_modules/nostr-tools/lib/cjs/nip40.js +63 -0
  355. package/node_modules/nostr-tools/lib/cjs/nip40.js.map +7 -0
  356. package/node_modules/nostr-tools/lib/cjs/nip42.js +41 -0
  357. package/node_modules/nostr-tools/lib/cjs/nip42.js.map +7 -0
  358. package/node_modules/nostr-tools/lib/cjs/nip44.js +167 -0
  359. package/node_modules/nostr-tools/lib/cjs/nip44.js.map +7 -0
  360. package/node_modules/nostr-tools/lib/cjs/nip46.js +1455 -0
  361. package/node_modules/nostr-tools/lib/cjs/nip46.js.map +7 -0
  362. package/node_modules/nostr-tools/lib/cjs/nip47.js +168 -0
  363. package/node_modules/nostr-tools/lib/cjs/nip47.js.map +7 -0
  364. package/node_modules/nostr-tools/lib/cjs/nip49.js +77 -0
  365. package/node_modules/nostr-tools/lib/cjs/nip49.js.map +7 -0
  366. package/node_modules/nostr-tools/lib/cjs/nip54.js +35 -0
  367. package/node_modules/nostr-tools/lib/cjs/nip54.js.map +7 -0
  368. package/node_modules/nostr-tools/lib/cjs/nip55.js +103 -0
  369. package/node_modules/nostr-tools/lib/cjs/nip55.js.map +7 -0
  370. package/node_modules/nostr-tools/lib/cjs/nip57.js +274 -0
  371. package/node_modules/nostr-tools/lib/cjs/nip57.js.map +7 -0
  372. package/node_modules/nostr-tools/lib/cjs/nip58.js +117 -0
  373. package/node_modules/nostr-tools/lib/cjs/nip58.js.map +7 -0
  374. package/node_modules/nostr-tools/lib/cjs/nip59.js +320 -0
  375. package/node_modules/nostr-tools/lib/cjs/nip59.js.map +7 -0
  376. package/node_modules/nostr-tools/lib/cjs/nip75.js +70 -0
  377. package/node_modules/nostr-tools/lib/cjs/nip75.js.map +7 -0
  378. package/node_modules/nostr-tools/lib/cjs/nip77.js +519 -0
  379. package/node_modules/nostr-tools/lib/cjs/nip77.js.map +7 -0
  380. package/node_modules/nostr-tools/lib/cjs/nip94.js +142 -0
  381. package/node_modules/nostr-tools/lib/cjs/nip94.js.map +7 -0
  382. package/node_modules/nostr-tools/lib/cjs/nip98.js +230 -0
  383. package/node_modules/nostr-tools/lib/cjs/nip98.js.map +7 -0
  384. package/node_modules/nostr-tools/lib/cjs/nip99.js +153 -0
  385. package/node_modules/nostr-tools/lib/cjs/nip99.js.map +7 -0
  386. package/node_modules/nostr-tools/lib/cjs/nipb7.js +184 -0
  387. package/node_modules/nostr-tools/lib/cjs/nipb7.js.map +7 -0
  388. package/node_modules/nostr-tools/lib/cjs/package.json +1 -0
  389. package/node_modules/nostr-tools/lib/cjs/pool.js +989 -0
  390. package/node_modules/nostr-tools/lib/cjs/pool.js.map +7 -0
  391. package/node_modules/nostr-tools/lib/cjs/pure.js +130 -0
  392. package/node_modules/nostr-tools/lib/cjs/pure.js.map +7 -0
  393. package/node_modules/nostr-tools/lib/cjs/references.js +210 -0
  394. package/node_modules/nostr-tools/lib/cjs/references.js.map +7 -0
  395. package/node_modules/nostr-tools/lib/cjs/relay.js +704 -0
  396. package/node_modules/nostr-tools/lib/cjs/relay.js.map +7 -0
  397. package/node_modules/nostr-tools/lib/cjs/signer.js +130 -0
  398. package/node_modules/nostr-tools/lib/cjs/signer.js.map +7 -0
  399. package/node_modules/nostr-tools/lib/cjs/utils.js +150 -0
  400. package/node_modules/nostr-tools/lib/cjs/utils.js.map +7 -0
  401. package/node_modules/nostr-tools/lib/cjs/wasm.js +103 -0
  402. package/node_modules/nostr-tools/lib/cjs/wasm.js.map +7 -0
  403. package/node_modules/nostr-tools/lib/esm/abstract-pool.js +866 -0
  404. package/node_modules/nostr-tools/lib/esm/abstract-pool.js.map +7 -0
  405. package/node_modules/nostr-tools/lib/esm/abstract-relay.js +573 -0
  406. package/node_modules/nostr-tools/lib/esm/abstract-relay.js.map +7 -0
  407. package/node_modules/nostr-tools/lib/esm/core.js +42 -0
  408. package/node_modules/nostr-tools/lib/esm/core.js.map +7 -0
  409. package/node_modules/nostr-tools/lib/esm/fakejson.js +45 -0
  410. package/node_modules/nostr-tools/lib/esm/fakejson.js.map +7 -0
  411. package/node_modules/nostr-tools/lib/esm/filter.js +88 -0
  412. package/node_modules/nostr-tools/lib/esm/filter.js.map +7 -0
  413. package/node_modules/nostr-tools/lib/esm/index.js +3649 -0
  414. package/node_modules/nostr-tools/lib/esm/index.js.map +7 -0
  415. package/node_modules/nostr-tools/lib/esm/kinds.js +250 -0
  416. package/node_modules/nostr-tools/lib/esm/kinds.js.map +7 -0
  417. package/node_modules/nostr-tools/lib/esm/nip04.js +40 -0
  418. package/node_modules/nostr-tools/lib/esm/nip04.js.map +7 -0
  419. package/node_modules/nostr-tools/lib/esm/nip05.js +55 -0
  420. package/node_modules/nostr-tools/lib/esm/nip05.js.map +7 -0
  421. package/node_modules/nostr-tools/lib/esm/nip06.js +61 -0
  422. package/node_modules/nostr-tools/lib/esm/nip06.js.map +7 -0
  423. package/node_modules/nostr-tools/lib/esm/nip07.js +0 -0
  424. package/node_modules/nostr-tools/lib/esm/nip07.js.map +7 -0
  425. package/node_modules/nostr-tools/lib/esm/nip10.js +103 -0
  426. package/node_modules/nostr-tools/lib/esm/nip10.js.map +7 -0
  427. package/node_modules/nostr-tools/lib/esm/nip11.js +18 -0
  428. package/node_modules/nostr-tools/lib/esm/nip11.js.map +7 -0
  429. package/node_modules/nostr-tools/lib/esm/nip13.js +62 -0
  430. package/node_modules/nostr-tools/lib/esm/nip13.js.map +7 -0
  431. package/node_modules/nostr-tools/lib/esm/nip17.js +320 -0
  432. package/node_modules/nostr-tools/lib/esm/nip17.js.map +7 -0
  433. package/node_modules/nostr-tools/lib/esm/nip18.js +165 -0
  434. package/node_modules/nostr-tools/lib/esm/nip18.js.map +7 -0
  435. package/node_modules/nostr-tools/lib/esm/nip19.js +196 -0
  436. package/node_modules/nostr-tools/lib/esm/nip19.js.map +7 -0
  437. package/node_modules/nostr-tools/lib/esm/nip21.js +117 -0
  438. package/node_modules/nostr-tools/lib/esm/nip21.js.map +7 -0
  439. package/node_modules/nostr-tools/lib/esm/nip22.js +133 -0
  440. package/node_modules/nostr-tools/lib/esm/nip22.js.map +7 -0
  441. package/node_modules/nostr-tools/lib/esm/nip25.js +136 -0
  442. package/node_modules/nostr-tools/lib/esm/nip25.js.map +7 -0
  443. package/node_modules/nostr-tools/lib/esm/nip27.js +246 -0
  444. package/node_modules/nostr-tools/lib/esm/nip27.js.map +7 -0
  445. package/node_modules/nostr-tools/lib/esm/nip28.js +197 -0
  446. package/node_modules/nostr-tools/lib/esm/nip28.js.map +7 -0
  447. package/node_modules/nostr-tools/lib/esm/nip29.js +476 -0
  448. package/node_modules/nostr-tools/lib/esm/nip29.js.map +7 -0
  449. package/node_modules/nostr-tools/lib/esm/nip30.js +32 -0
  450. package/node_modules/nostr-tools/lib/esm/nip30.js.map +7 -0
  451. package/node_modules/nostr-tools/lib/esm/nip39.js +21 -0
  452. package/node_modules/nostr-tools/lib/esm/nip39.js.map +7 -0
  453. package/node_modules/nostr-tools/lib/esm/nip40.js +42 -0
  454. package/node_modules/nostr-tools/lib/esm/nip40.js.map +7 -0
  455. package/node_modules/nostr-tools/lib/esm/nip42.js +18 -0
  456. package/node_modules/nostr-tools/lib/esm/nip42.js.map +7 -0
  457. package/node_modules/nostr-tools/lib/esm/nip44.js +146 -0
  458. package/node_modules/nostr-tools/lib/esm/nip44.js.map +7 -0
  459. package/node_modules/nostr-tools/lib/esm/nip46.js +1432 -0
  460. package/node_modules/nostr-tools/lib/esm/nip46.js.map +7 -0
  461. package/node_modules/nostr-tools/lib/esm/nip47.js +145 -0
  462. package/node_modules/nostr-tools/lib/esm/nip47.js.map +7 -0
  463. package/node_modules/nostr-tools/lib/esm/nip49.js +56 -0
  464. package/node_modules/nostr-tools/lib/esm/nip49.js.map +7 -0
  465. package/node_modules/nostr-tools/lib/esm/nip54.js +14 -0
  466. package/node_modules/nostr-tools/lib/esm/nip54.js.map +7 -0
  467. package/node_modules/nostr-tools/lib/esm/nip55.js +82 -0
  468. package/node_modules/nostr-tools/lib/esm/nip55.js.map +7 -0
  469. package/node_modules/nostr-tools/lib/esm/nip57.js +253 -0
  470. package/node_modules/nostr-tools/lib/esm/nip57.js.map +7 -0
  471. package/node_modules/nostr-tools/lib/esm/nip58.js +94 -0
  472. package/node_modules/nostr-tools/lib/esm/nip58.js.map +7 -0
  473. package/node_modules/nostr-tools/lib/esm/nip59.js +297 -0
  474. package/node_modules/nostr-tools/lib/esm/nip59.js.map +7 -0
  475. package/node_modules/nostr-tools/lib/esm/nip75.js +47 -0
  476. package/node_modules/nostr-tools/lib/esm/nip75.js.map +7 -0
  477. package/node_modules/nostr-tools/lib/esm/nip77.js +498 -0
  478. package/node_modules/nostr-tools/lib/esm/nip77.js.map +7 -0
  479. package/node_modules/nostr-tools/lib/esm/nip94.js +119 -0
  480. package/node_modules/nostr-tools/lib/esm/nip94.js.map +7 -0
  481. package/node_modules/nostr-tools/lib/esm/nip98.js +209 -0
  482. package/node_modules/nostr-tools/lib/esm/nip98.js.map +7 -0
  483. package/node_modules/nostr-tools/lib/esm/nip99.js +130 -0
  484. package/node_modules/nostr-tools/lib/esm/nip99.js.map +7 -0
  485. package/node_modules/nostr-tools/lib/esm/nipb7.js +163 -0
  486. package/node_modules/nostr-tools/lib/esm/nipb7.js.map +7 -0
  487. package/node_modules/nostr-tools/lib/esm/pool.js +966 -0
  488. package/node_modules/nostr-tools/lib/esm/pool.js.map +7 -0
  489. package/node_modules/nostr-tools/lib/esm/pure.js +109 -0
  490. package/node_modules/nostr-tools/lib/esm/pure.js.map +7 -0
  491. package/node_modules/nostr-tools/lib/esm/references.js +187 -0
  492. package/node_modules/nostr-tools/lib/esm/references.js.map +7 -0
  493. package/node_modules/nostr-tools/lib/esm/relay.js +681 -0
  494. package/node_modules/nostr-tools/lib/esm/relay.js.map +7 -0
  495. package/node_modules/nostr-tools/lib/esm/signer.js +107 -0
  496. package/node_modules/nostr-tools/lib/esm/signer.js.map +7 -0
  497. package/node_modules/nostr-tools/lib/esm/utils.js +129 -0
  498. package/node_modules/nostr-tools/lib/esm/utils.js.map +7 -0
  499. package/node_modules/nostr-tools/lib/esm/wasm.js +82 -0
  500. package/node_modules/nostr-tools/lib/esm/wasm.js.map +7 -0
  501. package/node_modules/nostr-tools/lib/nostr.bundle.js +7336 -0
  502. package/node_modules/nostr-tools/lib/nostr.bundle.js.map +7 -0
  503. package/node_modules/nostr-tools/lib/types/abstract-pool.d.ts +60 -0
  504. package/node_modules/nostr-tools/lib/types/abstract-relay.d.ts +110 -0
  505. package/node_modules/nostr-tools/lib/types/benchmarks.d.ts +1 -0
  506. package/node_modules/nostr-tools/lib/types/core.d.ts +32 -0
  507. package/node_modules/nostr-tools/lib/types/core.test.d.ts +1 -0
  508. package/node_modules/nostr-tools/lib/types/fakejson.d.ts +6 -0
  509. package/node_modules/nostr-tools/lib/types/fakejson.test.d.ts +1 -0
  510. package/node_modules/nostr-tools/lib/types/filter.d.ts +19 -0
  511. package/node_modules/nostr-tools/lib/types/filter.test.d.ts +1 -0
  512. package/node_modules/nostr-tools/lib/types/helpers.d.ts +2 -0
  513. package/node_modules/nostr-tools/lib/types/index.d.ts +31 -0
  514. package/node_modules/nostr-tools/lib/types/kinds.d.ts +200 -0
  515. package/node_modules/nostr-tools/lib/types/kinds.test.d.ts +1 -0
  516. package/node_modules/nostr-tools/lib/types/nip04.d.ts +2 -0
  517. package/node_modules/nostr-tools/lib/types/nip04.test.d.ts +1 -0
  518. package/node_modules/nostr-tools/lib/types/nip05.d.ts +17 -0
  519. package/node_modules/nostr-tools/lib/types/nip05.test.d.ts +1 -0
  520. package/node_modules/nostr-tools/lib/types/nip06.d.ts +15 -0
  521. package/node_modules/nostr-tools/lib/types/nip06.test.d.ts +1 -0
  522. package/node_modules/nostr-tools/lib/types/nip07.d.ts +13 -0
  523. package/node_modules/nostr-tools/lib/types/nip10.d.ts +24 -0
  524. package/node_modules/nostr-tools/lib/types/nip10.test.d.ts +1 -0
  525. package/node_modules/nostr-tools/lib/types/nip11.d.ts +266 -0
  526. package/node_modules/nostr-tools/lib/types/nip11.test.d.ts +1 -0
  527. package/node_modules/nostr-tools/lib/types/nip13.d.ts +8 -0
  528. package/node_modules/nostr-tools/lib/types/nip13.test.d.ts +1 -0
  529. package/node_modules/nostr-tools/lib/types/nip17.d.ts +15 -0
  530. package/node_modules/nostr-tools/lib/types/nip17.test.d.ts +1 -0
  531. package/node_modules/nostr-tools/lib/types/nip18.d.ts +22 -0
  532. package/node_modules/nostr-tools/lib/types/nip18.test.d.ts +1 -0
  533. package/node_modules/nostr-tools/lib/types/nip19.d.ts +81 -0
  534. package/node_modules/nostr-tools/lib/types/nip19.test.d.ts +1 -0
  535. package/node_modules/nostr-tools/lib/types/nip21.d.ts +34 -0
  536. package/node_modules/nostr-tools/lib/types/nip21.test.d.ts +1 -0
  537. package/node_modules/nostr-tools/lib/types/nip22.d.ts +36 -0
  538. package/node_modules/nostr-tools/lib/types/nip22.test.d.ts +1 -0
  539. package/node_modules/nostr-tools/lib/types/nip25.d.ts +15 -0
  540. package/node_modules/nostr-tools/lib/types/nip25.test.d.ts +1 -0
  541. package/node_modules/nostr-tools/lib/types/nip27.d.ts +32 -0
  542. package/node_modules/nostr-tools/lib/types/nip27.test.d.ts +1 -0
  543. package/node_modules/nostr-tools/lib/types/nip28.d.ts +46 -0
  544. package/node_modules/nostr-tools/lib/types/nip28.test.d.ts +1 -0
  545. package/node_modules/nostr-tools/lib/types/nip29.d.ts +265 -0
  546. package/node_modules/nostr-tools/lib/types/nip30.d.ts +22 -0
  547. package/node_modules/nostr-tools/lib/types/nip30.test.d.ts +1 -0
  548. package/node_modules/nostr-tools/lib/types/nip39.d.ts +2 -0
  549. package/node_modules/nostr-tools/lib/types/nip39.test.d.ts +1 -0
  550. package/node_modules/nostr-tools/lib/types/nip40.d.ts +10 -0
  551. package/node_modules/nostr-tools/lib/types/nip40.test.d.ts +1 -0
  552. package/node_modules/nostr-tools/lib/types/nip42.d.ts +5 -0
  553. package/node_modules/nostr-tools/lib/types/nip42.test.d.ts +1 -0
  554. package/node_modules/nostr-tools/lib/types/nip44.d.ts +18 -0
  555. package/node_modules/nostr-tools/lib/types/nip44.test.d.ts +1 -0
  556. package/node_modules/nostr-tools/lib/types/nip46.d.ts +119 -0
  557. package/node_modules/nostr-tools/lib/types/nip47.d.ts +11 -0
  558. package/node_modules/nostr-tools/lib/types/nip47.test.d.ts +1 -0
  559. package/node_modules/nostr-tools/lib/types/nip49.d.ts +3 -0
  560. package/node_modules/nostr-tools/lib/types/nip49.test.d.ts +1 -0
  561. package/node_modules/nostr-tools/lib/types/nip54.d.ts +1 -0
  562. package/node_modules/nostr-tools/lib/types/nip54.test.d.ts +1 -0
  563. package/node_modules/nostr-tools/lib/types/nip55.d.ts +30 -0
  564. package/node_modules/nostr-tools/lib/types/nip55.test.d.ts +1 -0
  565. package/node_modules/nostr-tools/lib/types/nip57.d.ts +25 -0
  566. package/node_modules/nostr-tools/lib/types/nip57.test.d.ts +1 -0
  567. package/node_modules/nostr-tools/lib/types/nip58.d.ts +134 -0
  568. package/node_modules/nostr-tools/lib/types/nip58.test.d.ts +1 -0
  569. package/node_modules/nostr-tools/lib/types/nip59.d.ts +12 -0
  570. package/node_modules/nostr-tools/lib/types/nip59.test.d.ts +1 -0
  571. package/node_modules/nostr-tools/lib/types/nip75.d.ts +61 -0
  572. package/node_modules/nostr-tools/lib/types/nip75.test.d.ts +1 -0
  573. package/node_modules/nostr-tools/lib/types/nip77.d.ts +102 -0
  574. package/node_modules/nostr-tools/lib/types/nip77.test.d.ts +1 -0
  575. package/node_modules/nostr-tools/lib/types/nip94.d.ts +87 -0
  576. package/node_modules/nostr-tools/lib/types/nip94.test.d.ts +1 -0
  577. package/node_modules/nostr-tools/lib/types/nip98.d.ts +74 -0
  578. package/node_modules/nostr-tools/lib/types/nip98.test.d.ts +1 -0
  579. package/node_modules/nostr-tools/lib/types/nip99.d.ts +92 -0
  580. package/node_modules/nostr-tools/lib/types/nip99.test.d.ts +1 -0
  581. package/node_modules/nostr-tools/lib/types/nipb7.d.ts +23 -0
  582. package/node_modules/nostr-tools/lib/types/nipb7.test.d.ts +1 -0
  583. package/node_modules/nostr-tools/lib/types/pool.d.ts +6 -0
  584. package/node_modules/nostr-tools/lib/types/pool.test.d.ts +1 -0
  585. package/node_modules/nostr-tools/lib/types/pure.d.ts +8 -0
  586. package/node_modules/nostr-tools/lib/types/pure.test.d.ts +1 -0
  587. package/node_modules/nostr-tools/lib/types/references.d.ts +10 -0
  588. package/node_modules/nostr-tools/lib/types/references.test.d.ts +1 -0
  589. package/node_modules/nostr-tools/lib/types/relay.d.ts +11 -0
  590. package/node_modules/nostr-tools/lib/types/relay.test.d.ts +1 -0
  591. package/node_modules/nostr-tools/lib/types/signer.d.ts +11 -0
  592. package/node_modules/nostr-tools/lib/types/test-helpers.d.ts +14 -0
  593. package/node_modules/nostr-tools/lib/types/utils.d.ts +9 -0
  594. package/node_modules/nostr-tools/lib/types/utils.test.d.ts +1 -0
  595. package/node_modules/nostr-tools/lib/types/wasm.d.ts +8 -0
  596. package/node_modules/nostr-tools/package.json +330 -0
  597. package/node_modules/nostr-wasm/README.md +91 -0
  598. package/node_modules/nostr-wasm/dist/api/emsimp.d.ts +3 -0
  599. package/node_modules/nostr-wasm/dist/api/nostr.d.ts +45 -0
  600. package/node_modules/nostr-wasm/dist/api/secp256k1-types.d.ts +124 -0
  601. package/node_modules/nostr-wasm/dist/api/secp256k1.d.ts +41 -0
  602. package/node_modules/nostr-wasm/dist/api/types.d.ts +124 -0
  603. package/node_modules/nostr-wasm/dist/api/wasm-env.d.ts +3 -0
  604. package/node_modules/nostr-wasm/dist/gen/wasm.d.ts +27 -0
  605. package/node_modules/nostr-wasm/dist/generate.d.ts +1 -0
  606. package/node_modules/nostr-wasm/dist/gzipped.d.ts +3 -0
  607. package/node_modules/nostr-wasm/dist/gzipped.js +44 -0
  608. package/node_modules/nostr-wasm/dist/headless.d.ts +2 -0
  609. package/node_modules/nostr-wasm/dist/main.d.ts +3 -0
  610. package/node_modules/nostr-wasm/dist/main.js +9 -0
  611. package/node_modules/nostr-wasm/dist/nostr.js +248 -0
  612. package/node_modules/nostr-wasm/dist/secp256k1.js +230 -0
  613. package/node_modules/nostr-wasm/dist/types.d.ts +22 -0
  614. package/node_modules/nostr-wasm/package.json +37 -0
  615. package/node_modules/nostr-wasm/public/out/secp256k1.js +1 -0
  616. package/node_modules/nostr-wasm/public/out/secp256k1.wasm +0 -0
  617. package/node_modules/zod/LICENSE +21 -0
  618. package/node_modules/zod/README.md +191 -0
  619. package/node_modules/zod/index.cjs +33 -0
  620. package/node_modules/zod/index.d.cts +4 -0
  621. package/node_modules/zod/index.d.ts +4 -0
  622. package/node_modules/zod/index.js +4 -0
  623. package/node_modules/zod/locales/index.cjs +17 -0
  624. package/node_modules/zod/locales/index.d.cts +1 -0
  625. package/node_modules/zod/locales/index.d.ts +1 -0
  626. package/node_modules/zod/locales/index.js +1 -0
  627. package/node_modules/zod/locales/package.json +7 -0
  628. package/node_modules/zod/mini/index.cjs +32 -0
  629. package/node_modules/zod/mini/index.d.cts +3 -0
  630. package/node_modules/zod/mini/index.d.ts +3 -0
  631. package/node_modules/zod/mini/index.js +3 -0
  632. package/node_modules/zod/mini/package.json +7 -0
  633. package/node_modules/zod/package.json +135 -0
  634. package/node_modules/zod/src/index.ts +4 -0
  635. package/node_modules/zod/src/locales/index.ts +1 -0
  636. package/node_modules/zod/src/mini/index.ts +3 -0
  637. package/node_modules/zod/src/v3/ZodError.ts +330 -0
  638. package/node_modules/zod/src/v3/benchmarks/datetime.ts +58 -0
  639. package/node_modules/zod/src/v3/benchmarks/discriminatedUnion.ts +80 -0
  640. package/node_modules/zod/src/v3/benchmarks/index.ts +59 -0
  641. package/node_modules/zod/src/v3/benchmarks/ipv4.ts +57 -0
  642. package/node_modules/zod/src/v3/benchmarks/object.ts +69 -0
  643. package/node_modules/zod/src/v3/benchmarks/primitives.ts +162 -0
  644. package/node_modules/zod/src/v3/benchmarks/realworld.ts +63 -0
  645. package/node_modules/zod/src/v3/benchmarks/string.ts +55 -0
  646. package/node_modules/zod/src/v3/benchmarks/union.ts +80 -0
  647. package/node_modules/zod/src/v3/errors.ts +13 -0
  648. package/node_modules/zod/src/v3/external.ts +6 -0
  649. package/node_modules/zod/src/v3/helpers/enumUtil.ts +17 -0
  650. package/node_modules/zod/src/v3/helpers/errorUtil.ts +8 -0
  651. package/node_modules/zod/src/v3/helpers/parseUtil.ts +176 -0
  652. package/node_modules/zod/src/v3/helpers/partialUtil.ts +34 -0
  653. package/node_modules/zod/src/v3/helpers/typeAliases.ts +2 -0
  654. package/node_modules/zod/src/v3/helpers/util.ts +224 -0
  655. package/node_modules/zod/src/v3/index.ts +4 -0
  656. package/node_modules/zod/src/v3/locales/en.ts +124 -0
  657. package/node_modules/zod/src/v3/standard-schema.ts +113 -0
  658. package/node_modules/zod/src/v3/tests/Mocker.ts +54 -0
  659. package/node_modules/zod/src/v3/tests/all-errors.test.ts +157 -0
  660. package/node_modules/zod/src/v3/tests/anyunknown.test.ts +28 -0
  661. package/node_modules/zod/src/v3/tests/array.test.ts +71 -0
  662. package/node_modules/zod/src/v3/tests/async-parsing.test.ts +388 -0
  663. package/node_modules/zod/src/v3/tests/async-refinements.test.ts +46 -0
  664. package/node_modules/zod/src/v3/tests/base.test.ts +29 -0
  665. package/node_modules/zod/src/v3/tests/bigint.test.ts +55 -0
  666. package/node_modules/zod/src/v3/tests/branded.test.ts +53 -0
  667. package/node_modules/zod/src/v3/tests/catch.test.ts +220 -0
  668. package/node_modules/zod/src/v3/tests/coerce.test.ts +133 -0
  669. package/node_modules/zod/src/v3/tests/complex.test.ts +70 -0
  670. package/node_modules/zod/src/v3/tests/custom.test.ts +31 -0
  671. package/node_modules/zod/src/v3/tests/date.test.ts +32 -0
  672. package/node_modules/zod/src/v3/tests/deepmasking.test.ts +186 -0
  673. package/node_modules/zod/src/v3/tests/default.test.ts +112 -0
  674. package/node_modules/zod/src/v3/tests/description.test.ts +33 -0
  675. package/node_modules/zod/src/v3/tests/discriminated-unions.test.ts +315 -0
  676. package/node_modules/zod/src/v3/tests/enum.test.ts +80 -0
  677. package/node_modules/zod/src/v3/tests/error.test.ts +551 -0
  678. package/node_modules/zod/src/v3/tests/firstparty.test.ts +87 -0
  679. package/node_modules/zod/src/v3/tests/firstpartyschematypes.test.ts +21 -0
  680. package/node_modules/zod/src/v3/tests/function.test.ts +261 -0
  681. package/node_modules/zod/src/v3/tests/generics.test.ts +48 -0
  682. package/node_modules/zod/src/v3/tests/instanceof.test.ts +37 -0
  683. package/node_modules/zod/src/v3/tests/intersection.test.ts +110 -0
  684. package/node_modules/zod/src/v3/tests/language-server.source.ts +76 -0
  685. package/node_modules/zod/src/v3/tests/language-server.test.ts +207 -0
  686. package/node_modules/zod/src/v3/tests/literal.test.ts +36 -0
  687. package/node_modules/zod/src/v3/tests/map.test.ts +110 -0
  688. package/node_modules/zod/src/v3/tests/masking.test.ts +4 -0
  689. package/node_modules/zod/src/v3/tests/mocker.test.ts +19 -0
  690. package/node_modules/zod/src/v3/tests/nan.test.ts +24 -0
  691. package/node_modules/zod/src/v3/tests/nativeEnum.test.ts +87 -0
  692. package/node_modules/zod/src/v3/tests/nullable.test.ts +42 -0
  693. package/node_modules/zod/src/v3/tests/number.test.ts +176 -0
  694. package/node_modules/zod/src/v3/tests/object-augmentation.test.ts +29 -0
  695. package/node_modules/zod/src/v3/tests/object-in-es5-env.test.ts +29 -0
  696. package/node_modules/zod/src/v3/tests/object.test.ts +434 -0
  697. package/node_modules/zod/src/v3/tests/optional.test.ts +42 -0
  698. package/node_modules/zod/src/v3/tests/parseUtil.test.ts +23 -0
  699. package/node_modules/zod/src/v3/tests/parser.test.ts +41 -0
  700. package/node_modules/zod/src/v3/tests/partials.test.ts +243 -0
  701. package/node_modules/zod/src/v3/tests/pickomit.test.ts +111 -0
  702. package/node_modules/zod/src/v3/tests/pipeline.test.ts +29 -0
  703. package/node_modules/zod/src/v3/tests/preprocess.test.ts +186 -0
  704. package/node_modules/zod/src/v3/tests/primitive.test.ts +440 -0
  705. package/node_modules/zod/src/v3/tests/promise.test.ts +90 -0
  706. package/node_modules/zod/src/v3/tests/readonly.test.ts +194 -0
  707. package/node_modules/zod/src/v3/tests/record.test.ts +171 -0
  708. package/node_modules/zod/src/v3/tests/recursive.test.ts +197 -0
  709. package/node_modules/zod/src/v3/tests/refine.test.ts +313 -0
  710. package/node_modules/zod/src/v3/tests/safeparse.test.ts +27 -0
  711. package/node_modules/zod/src/v3/tests/set.test.ts +142 -0
  712. package/node_modules/zod/src/v3/tests/standard-schema.test.ts +83 -0
  713. package/node_modules/zod/src/v3/tests/string.test.ts +916 -0
  714. package/node_modules/zod/src/v3/tests/transformer.test.ts +233 -0
  715. package/node_modules/zod/src/v3/tests/tuple.test.ts +90 -0
  716. package/node_modules/zod/src/v3/tests/unions.test.ts +57 -0
  717. package/node_modules/zod/src/v3/tests/validations.test.ts +133 -0
  718. package/node_modules/zod/src/v3/tests/void.test.ts +15 -0
  719. package/node_modules/zod/src/v3/types.ts +5138 -0
  720. package/node_modules/zod/src/v4/classic/checks.ts +32 -0
  721. package/node_modules/zod/src/v4/classic/coerce.ts +27 -0
  722. package/node_modules/zod/src/v4/classic/compat.ts +70 -0
  723. package/node_modules/zod/src/v4/classic/errors.ts +82 -0
  724. package/node_modules/zod/src/v4/classic/external.ts +52 -0
  725. package/node_modules/zod/src/v4/classic/from-json-schema.ts +659 -0
  726. package/node_modules/zod/src/v4/classic/index.ts +5 -0
  727. package/node_modules/zod/src/v4/classic/iso.ts +90 -0
  728. package/node_modules/zod/src/v4/classic/parse.ts +82 -0
  729. package/node_modules/zod/src/v4/classic/schemas.ts +2672 -0
  730. package/node_modules/zod/src/v4/classic/tests/anyunknown.test.ts +26 -0
  731. package/node_modules/zod/src/v4/classic/tests/apply.test.ts +59 -0
  732. package/node_modules/zod/src/v4/classic/tests/array.test.ts +264 -0
  733. package/node_modules/zod/src/v4/classic/tests/assignability.test.ts +216 -0
  734. package/node_modules/zod/src/v4/classic/tests/async-parsing.test.ts +381 -0
  735. package/node_modules/zod/src/v4/classic/tests/async-refinements.test.ts +68 -0
  736. package/node_modules/zod/src/v4/classic/tests/base.test.ts +7 -0
  737. package/node_modules/zod/src/v4/classic/tests/bigint.test.ts +54 -0
  738. package/node_modules/zod/src/v4/classic/tests/brand.test.ts +106 -0
  739. package/node_modules/zod/src/v4/classic/tests/catch.test.ts +326 -0
  740. package/node_modules/zod/src/v4/classic/tests/coalesce.test.ts +20 -0
  741. package/node_modules/zod/src/v4/classic/tests/codec-examples.test.ts +573 -0
  742. package/node_modules/zod/src/v4/classic/tests/codec.test.ts +703 -0
  743. package/node_modules/zod/src/v4/classic/tests/coerce.test.ts +160 -0
  744. package/node_modules/zod/src/v4/classic/tests/continuability.test.ts +374 -0
  745. package/node_modules/zod/src/v4/classic/tests/custom.test.ts +40 -0
  746. package/node_modules/zod/src/v4/classic/tests/date.test.ts +62 -0
  747. package/node_modules/zod/src/v4/classic/tests/datetime.test.ts +302 -0
  748. package/node_modules/zod/src/v4/classic/tests/default.test.ts +409 -0
  749. package/node_modules/zod/src/v4/classic/tests/describe-meta-checks.test.ts +27 -0
  750. package/node_modules/zod/src/v4/classic/tests/description.test.ts +32 -0
  751. package/node_modules/zod/src/v4/classic/tests/detached-methods.test.ts +197 -0
  752. package/node_modules/zod/src/v4/classic/tests/discriminated-unions.test.ts +694 -0
  753. package/node_modules/zod/src/v4/classic/tests/enum.test.ts +285 -0
  754. package/node_modules/zod/src/v4/classic/tests/error-utils.test.ts +807 -0
  755. package/node_modules/zod/src/v4/classic/tests/error.test.ts +711 -0
  756. package/node_modules/zod/src/v4/classic/tests/file.test.ts +96 -0
  757. package/node_modules/zod/src/v4/classic/tests/firstparty.test.ts +179 -0
  758. package/node_modules/zod/src/v4/classic/tests/fix-json-issue.test.ts +26 -0
  759. package/node_modules/zod/src/v4/classic/tests/from-json-schema.test.ts +895 -0
  760. package/node_modules/zod/src/v4/classic/tests/function.test.ts +360 -0
  761. package/node_modules/zod/src/v4/classic/tests/generics.test.ts +72 -0
  762. package/node_modules/zod/src/v4/classic/tests/global-config.test.ts +39 -0
  763. package/node_modules/zod/src/v4/classic/tests/hash.test.ts +68 -0
  764. package/node_modules/zod/src/v4/classic/tests/index.test.ts +939 -0
  765. package/node_modules/zod/src/v4/classic/tests/instanceof.test.ts +60 -0
  766. package/node_modules/zod/src/v4/classic/tests/intersection.test.ts +198 -0
  767. package/node_modules/zod/src/v4/classic/tests/jitless-allows-eval.test.ts +46 -0
  768. package/node_modules/zod/src/v4/classic/tests/json.test.ts +109 -0
  769. package/node_modules/zod/src/v4/classic/tests/lazy.test.ts +227 -0
  770. package/node_modules/zod/src/v4/classic/tests/literal.test.ts +117 -0
  771. package/node_modules/zod/src/v4/classic/tests/locales_ka.test.ts +29 -0
  772. package/node_modules/zod/src/v4/classic/tests/locales_ro.test.ts +24 -0
  773. package/node_modules/zod/src/v4/classic/tests/map.test.ts +330 -0
  774. package/node_modules/zod/src/v4/classic/tests/nan.test.ts +21 -0
  775. package/node_modules/zod/src/v4/classic/tests/nested-refine.test.ts +168 -0
  776. package/node_modules/zod/src/v4/classic/tests/nonoptional.test.ts +101 -0
  777. package/node_modules/zod/src/v4/classic/tests/nullable.test.ts +22 -0
  778. package/node_modules/zod/src/v4/classic/tests/number.test.ts +325 -0
  779. package/node_modules/zod/src/v4/classic/tests/object.test.ts +717 -0
  780. package/node_modules/zod/src/v4/classic/tests/optional.test.ts +333 -0
  781. package/node_modules/zod/src/v4/classic/tests/partial.test.ts +450 -0
  782. package/node_modules/zod/src/v4/classic/tests/pickomit.test.ts +211 -0
  783. package/node_modules/zod/src/v4/classic/tests/pipe.test.ts +101 -0
  784. package/node_modules/zod/src/v4/classic/tests/prefault.test.ts +74 -0
  785. package/node_modules/zod/src/v4/classic/tests/preprocess-types.test.ts +26 -0
  786. package/node_modules/zod/src/v4/classic/tests/preprocess.test.ts +351 -0
  787. package/node_modules/zod/src/v4/classic/tests/primitive.test.ts +175 -0
  788. package/node_modules/zod/src/v4/classic/tests/promise.test.ts +81 -0
  789. package/node_modules/zod/src/v4/classic/tests/prototypes.test.ts +23 -0
  790. package/node_modules/zod/src/v4/classic/tests/readonly.test.ts +252 -0
  791. package/node_modules/zod/src/v4/classic/tests/record.test.ts +717 -0
  792. package/node_modules/zod/src/v4/classic/tests/recursive-types.test.ts +631 -0
  793. package/node_modules/zod/src/v4/classic/tests/refine.test.ts +633 -0
  794. package/node_modules/zod/src/v4/classic/tests/registries.test.ts +243 -0
  795. package/node_modules/zod/src/v4/classic/tests/set.test.ts +181 -0
  796. package/node_modules/zod/src/v4/classic/tests/standard-schema.test.ts +134 -0
  797. package/node_modules/zod/src/v4/classic/tests/string-formats.test.ts +125 -0
  798. package/node_modules/zod/src/v4/classic/tests/string.test.ts +1224 -0
  799. package/node_modules/zod/src/v4/classic/tests/stringbool.test.ts +106 -0
  800. package/node_modules/zod/src/v4/classic/tests/template-literal.test.ts +771 -0
  801. package/node_modules/zod/src/v4/classic/tests/to-json-schema-methods.test.ts +438 -0
  802. package/node_modules/zod/src/v4/classic/tests/to-json-schema.test.ts +3125 -0
  803. package/node_modules/zod/src/v4/classic/tests/transform.test.ts +378 -0
  804. package/node_modules/zod/src/v4/classic/tests/tuple.test.ts +496 -0
  805. package/node_modules/zod/src/v4/classic/tests/union.test.ts +273 -0
  806. package/node_modules/zod/src/v4/classic/tests/url.test.ts +13 -0
  807. package/node_modules/zod/src/v4/classic/tests/validations.test.ts +283 -0
  808. package/node_modules/zod/src/v4/classic/tests/void.test.ts +12 -0
  809. package/node_modules/zod/src/v4/core/api.ts +1823 -0
  810. package/node_modules/zod/src/v4/core/checks.ts +1293 -0
  811. package/node_modules/zod/src/v4/core/config.ts +15 -0
  812. package/node_modules/zod/src/v4/core/core.ts +153 -0
  813. package/node_modules/zod/src/v4/core/doc.ts +44 -0
  814. package/node_modules/zod/src/v4/core/errors.ts +455 -0
  815. package/node_modules/zod/src/v4/core/index.ts +16 -0
  816. package/node_modules/zod/src/v4/core/json-schema-generator.ts +126 -0
  817. package/node_modules/zod/src/v4/core/json-schema-processors.ts +666 -0
  818. package/node_modules/zod/src/v4/core/json-schema.ts +147 -0
  819. package/node_modules/zod/src/v4/core/parse.ts +195 -0
  820. package/node_modules/zod/src/v4/core/regexes.ts +190 -0
  821. package/node_modules/zod/src/v4/core/registries.ts +105 -0
  822. package/node_modules/zod/src/v4/core/schemas.ts +4730 -0
  823. package/node_modules/zod/src/v4/core/standard-schema.ts +159 -0
  824. package/node_modules/zod/src/v4/core/tests/extend.test.ts +59 -0
  825. package/node_modules/zod/src/v4/core/tests/index.test.ts +46 -0
  826. package/node_modules/zod/src/v4/core/tests/locales/be.test.ts +124 -0
  827. package/node_modules/zod/src/v4/core/tests/locales/el.test.ts +215 -0
  828. package/node_modules/zod/src/v4/core/tests/locales/en.test.ts +22 -0
  829. package/node_modules/zod/src/v4/core/tests/locales/es.test.ts +181 -0
  830. package/node_modules/zod/src/v4/core/tests/locales/fr.test.ts +72 -0
  831. package/node_modules/zod/src/v4/core/tests/locales/he.test.ts +379 -0
  832. package/node_modules/zod/src/v4/core/tests/locales/hr.test.ts +163 -0
  833. package/node_modules/zod/src/v4/core/tests/locales/nl.test.ts +46 -0
  834. package/node_modules/zod/src/v4/core/tests/locales/ru.test.ts +128 -0
  835. package/node_modules/zod/src/v4/core/tests/locales/tr.test.ts +69 -0
  836. package/node_modules/zod/src/v4/core/tests/locales/uz.test.ts +105 -0
  837. package/node_modules/zod/src/v4/core/tests/record-constructor.test.ts +125 -0
  838. package/node_modules/zod/src/v4/core/tests/recursive-tuples.test.ts +45 -0
  839. package/node_modules/zod/src/v4/core/to-json-schema.ts +622 -0
  840. package/node_modules/zod/src/v4/core/util.ts +983 -0
  841. package/node_modules/zod/src/v4/core/versions.ts +5 -0
  842. package/node_modules/zod/src/v4/core/zsf.ts +323 -0
  843. package/node_modules/zod/src/v4/index.ts +4 -0
  844. package/node_modules/zod/src/v4/locales/ar.ts +115 -0
  845. package/node_modules/zod/src/v4/locales/az.ts +111 -0
  846. package/node_modules/zod/src/v4/locales/be.ts +176 -0
  847. package/node_modules/zod/src/v4/locales/bg.ts +128 -0
  848. package/node_modules/zod/src/v4/locales/ca.ts +116 -0
  849. package/node_modules/zod/src/v4/locales/cs.ts +118 -0
  850. package/node_modules/zod/src/v4/locales/da.ts +123 -0
  851. package/node_modules/zod/src/v4/locales/de.ts +116 -0
  852. package/node_modules/zod/src/v4/locales/el.ts +121 -0
  853. package/node_modules/zod/src/v4/locales/en.ts +123 -0
  854. package/node_modules/zod/src/v4/locales/eo.ts +118 -0
  855. package/node_modules/zod/src/v4/locales/es.ts +141 -0
  856. package/node_modules/zod/src/v4/locales/fa.ts +126 -0
  857. package/node_modules/zod/src/v4/locales/fi.ts +121 -0
  858. package/node_modules/zod/src/v4/locales/fr-CA.ts +116 -0
  859. package/node_modules/zod/src/v4/locales/fr.ts +132 -0
  860. package/node_modules/zod/src/v4/locales/he.ts +246 -0
  861. package/node_modules/zod/src/v4/locales/hr.ts +131 -0
  862. package/node_modules/zod/src/v4/locales/hu.ts +117 -0
  863. package/node_modules/zod/src/v4/locales/hy.ts +164 -0
  864. package/node_modules/zod/src/v4/locales/id.ts +115 -0
  865. package/node_modules/zod/src/v4/locales/index.ts +52 -0
  866. package/node_modules/zod/src/v4/locales/is.ts +119 -0
  867. package/node_modules/zod/src/v4/locales/it.ts +116 -0
  868. package/node_modules/zod/src/v4/locales/ja.ts +114 -0
  869. package/node_modules/zod/src/v4/locales/ka.ts +123 -0
  870. package/node_modules/zod/src/v4/locales/kh.ts +7 -0
  871. package/node_modules/zod/src/v4/locales/km.ts +119 -0
  872. package/node_modules/zod/src/v4/locales/ko.ts +121 -0
  873. package/node_modules/zod/src/v4/locales/lt.ts +239 -0
  874. package/node_modules/zod/src/v4/locales/mk.ts +118 -0
  875. package/node_modules/zod/src/v4/locales/ms.ts +115 -0
  876. package/node_modules/zod/src/v4/locales/nl.ts +121 -0
  877. package/node_modules/zod/src/v4/locales/no.ts +116 -0
  878. package/node_modules/zod/src/v4/locales/ota.ts +117 -0
  879. package/node_modules/zod/src/v4/locales/pl.ts +118 -0
  880. package/node_modules/zod/src/v4/locales/ps.ts +126 -0
  881. package/node_modules/zod/src/v4/locales/pt.ts +116 -0
  882. package/node_modules/zod/src/v4/locales/ro.ts +129 -0
  883. package/node_modules/zod/src/v4/locales/ru.ts +176 -0
  884. package/node_modules/zod/src/v4/locales/sl.ts +118 -0
  885. package/node_modules/zod/src/v4/locales/sv.ts +119 -0
  886. package/node_modules/zod/src/v4/locales/ta.ts +118 -0
  887. package/node_modules/zod/src/v4/locales/th.ts +119 -0
  888. package/node_modules/zod/src/v4/locales/tr.ts +111 -0
  889. package/node_modules/zod/src/v4/locales/ua.ts +7 -0
  890. package/node_modules/zod/src/v4/locales/uk.ts +117 -0
  891. package/node_modules/zod/src/v4/locales/ur.ts +119 -0
  892. package/node_modules/zod/src/v4/locales/uz.ts +117 -0
  893. package/node_modules/zod/src/v4/locales/vi.ts +117 -0
  894. package/node_modules/zod/src/v4/locales/yo.ts +124 -0
  895. package/node_modules/zod/src/v4/locales/zh-CN.ts +116 -0
  896. package/node_modules/zod/src/v4/locales/zh-TW.ts +115 -0
  897. package/node_modules/zod/src/v4/mini/checks.ts +32 -0
  898. package/node_modules/zod/src/v4/mini/coerce.ts +27 -0
  899. package/node_modules/zod/src/v4/mini/external.ts +41 -0
  900. package/node_modules/zod/src/v4/mini/index.ts +3 -0
  901. package/node_modules/zod/src/v4/mini/iso.ts +66 -0
  902. package/node_modules/zod/src/v4/mini/parse.ts +14 -0
  903. package/node_modules/zod/src/v4/mini/schemas.ts +1947 -0
  904. package/node_modules/zod/src/v4/mini/tests/apply.test.ts +24 -0
  905. package/node_modules/zod/src/v4/mini/tests/assignability.test.ts +129 -0
  906. package/node_modules/zod/src/v4/mini/tests/brand.test.ts +94 -0
  907. package/node_modules/zod/src/v4/mini/tests/checks.test.ts +144 -0
  908. package/node_modules/zod/src/v4/mini/tests/codec.test.ts +548 -0
  909. package/node_modules/zod/src/v4/mini/tests/computed.test.ts +36 -0
  910. package/node_modules/zod/src/v4/mini/tests/error.test.ts +22 -0
  911. package/node_modules/zod/src/v4/mini/tests/functions.test.ts +5 -0
  912. package/node_modules/zod/src/v4/mini/tests/index.test.ts +993 -0
  913. package/node_modules/zod/src/v4/mini/tests/number.test.ts +95 -0
  914. package/node_modules/zod/src/v4/mini/tests/object.test.ts +227 -0
  915. package/node_modules/zod/src/v4/mini/tests/prototypes.test.ts +43 -0
  916. package/node_modules/zod/src/v4/mini/tests/recursive-types.test.ts +325 -0
  917. package/node_modules/zod/src/v4/mini/tests/standard-schema.test.ts +50 -0
  918. package/node_modules/zod/src/v4/mini/tests/string.test.ts +352 -0
  919. package/node_modules/zod/src/v4-mini/index.ts +3 -0
  920. package/node_modules/zod/v3/ZodError.cjs +138 -0
  921. package/node_modules/zod/v3/ZodError.d.cts +164 -0
  922. package/node_modules/zod/v3/ZodError.d.ts +164 -0
  923. package/node_modules/zod/v3/ZodError.js +133 -0
  924. package/node_modules/zod/v3/errors.cjs +17 -0
  925. package/node_modules/zod/v3/errors.d.cts +5 -0
  926. package/node_modules/zod/v3/errors.d.ts +5 -0
  927. package/node_modules/zod/v3/errors.js +9 -0
  928. package/node_modules/zod/v3/external.cjs +22 -0
  929. package/node_modules/zod/v3/external.d.cts +6 -0
  930. package/node_modules/zod/v3/external.d.ts +6 -0
  931. package/node_modules/zod/v3/external.js +6 -0
  932. package/node_modules/zod/v3/helpers/enumUtil.cjs +2 -0
  933. package/node_modules/zod/v3/helpers/enumUtil.d.cts +8 -0
  934. package/node_modules/zod/v3/helpers/enumUtil.d.ts +8 -0
  935. package/node_modules/zod/v3/helpers/enumUtil.js +1 -0
  936. package/node_modules/zod/v3/helpers/errorUtil.cjs +9 -0
  937. package/node_modules/zod/v3/helpers/errorUtil.d.cts +9 -0
  938. package/node_modules/zod/v3/helpers/errorUtil.d.ts +9 -0
  939. package/node_modules/zod/v3/helpers/errorUtil.js +6 -0
  940. package/node_modules/zod/v3/helpers/parseUtil.cjs +124 -0
  941. package/node_modules/zod/v3/helpers/parseUtil.d.cts +78 -0
  942. package/node_modules/zod/v3/helpers/parseUtil.d.ts +78 -0
  943. package/node_modules/zod/v3/helpers/parseUtil.js +109 -0
  944. package/node_modules/zod/v3/helpers/partialUtil.cjs +2 -0
  945. package/node_modules/zod/v3/helpers/partialUtil.d.cts +8 -0
  946. package/node_modules/zod/v3/helpers/partialUtil.d.ts +8 -0
  947. package/node_modules/zod/v3/helpers/partialUtil.js +1 -0
  948. package/node_modules/zod/v3/helpers/typeAliases.cjs +2 -0
  949. package/node_modules/zod/v3/helpers/typeAliases.d.cts +2 -0
  950. package/node_modules/zod/v3/helpers/typeAliases.d.ts +2 -0
  951. package/node_modules/zod/v3/helpers/typeAliases.js +1 -0
  952. package/node_modules/zod/v3/helpers/util.cjs +137 -0
  953. package/node_modules/zod/v3/helpers/util.d.cts +85 -0
  954. package/node_modules/zod/v3/helpers/util.d.ts +85 -0
  955. package/node_modules/zod/v3/helpers/util.js +133 -0
  956. package/node_modules/zod/v3/index.cjs +33 -0
  957. package/node_modules/zod/v3/index.d.cts +4 -0
  958. package/node_modules/zod/v3/index.d.ts +4 -0
  959. package/node_modules/zod/v3/index.js +4 -0
  960. package/node_modules/zod/v3/locales/en.cjs +112 -0
  961. package/node_modules/zod/v3/locales/en.d.cts +3 -0
  962. package/node_modules/zod/v3/locales/en.d.ts +3 -0
  963. package/node_modules/zod/v3/locales/en.js +109 -0
  964. package/node_modules/zod/v3/package.json +7 -0
  965. package/node_modules/zod/v3/standard-schema.cjs +2 -0
  966. package/node_modules/zod/v3/standard-schema.d.cts +102 -0
  967. package/node_modules/zod/v3/standard-schema.d.ts +102 -0
  968. package/node_modules/zod/v3/standard-schema.js +1 -0
  969. package/node_modules/zod/v3/types.cjs +3777 -0
  970. package/node_modules/zod/v3/types.d.cts +1034 -0
  971. package/node_modules/zod/v3/types.d.ts +1034 -0
  972. package/node_modules/zod/v3/types.js +3695 -0
  973. package/node_modules/zod/v4/classic/checks.cjs +33 -0
  974. package/node_modules/zod/v4/classic/checks.d.cts +1 -0
  975. package/node_modules/zod/v4/classic/checks.d.ts +1 -0
  976. package/node_modules/zod/v4/classic/checks.js +1 -0
  977. package/node_modules/zod/v4/classic/coerce.cjs +47 -0
  978. package/node_modules/zod/v4/classic/coerce.d.cts +17 -0
  979. package/node_modules/zod/v4/classic/coerce.d.ts +17 -0
  980. package/node_modules/zod/v4/classic/coerce.js +17 -0
  981. package/node_modules/zod/v4/classic/compat.cjs +61 -0
  982. package/node_modules/zod/v4/classic/compat.d.cts +50 -0
  983. package/node_modules/zod/v4/classic/compat.d.ts +50 -0
  984. package/node_modules/zod/v4/classic/compat.js +31 -0
  985. package/node_modules/zod/v4/classic/errors.cjs +74 -0
  986. package/node_modules/zod/v4/classic/errors.d.cts +30 -0
  987. package/node_modules/zod/v4/classic/errors.d.ts +30 -0
  988. package/node_modules/zod/v4/classic/errors.js +48 -0
  989. package/node_modules/zod/v4/classic/external.cjs +73 -0
  990. package/node_modules/zod/v4/classic/external.d.cts +16 -0
  991. package/node_modules/zod/v4/classic/external.d.ts +16 -0
  992. package/node_modules/zod/v4/classic/external.js +20 -0
  993. package/node_modules/zod/v4/classic/from-json-schema.cjs +625 -0
  994. package/node_modules/zod/v4/classic/from-json-schema.d.cts +12 -0
  995. package/node_modules/zod/v4/classic/from-json-schema.d.ts +12 -0
  996. package/node_modules/zod/v4/classic/from-json-schema.js +599 -0
  997. package/node_modules/zod/v4/classic/index.cjs +33 -0
  998. package/node_modules/zod/v4/classic/index.d.cts +4 -0
  999. package/node_modules/zod/v4/classic/index.d.ts +4 -0
  1000. package/node_modules/zod/v4/classic/index.js +4 -0
  1001. package/node_modules/zod/v4/classic/iso.cjs +60 -0
  1002. package/node_modules/zod/v4/classic/iso.d.cts +22 -0
  1003. package/node_modules/zod/v4/classic/iso.d.ts +22 -0
  1004. package/node_modules/zod/v4/classic/iso.js +30 -0
  1005. package/node_modules/zod/v4/classic/package.json +7 -0
  1006. package/node_modules/zod/v4/classic/parse.cjs +41 -0
  1007. package/node_modules/zod/v4/classic/parse.d.cts +31 -0
  1008. package/node_modules/zod/v4/classic/parse.d.ts +31 -0
  1009. package/node_modules/zod/v4/classic/parse.js +15 -0
  1010. package/node_modules/zod/v4/classic/schemas.cjs +1511 -0
  1011. package/node_modules/zod/v4/classic/schemas.d.cts +767 -0
  1012. package/node_modules/zod/v4/classic/schemas.d.ts +767 -0
  1013. package/node_modules/zod/v4/classic/schemas.js +1395 -0
  1014. package/node_modules/zod/v4/core/api.cjs +1227 -0
  1015. package/node_modules/zod/v4/core/api.d.cts +325 -0
  1016. package/node_modules/zod/v4/core/api.d.ts +325 -0
  1017. package/node_modules/zod/v4/core/api.js +1087 -0
  1018. package/node_modules/zod/v4/core/checks.cjs +601 -0
  1019. package/node_modules/zod/v4/core/checks.d.cts +278 -0
  1020. package/node_modules/zod/v4/core/checks.d.ts +278 -0
  1021. package/node_modules/zod/v4/core/checks.js +575 -0
  1022. package/node_modules/zod/v4/core/core.cjs +85 -0
  1023. package/node_modules/zod/v4/core/core.d.cts +70 -0
  1024. package/node_modules/zod/v4/core/core.d.ts +70 -0
  1025. package/node_modules/zod/v4/core/core.js +78 -0
  1026. package/node_modules/zod/v4/core/doc.cjs +39 -0
  1027. package/node_modules/zod/v4/core/doc.d.cts +14 -0
  1028. package/node_modules/zod/v4/core/doc.d.ts +14 -0
  1029. package/node_modules/zod/v4/core/doc.js +35 -0
  1030. package/node_modules/zod/v4/core/errors.cjs +216 -0
  1031. package/node_modules/zod/v4/core/errors.d.cts +221 -0
  1032. package/node_modules/zod/v4/core/errors.d.ts +221 -0
  1033. package/node_modules/zod/v4/core/errors.js +185 -0
  1034. package/node_modules/zod/v4/core/index.cjs +47 -0
  1035. package/node_modules/zod/v4/core/index.d.cts +16 -0
  1036. package/node_modules/zod/v4/core/index.d.ts +16 -0
  1037. package/node_modules/zod/v4/core/index.js +16 -0
  1038. package/node_modules/zod/v4/core/json-schema-generator.cjs +99 -0
  1039. package/node_modules/zod/v4/core/json-schema-generator.d.cts +65 -0
  1040. package/node_modules/zod/v4/core/json-schema-generator.d.ts +65 -0
  1041. package/node_modules/zod/v4/core/json-schema-generator.js +95 -0
  1042. package/node_modules/zod/v4/core/json-schema-processors.cjs +644 -0
  1043. package/node_modules/zod/v4/core/json-schema-processors.d.cts +49 -0
  1044. package/node_modules/zod/v4/core/json-schema-processors.d.ts +49 -0
  1045. package/node_modules/zod/v4/core/json-schema-processors.js +601 -0
  1046. package/node_modules/zod/v4/core/json-schema.cjs +2 -0
  1047. package/node_modules/zod/v4/core/json-schema.d.cts +88 -0
  1048. package/node_modules/zod/v4/core/json-schema.d.ts +88 -0
  1049. package/node_modules/zod/v4/core/json-schema.js +1 -0
  1050. package/node_modules/zod/v4/core/package.json +7 -0
  1051. package/node_modules/zod/v4/core/parse.cjs +131 -0
  1052. package/node_modules/zod/v4/core/parse.d.cts +49 -0
  1053. package/node_modules/zod/v4/core/parse.d.ts +49 -0
  1054. package/node_modules/zod/v4/core/parse.js +93 -0
  1055. package/node_modules/zod/v4/core/regexes.cjs +172 -0
  1056. package/node_modules/zod/v4/core/regexes.d.cts +85 -0
  1057. package/node_modules/zod/v4/core/regexes.d.ts +85 -0
  1058. package/node_modules/zod/v4/core/regexes.js +139 -0
  1059. package/node_modules/zod/v4/core/registries.cjs +56 -0
  1060. package/node_modules/zod/v4/core/registries.d.cts +35 -0
  1061. package/node_modules/zod/v4/core/registries.d.ts +35 -0
  1062. package/node_modules/zod/v4/core/registries.js +51 -0
  1063. package/node_modules/zod/v4/core/schemas.cjs +2270 -0
  1064. package/node_modules/zod/v4/core/schemas.d.cts +1184 -0
  1065. package/node_modules/zod/v4/core/schemas.d.ts +1184 -0
  1066. package/node_modules/zod/v4/core/schemas.js +2239 -0
  1067. package/node_modules/zod/v4/core/standard-schema.cjs +2 -0
  1068. package/node_modules/zod/v4/core/standard-schema.d.cts +126 -0
  1069. package/node_modules/zod/v4/core/standard-schema.d.ts +126 -0
  1070. package/node_modules/zod/v4/core/standard-schema.js +1 -0
  1071. package/node_modules/zod/v4/core/to-json-schema.cjs +457 -0
  1072. package/node_modules/zod/v4/core/to-json-schema.d.cts +114 -0
  1073. package/node_modules/zod/v4/core/to-json-schema.d.ts +114 -0
  1074. package/node_modules/zod/v4/core/to-json-schema.js +448 -0
  1075. package/node_modules/zod/v4/core/util.cjs +734 -0
  1076. package/node_modules/zod/v4/core/util.d.cts +200 -0
  1077. package/node_modules/zod/v4/core/util.d.ts +200 -0
  1078. package/node_modules/zod/v4/core/util.js +674 -0
  1079. package/node_modules/zod/v4/core/versions.cjs +8 -0
  1080. package/node_modules/zod/v4/core/versions.d.cts +5 -0
  1081. package/node_modules/zod/v4/core/versions.d.ts +5 -0
  1082. package/node_modules/zod/v4/core/versions.js +5 -0
  1083. package/node_modules/zod/v4/index.cjs +22 -0
  1084. package/node_modules/zod/v4/index.d.cts +3 -0
  1085. package/node_modules/zod/v4/index.d.ts +3 -0
  1086. package/node_modules/zod/v4/index.js +3 -0
  1087. package/node_modules/zod/v4/locales/ar.cjs +133 -0
  1088. package/node_modules/zod/v4/locales/ar.d.cts +5 -0
  1089. package/node_modules/zod/v4/locales/ar.d.ts +4 -0
  1090. package/node_modules/zod/v4/locales/ar.js +106 -0
  1091. package/node_modules/zod/v4/locales/az.cjs +132 -0
  1092. package/node_modules/zod/v4/locales/az.d.cts +5 -0
  1093. package/node_modules/zod/v4/locales/az.d.ts +4 -0
  1094. package/node_modules/zod/v4/locales/az.js +105 -0
  1095. package/node_modules/zod/v4/locales/be.cjs +183 -0
  1096. package/node_modules/zod/v4/locales/be.d.cts +5 -0
  1097. package/node_modules/zod/v4/locales/be.d.ts +4 -0
  1098. package/node_modules/zod/v4/locales/be.js +156 -0
  1099. package/node_modules/zod/v4/locales/bg.cjs +147 -0
  1100. package/node_modules/zod/v4/locales/bg.d.cts +5 -0
  1101. package/node_modules/zod/v4/locales/bg.d.ts +4 -0
  1102. package/node_modules/zod/v4/locales/bg.js +120 -0
  1103. package/node_modules/zod/v4/locales/ca.cjs +134 -0
  1104. package/node_modules/zod/v4/locales/ca.d.cts +5 -0
  1105. package/node_modules/zod/v4/locales/ca.d.ts +4 -0
  1106. package/node_modules/zod/v4/locales/ca.js +107 -0
  1107. package/node_modules/zod/v4/locales/cs.cjs +138 -0
  1108. package/node_modules/zod/v4/locales/cs.d.cts +5 -0
  1109. package/node_modules/zod/v4/locales/cs.d.ts +4 -0
  1110. package/node_modules/zod/v4/locales/cs.js +111 -0
  1111. package/node_modules/zod/v4/locales/da.cjs +142 -0
  1112. package/node_modules/zod/v4/locales/da.d.cts +5 -0
  1113. package/node_modules/zod/v4/locales/da.d.ts +4 -0
  1114. package/node_modules/zod/v4/locales/da.js +115 -0
  1115. package/node_modules/zod/v4/locales/de.cjs +135 -0
  1116. package/node_modules/zod/v4/locales/de.d.cts +5 -0
  1117. package/node_modules/zod/v4/locales/de.d.ts +4 -0
  1118. package/node_modules/zod/v4/locales/de.js +108 -0
  1119. package/node_modules/zod/v4/locales/el.cjs +136 -0
  1120. package/node_modules/zod/v4/locales/el.d.cts +5 -0
  1121. package/node_modules/zod/v4/locales/el.d.ts +4 -0
  1122. package/node_modules/zod/v4/locales/el.js +109 -0
  1123. package/node_modules/zod/v4/locales/en.cjs +140 -0
  1124. package/node_modules/zod/v4/locales/en.d.cts +5 -0
  1125. package/node_modules/zod/v4/locales/en.d.ts +4 -0
  1126. package/node_modules/zod/v4/locales/en.js +113 -0
  1127. package/node_modules/zod/v4/locales/eo.cjs +136 -0
  1128. package/node_modules/zod/v4/locales/eo.d.cts +5 -0
  1129. package/node_modules/zod/v4/locales/eo.d.ts +4 -0
  1130. package/node_modules/zod/v4/locales/eo.js +109 -0
  1131. package/node_modules/zod/v4/locales/es.cjs +159 -0
  1132. package/node_modules/zod/v4/locales/es.d.cts +5 -0
  1133. package/node_modules/zod/v4/locales/es.d.ts +4 -0
  1134. package/node_modules/zod/v4/locales/es.js +132 -0
  1135. package/node_modules/zod/v4/locales/fa.cjs +141 -0
  1136. package/node_modules/zod/v4/locales/fa.d.cts +5 -0
  1137. package/node_modules/zod/v4/locales/fa.d.ts +4 -0
  1138. package/node_modules/zod/v4/locales/fa.js +114 -0
  1139. package/node_modules/zod/v4/locales/fi.cjs +139 -0
  1140. package/node_modules/zod/v4/locales/fi.d.cts +5 -0
  1141. package/node_modules/zod/v4/locales/fi.d.ts +4 -0
  1142. package/node_modules/zod/v4/locales/fi.js +112 -0
  1143. package/node_modules/zod/v4/locales/fr-CA.cjs +134 -0
  1144. package/node_modules/zod/v4/locales/fr-CA.d.cts +5 -0
  1145. package/node_modules/zod/v4/locales/fr-CA.d.ts +4 -0
  1146. package/node_modules/zod/v4/locales/fr-CA.js +107 -0
  1147. package/node_modules/zod/v4/locales/fr.cjs +152 -0
  1148. package/node_modules/zod/v4/locales/fr.d.cts +5 -0
  1149. package/node_modules/zod/v4/locales/fr.d.ts +4 -0
  1150. package/node_modules/zod/v4/locales/fr.js +125 -0
  1151. package/node_modules/zod/v4/locales/he.cjs +241 -0
  1152. package/node_modules/zod/v4/locales/he.d.cts +5 -0
  1153. package/node_modules/zod/v4/locales/he.d.ts +4 -0
  1154. package/node_modules/zod/v4/locales/he.js +214 -0
  1155. package/node_modules/zod/v4/locales/hr.cjs +149 -0
  1156. package/node_modules/zod/v4/locales/hr.d.cts +5 -0
  1157. package/node_modules/zod/v4/locales/hr.d.ts +4 -0
  1158. package/node_modules/zod/v4/locales/hr.js +122 -0
  1159. package/node_modules/zod/v4/locales/hu.cjs +135 -0
  1160. package/node_modules/zod/v4/locales/hu.d.cts +5 -0
  1161. package/node_modules/zod/v4/locales/hu.d.ts +4 -0
  1162. package/node_modules/zod/v4/locales/hu.js +108 -0
  1163. package/node_modules/zod/v4/locales/hy.cjs +174 -0
  1164. package/node_modules/zod/v4/locales/hy.d.cts +5 -0
  1165. package/node_modules/zod/v4/locales/hy.d.ts +4 -0
  1166. package/node_modules/zod/v4/locales/hy.js +147 -0
  1167. package/node_modules/zod/v4/locales/id.cjs +133 -0
  1168. package/node_modules/zod/v4/locales/id.d.cts +5 -0
  1169. package/node_modules/zod/v4/locales/id.d.ts +4 -0
  1170. package/node_modules/zod/v4/locales/id.js +106 -0
  1171. package/node_modules/zod/v4/locales/index.cjs +111 -0
  1172. package/node_modules/zod/v4/locales/index.d.cts +52 -0
  1173. package/node_modules/zod/v4/locales/index.d.ts +52 -0
  1174. package/node_modules/zod/v4/locales/index.js +52 -0
  1175. package/node_modules/zod/v4/locales/is.cjs +136 -0
  1176. package/node_modules/zod/v4/locales/is.d.cts +5 -0
  1177. package/node_modules/zod/v4/locales/is.d.ts +4 -0
  1178. package/node_modules/zod/v4/locales/is.js +109 -0
  1179. package/node_modules/zod/v4/locales/it.cjs +135 -0
  1180. package/node_modules/zod/v4/locales/it.d.cts +5 -0
  1181. package/node_modules/zod/v4/locales/it.d.ts +4 -0
  1182. package/node_modules/zod/v4/locales/it.js +108 -0
  1183. package/node_modules/zod/v4/locales/ja.cjs +134 -0
  1184. package/node_modules/zod/v4/locales/ja.d.cts +5 -0
  1185. package/node_modules/zod/v4/locales/ja.d.ts +4 -0
  1186. package/node_modules/zod/v4/locales/ja.js +107 -0
  1187. package/node_modules/zod/v4/locales/ka.cjs +139 -0
  1188. package/node_modules/zod/v4/locales/ka.d.cts +5 -0
  1189. package/node_modules/zod/v4/locales/ka.d.ts +4 -0
  1190. package/node_modules/zod/v4/locales/ka.js +112 -0
  1191. package/node_modules/zod/v4/locales/kh.cjs +12 -0
  1192. package/node_modules/zod/v4/locales/kh.d.cts +5 -0
  1193. package/node_modules/zod/v4/locales/kh.d.ts +5 -0
  1194. package/node_modules/zod/v4/locales/kh.js +5 -0
  1195. package/node_modules/zod/v4/locales/km.cjs +137 -0
  1196. package/node_modules/zod/v4/locales/km.d.cts +5 -0
  1197. package/node_modules/zod/v4/locales/km.d.ts +4 -0
  1198. package/node_modules/zod/v4/locales/km.js +110 -0
  1199. package/node_modules/zod/v4/locales/ko.cjs +138 -0
  1200. package/node_modules/zod/v4/locales/ko.d.cts +5 -0
  1201. package/node_modules/zod/v4/locales/ko.d.ts +4 -0
  1202. package/node_modules/zod/v4/locales/ko.js +111 -0
  1203. package/node_modules/zod/v4/locales/lt.cjs +230 -0
  1204. package/node_modules/zod/v4/locales/lt.d.cts +5 -0
  1205. package/node_modules/zod/v4/locales/lt.d.ts +4 -0
  1206. package/node_modules/zod/v4/locales/lt.js +203 -0
  1207. package/node_modules/zod/v4/locales/mk.cjs +136 -0
  1208. package/node_modules/zod/v4/locales/mk.d.cts +5 -0
  1209. package/node_modules/zod/v4/locales/mk.d.ts +4 -0
  1210. package/node_modules/zod/v4/locales/mk.js +109 -0
  1211. package/node_modules/zod/v4/locales/ms.cjs +134 -0
  1212. package/node_modules/zod/v4/locales/ms.d.cts +5 -0
  1213. package/node_modules/zod/v4/locales/ms.d.ts +4 -0
  1214. package/node_modules/zod/v4/locales/ms.js +107 -0
  1215. package/node_modules/zod/v4/locales/nl.cjs +137 -0
  1216. package/node_modules/zod/v4/locales/nl.d.cts +5 -0
  1217. package/node_modules/zod/v4/locales/nl.d.ts +4 -0
  1218. package/node_modules/zod/v4/locales/nl.js +110 -0
  1219. package/node_modules/zod/v4/locales/no.cjs +135 -0
  1220. package/node_modules/zod/v4/locales/no.d.cts +5 -0
  1221. package/node_modules/zod/v4/locales/no.d.ts +4 -0
  1222. package/node_modules/zod/v4/locales/no.js +108 -0
  1223. package/node_modules/zod/v4/locales/ota.cjs +136 -0
  1224. package/node_modules/zod/v4/locales/ota.d.cts +5 -0
  1225. package/node_modules/zod/v4/locales/ota.d.ts +4 -0
  1226. package/node_modules/zod/v4/locales/ota.js +109 -0
  1227. package/node_modules/zod/v4/locales/package.json +7 -0
  1228. package/node_modules/zod/v4/locales/pl.cjs +136 -0
  1229. package/node_modules/zod/v4/locales/pl.d.cts +5 -0
  1230. package/node_modules/zod/v4/locales/pl.d.ts +4 -0
  1231. package/node_modules/zod/v4/locales/pl.js +109 -0
  1232. package/node_modules/zod/v4/locales/ps.cjs +141 -0
  1233. package/node_modules/zod/v4/locales/ps.d.cts +5 -0
  1234. package/node_modules/zod/v4/locales/ps.d.ts +4 -0
  1235. package/node_modules/zod/v4/locales/ps.js +114 -0
  1236. package/node_modules/zod/v4/locales/pt.cjs +135 -0
  1237. package/node_modules/zod/v4/locales/pt.d.cts +5 -0
  1238. package/node_modules/zod/v4/locales/pt.d.ts +4 -0
  1239. package/node_modules/zod/v4/locales/pt.js +108 -0
  1240. package/node_modules/zod/v4/locales/ro.cjs +146 -0
  1241. package/node_modules/zod/v4/locales/ro.d.cts +5 -0
  1242. package/node_modules/zod/v4/locales/ro.d.ts +4 -0
  1243. package/node_modules/zod/v4/locales/ro.js +119 -0
  1244. package/node_modules/zod/v4/locales/ru.cjs +183 -0
  1245. package/node_modules/zod/v4/locales/ru.d.cts +5 -0
  1246. package/node_modules/zod/v4/locales/ru.d.ts +4 -0
  1247. package/node_modules/zod/v4/locales/ru.js +156 -0
  1248. package/node_modules/zod/v4/locales/sl.cjs +136 -0
  1249. package/node_modules/zod/v4/locales/sl.d.cts +5 -0
  1250. package/node_modules/zod/v4/locales/sl.d.ts +4 -0
  1251. package/node_modules/zod/v4/locales/sl.js +109 -0
  1252. package/node_modules/zod/v4/locales/sv.cjs +137 -0
  1253. package/node_modules/zod/v4/locales/sv.d.cts +5 -0
  1254. package/node_modules/zod/v4/locales/sv.d.ts +4 -0
  1255. package/node_modules/zod/v4/locales/sv.js +110 -0
  1256. package/node_modules/zod/v4/locales/ta.cjs +137 -0
  1257. package/node_modules/zod/v4/locales/ta.d.cts +5 -0
  1258. package/node_modules/zod/v4/locales/ta.d.ts +4 -0
  1259. package/node_modules/zod/v4/locales/ta.js +110 -0
  1260. package/node_modules/zod/v4/locales/th.cjs +137 -0
  1261. package/node_modules/zod/v4/locales/th.d.cts +5 -0
  1262. package/node_modules/zod/v4/locales/th.d.ts +4 -0
  1263. package/node_modules/zod/v4/locales/th.js +110 -0
  1264. package/node_modules/zod/v4/locales/tr.cjs +132 -0
  1265. package/node_modules/zod/v4/locales/tr.d.cts +5 -0
  1266. package/node_modules/zod/v4/locales/tr.d.ts +4 -0
  1267. package/node_modules/zod/v4/locales/tr.js +105 -0
  1268. package/node_modules/zod/v4/locales/ua.cjs +12 -0
  1269. package/node_modules/zod/v4/locales/ua.d.cts +5 -0
  1270. package/node_modules/zod/v4/locales/ua.d.ts +5 -0
  1271. package/node_modules/zod/v4/locales/ua.js +5 -0
  1272. package/node_modules/zod/v4/locales/uk.cjs +135 -0
  1273. package/node_modules/zod/v4/locales/uk.d.cts +5 -0
  1274. package/node_modules/zod/v4/locales/uk.d.ts +4 -0
  1275. package/node_modules/zod/v4/locales/uk.js +108 -0
  1276. package/node_modules/zod/v4/locales/ur.cjs +137 -0
  1277. package/node_modules/zod/v4/locales/ur.d.cts +5 -0
  1278. package/node_modules/zod/v4/locales/ur.d.ts +4 -0
  1279. package/node_modules/zod/v4/locales/ur.js +110 -0
  1280. package/node_modules/zod/v4/locales/uz.cjs +137 -0
  1281. package/node_modules/zod/v4/locales/uz.d.cts +5 -0
  1282. package/node_modules/zod/v4/locales/uz.d.ts +4 -0
  1283. package/node_modules/zod/v4/locales/uz.js +110 -0
  1284. package/node_modules/zod/v4/locales/vi.cjs +135 -0
  1285. package/node_modules/zod/v4/locales/vi.d.cts +5 -0
  1286. package/node_modules/zod/v4/locales/vi.d.ts +4 -0
  1287. package/node_modules/zod/v4/locales/vi.js +108 -0
  1288. package/node_modules/zod/v4/locales/yo.cjs +134 -0
  1289. package/node_modules/zod/v4/locales/yo.d.cts +5 -0
  1290. package/node_modules/zod/v4/locales/yo.d.ts +4 -0
  1291. package/node_modules/zod/v4/locales/yo.js +107 -0
  1292. package/node_modules/zod/v4/locales/zh-CN.cjs +136 -0
  1293. package/node_modules/zod/v4/locales/zh-CN.d.cts +5 -0
  1294. package/node_modules/zod/v4/locales/zh-CN.d.ts +4 -0
  1295. package/node_modules/zod/v4/locales/zh-CN.js +109 -0
  1296. package/node_modules/zod/v4/locales/zh-TW.cjs +134 -0
  1297. package/node_modules/zod/v4/locales/zh-TW.d.cts +5 -0
  1298. package/node_modules/zod/v4/locales/zh-TW.d.ts +4 -0
  1299. package/node_modules/zod/v4/locales/zh-TW.js +107 -0
  1300. package/node_modules/zod/v4/mini/checks.cjs +34 -0
  1301. package/node_modules/zod/v4/mini/checks.d.cts +1 -0
  1302. package/node_modules/zod/v4/mini/checks.d.ts +1 -0
  1303. package/node_modules/zod/v4/mini/checks.js +1 -0
  1304. package/node_modules/zod/v4/mini/coerce.cjs +52 -0
  1305. package/node_modules/zod/v4/mini/coerce.d.cts +7 -0
  1306. package/node_modules/zod/v4/mini/coerce.d.ts +7 -0
  1307. package/node_modules/zod/v4/mini/coerce.js +22 -0
  1308. package/node_modules/zod/v4/mini/external.cjs +63 -0
  1309. package/node_modules/zod/v4/mini/external.d.cts +13 -0
  1310. package/node_modules/zod/v4/mini/external.d.ts +13 -0
  1311. package/node_modules/zod/v4/mini/external.js +14 -0
  1312. package/node_modules/zod/v4/mini/index.cjs +32 -0
  1313. package/node_modules/zod/v4/mini/index.d.cts +3 -0
  1314. package/node_modules/zod/v4/mini/index.d.ts +3 -0
  1315. package/node_modules/zod/v4/mini/index.js +3 -0
  1316. package/node_modules/zod/v4/mini/iso.cjs +64 -0
  1317. package/node_modules/zod/v4/mini/iso.d.cts +22 -0
  1318. package/node_modules/zod/v4/mini/iso.d.ts +22 -0
  1319. package/node_modules/zod/v4/mini/iso.js +34 -0
  1320. package/node_modules/zod/v4/mini/package.json +7 -0
  1321. package/node_modules/zod/v4/mini/parse.cjs +16 -0
  1322. package/node_modules/zod/v4/mini/parse.d.cts +1 -0
  1323. package/node_modules/zod/v4/mini/parse.d.ts +1 -0
  1324. package/node_modules/zod/v4/mini/parse.js +1 -0
  1325. package/node_modules/zod/v4/mini/schemas.cjs +1083 -0
  1326. package/node_modules/zod/v4/mini/schemas.d.cts +445 -0
  1327. package/node_modules/zod/v4/mini/schemas.d.ts +445 -0
  1328. package/node_modules/zod/v4/mini/schemas.js +961 -0
  1329. package/node_modules/zod/v4/package.json +7 -0
  1330. package/node_modules/zod/v4-mini/index.cjs +32 -0
  1331. package/node_modules/zod/v4-mini/index.d.cts +3 -0
  1332. package/node_modules/zod/v4-mini/index.d.ts +3 -0
  1333. package/node_modules/zod/v4-mini/index.js +3 -0
  1334. package/node_modules/zod/v4-mini/package.json +7 -0
  1335. package/npm-shrinkwrap.json +137 -0
  1336. package/package.json +9 -8
@@ -0,0 +1,1281 @@
1
+ /**
2
+ * [AES](https://en.wikipedia.org/wiki/Advanced_Encryption_Standard)
3
+ * a.k.a. Advanced Encryption Standard
4
+ * is a variant of Rijndael block cipher, standardized by NIST in 2001.
5
+ * We provide the fastest available pure JS implementation.
6
+ *
7
+ * `cipher = encrypt(block, key)`
8
+ *
9
+ * Data is split into 128-bit blocks. Encrypted in 10/12/14 rounds (128/192/256 bits). In every round:
10
+ * 1. **S-box**, table substitution
11
+ * 2. **Shift rows**, cyclic shift left of all rows of data array
12
+ * 3. **Mix columns**, multiplying every column by fixed polynomial
13
+ * 4. **Add round key**, round_key xor i-th column of array
14
+ *
15
+ * Check out [FIPS-197](https://csrc.nist.gov/files/pubs/fips/197/final/docs/fips-197.pdf),
16
+ * [NIST 800-38G](https://nvlpubs.nist.gov/nistpubs/SpecialPublications/NIST.SP.800-38G.pdf)
17
+ * and [original proposal](https://csrc.nist.gov/csrc/media/projects/cryptographic-standards-and-guidelines/documents/aes-development/rijndael-ammended.pdf)
18
+ * @module
19
+ */
20
+ import { ghash, polyval } from "./_polyval.js";
21
+ // prettier-ignore
22
+ import { abytes, anumber, clean, complexOverlapBytes, concatBytes, copyBytes, createView, equalBytes, getOutput, isAligned32, overlapBytes, u32, u64Lengths, u8, wrapCipher } from "./utils.js";
23
+ const BLOCK_SIZE = 16;
24
+ const BLOCK_SIZE32 = 4;
25
+ const EMPTY_BLOCK = /* @__PURE__ */ new Uint8Array(BLOCK_SIZE);
26
+ const ONE_BLOCK = /* @__PURE__ */ Uint8Array.from([
27
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01,
28
+ ]);
29
+ const POLY = 0x11b; // 1 + x + x**3 + x**4 + x**8
30
+ function validateKeyLength(key) {
31
+ if (![16, 24, 32].includes(key.length))
32
+ throw new Error('"aes key" expected Uint8Array of length 16/24/32, got length=' + key.length);
33
+ }
34
+ // TODO: remove multiplication, binary ops only
35
+ function mul2(n) {
36
+ return (n << 1) ^ (POLY & -(n >> 7));
37
+ }
38
+ function mul(a, b) {
39
+ let res = 0;
40
+ for (; b > 0; b >>= 1) {
41
+ // Montgomery ladder
42
+ res ^= a & -(b & 1); // if (b&1) res ^=a (but const-time).
43
+ a = mul2(a); // a = 2*a
44
+ }
45
+ return res;
46
+ }
47
+ // Increments bigint with wrap around
48
+ // NOTE: we cannot use u32 here since it may overflow on carry!
49
+ const incBytes = (data, isLE, carry = 1) => {
50
+ if (!Number.isSafeInteger(carry))
51
+ throw new Error('incBytes: wrong carry ' + carry);
52
+ abytes(data);
53
+ for (let i = 0; i < data.length; i++) {
54
+ const pos = !isLE ? data.length - 1 - i : i;
55
+ carry = (carry + (data[pos] & 0xff)) | 0;
56
+ data[pos] = carry & 0xff;
57
+ carry >>>= 8;
58
+ }
59
+ };
60
+ // AES S-box is generated using finite field inversion,
61
+ // an affine transform, and xor of a constant 0x63.
62
+ const sbox = /* @__PURE__ */ (() => {
63
+ const t = new Uint8Array(256);
64
+ for (let i = 0, x = 1; i < 256; i++, x ^= mul2(x))
65
+ t[i] = x;
66
+ const box = new Uint8Array(256);
67
+ box[0] = 0x63; // first elm
68
+ for (let i = 0; i < 255; i++) {
69
+ let x = t[255 - i];
70
+ x |= x << 8;
71
+ box[t[i]] = (x ^ (x >> 4) ^ (x >> 5) ^ (x >> 6) ^ (x >> 7) ^ 0x63) & 0xff;
72
+ }
73
+ clean(t);
74
+ return box;
75
+ })();
76
+ // Inverted S-box
77
+ const invSbox = /* @__PURE__ */ sbox.map((_, j) => sbox.indexOf(j));
78
+ // Rotate u32 by 8
79
+ const rotr32_8 = (n) => (n << 24) | (n >>> 8);
80
+ const rotl32_8 = (n) => (n << 8) | (n >>> 24);
81
+ // The byte swap operation for uint32 (LE<->BE)
82
+ const byteSwap = (word) => ((word << 24) & 0xff000000) |
83
+ ((word << 8) & 0xff0000) |
84
+ ((word >>> 8) & 0xff00) |
85
+ ((word >>> 24) & 0xff);
86
+ // T-table is optimization suggested in 5.2 of original proposal (missed from FIPS-197). Changes:
87
+ // - LE instead of BE
88
+ // - bigger tables: T0 and T1 are merged into T01 table and T2 & T3 into T23;
89
+ // so index is u16, instead of u8. This speeds up things, unexpectedly
90
+ function genTtable(sbox, fn) {
91
+ if (sbox.length !== 256)
92
+ throw new Error('Wrong sbox length');
93
+ const T0 = new Uint32Array(256).map((_, j) => fn(sbox[j]));
94
+ const T1 = T0.map(rotl32_8);
95
+ const T2 = T1.map(rotl32_8);
96
+ const T3 = T2.map(rotl32_8);
97
+ const T01 = new Uint32Array(256 * 256);
98
+ const T23 = new Uint32Array(256 * 256);
99
+ const sbox2 = new Uint16Array(256 * 256);
100
+ for (let i = 0; i < 256; i++) {
101
+ for (let j = 0; j < 256; j++) {
102
+ const idx = i * 256 + j;
103
+ T01[idx] = T0[i] ^ T1[j];
104
+ T23[idx] = T2[i] ^ T3[j];
105
+ sbox2[idx] = (sbox[i] << 8) | sbox[j];
106
+ }
107
+ }
108
+ return { sbox, sbox2, T0, T1, T2, T3, T01, T23 };
109
+ }
110
+ const tableEncoding = /* @__PURE__ */ genTtable(sbox, (s) => (mul(s, 3) << 24) | (s << 16) | (s << 8) | mul(s, 2));
111
+ const tableDecoding = /* @__PURE__ */ genTtable(invSbox, (s) => (mul(s, 11) << 24) | (mul(s, 13) << 16) | (mul(s, 9) << 8) | mul(s, 14));
112
+ const xPowers = /* @__PURE__ */ (() => {
113
+ const p = new Uint8Array(16);
114
+ for (let i = 0, x = 1; i < 16; i++, x = mul2(x))
115
+ p[i] = x;
116
+ return p;
117
+ })();
118
+ /** Key expansion used in CTR. */
119
+ function expandKeyLE(key) {
120
+ abytes(key);
121
+ const len = key.length;
122
+ validateKeyLength(key);
123
+ const { sbox2 } = tableEncoding;
124
+ const toClean = [];
125
+ if (!isAligned32(key))
126
+ toClean.push((key = copyBytes(key)));
127
+ const k32 = u32(key);
128
+ const Nk = k32.length;
129
+ const subByte = (n) => applySbox(sbox2, n, n, n, n);
130
+ const xk = new Uint32Array(len + 28); // expanded key
131
+ xk.set(k32);
132
+ // 4.3.1 Key expansion
133
+ for (let i = Nk; i < xk.length; i++) {
134
+ let t = xk[i - 1];
135
+ if (i % Nk === 0)
136
+ t = subByte(rotr32_8(t)) ^ xPowers[i / Nk - 1];
137
+ else if (Nk > 6 && i % Nk === 4)
138
+ t = subByte(t);
139
+ xk[i] = xk[i - Nk] ^ t;
140
+ }
141
+ clean(...toClean);
142
+ return xk;
143
+ }
144
+ function expandKeyDecLE(key) {
145
+ const encKey = expandKeyLE(key);
146
+ const xk = encKey.slice();
147
+ const Nk = encKey.length;
148
+ const { sbox2 } = tableEncoding;
149
+ const { T0, T1, T2, T3 } = tableDecoding;
150
+ // Inverse key by chunks of 4 (rounds)
151
+ for (let i = 0; i < Nk; i += 4) {
152
+ for (let j = 0; j < 4; j++)
153
+ xk[i + j] = encKey[Nk - i - 4 + j];
154
+ }
155
+ clean(encKey);
156
+ // apply InvMixColumn except first & last round
157
+ for (let i = 4; i < Nk - 4; i++) {
158
+ const x = xk[i];
159
+ const w = applySbox(sbox2, x, x, x, x);
160
+ xk[i] = T0[w & 0xff] ^ T1[(w >>> 8) & 0xff] ^ T2[(w >>> 16) & 0xff] ^ T3[w >>> 24];
161
+ }
162
+ return xk;
163
+ }
164
+ // Apply tables
165
+ function apply0123(T01, T23, s0, s1, s2, s3) {
166
+ return (T01[((s0 << 8) & 0xff00) | ((s1 >>> 8) & 0xff)] ^
167
+ T23[((s2 >>> 8) & 0xff00) | ((s3 >>> 24) & 0xff)]);
168
+ }
169
+ function applySbox(sbox2, s0, s1, s2, s3) {
170
+ return (sbox2[(s0 & 0xff) | (s1 & 0xff00)] |
171
+ (sbox2[((s2 >>> 16) & 0xff) | ((s3 >>> 16) & 0xff00)] << 16));
172
+ }
173
+ function encrypt(xk, s0, s1, s2, s3) {
174
+ const { sbox2, T01, T23 } = tableEncoding;
175
+ let k = 0;
176
+ ((s0 ^= xk[k++]), (s1 ^= xk[k++]), (s2 ^= xk[k++]), (s3 ^= xk[k++]));
177
+ const rounds = xk.length / 4 - 2;
178
+ for (let i = 0; i < rounds; i++) {
179
+ const t0 = xk[k++] ^ apply0123(T01, T23, s0, s1, s2, s3);
180
+ const t1 = xk[k++] ^ apply0123(T01, T23, s1, s2, s3, s0);
181
+ const t2 = xk[k++] ^ apply0123(T01, T23, s2, s3, s0, s1);
182
+ const t3 = xk[k++] ^ apply0123(T01, T23, s3, s0, s1, s2);
183
+ ((s0 = t0), (s1 = t1), (s2 = t2), (s3 = t3));
184
+ }
185
+ // last round (without mixcolumns, so using SBOX2 table)
186
+ const t0 = xk[k++] ^ applySbox(sbox2, s0, s1, s2, s3);
187
+ const t1 = xk[k++] ^ applySbox(sbox2, s1, s2, s3, s0);
188
+ const t2 = xk[k++] ^ applySbox(sbox2, s2, s3, s0, s1);
189
+ const t3 = xk[k++] ^ applySbox(sbox2, s3, s0, s1, s2);
190
+ return { s0: t0, s1: t1, s2: t2, s3: t3 };
191
+ }
192
+ // Can't be merged with encrypt: arg positions for apply0123 / applySbox are different
193
+ function decrypt(xk, s0, s1, s2, s3) {
194
+ const { sbox2, T01, T23 } = tableDecoding;
195
+ let k = 0;
196
+ ((s0 ^= xk[k++]), (s1 ^= xk[k++]), (s2 ^= xk[k++]), (s3 ^= xk[k++]));
197
+ const rounds = xk.length / 4 - 2;
198
+ for (let i = 0; i < rounds; i++) {
199
+ const t0 = xk[k++] ^ apply0123(T01, T23, s0, s3, s2, s1);
200
+ const t1 = xk[k++] ^ apply0123(T01, T23, s1, s0, s3, s2);
201
+ const t2 = xk[k++] ^ apply0123(T01, T23, s2, s1, s0, s3);
202
+ const t3 = xk[k++] ^ apply0123(T01, T23, s3, s2, s1, s0);
203
+ ((s0 = t0), (s1 = t1), (s2 = t2), (s3 = t3));
204
+ }
205
+ // Last round
206
+ const t0 = xk[k++] ^ applySbox(sbox2, s0, s3, s2, s1);
207
+ const t1 = xk[k++] ^ applySbox(sbox2, s1, s0, s3, s2);
208
+ const t2 = xk[k++] ^ applySbox(sbox2, s2, s1, s0, s3);
209
+ const t3 = xk[k++] ^ applySbox(sbox2, s3, s2, s1, s0);
210
+ return { s0: t0, s1: t1, s2: t2, s3: t3 };
211
+ }
212
+ // TODO: investigate merging with ctr32
213
+ function ctrCounter(xk, nonce, src, dst) {
214
+ abytes(nonce, BLOCK_SIZE, 'nonce');
215
+ abytes(src);
216
+ const srcLen = src.length;
217
+ dst = getOutput(srcLen, dst);
218
+ complexOverlapBytes(src, dst);
219
+ const ctr = nonce;
220
+ const c32 = u32(ctr);
221
+ // Fill block (empty, ctr=0)
222
+ let { s0, s1, s2, s3 } = encrypt(xk, c32[0], c32[1], c32[2], c32[3]);
223
+ const src32 = u32(src);
224
+ const dst32 = u32(dst);
225
+ // process blocks
226
+ for (let i = 0; i + 4 <= src32.length; i += 4) {
227
+ dst32[i + 0] = src32[i + 0] ^ s0;
228
+ dst32[i + 1] = src32[i + 1] ^ s1;
229
+ dst32[i + 2] = src32[i + 2] ^ s2;
230
+ dst32[i + 3] = src32[i + 3] ^ s3;
231
+ incBytes(ctr, false, 1); // Full 128 bit counter with wrap around
232
+ ({ s0, s1, s2, s3 } = encrypt(xk, c32[0], c32[1], c32[2], c32[3]));
233
+ }
234
+ // leftovers (less than block)
235
+ // It's possible to handle > u32 fast, but is it worth it?
236
+ const start = BLOCK_SIZE * Math.floor(src32.length / BLOCK_SIZE32);
237
+ if (start < srcLen) {
238
+ const b32 = new Uint32Array([s0, s1, s2, s3]);
239
+ const buf = u8(b32);
240
+ for (let i = start, pos = 0; i < srcLen; i++, pos++)
241
+ dst[i] = src[i] ^ buf[pos];
242
+ clean(b32);
243
+ }
244
+ return dst;
245
+ }
246
+ // AES CTR with overflowing 32 bit counter
247
+ // It's possible to do 32le significantly simpler (and probably faster) by using u32.
248
+ // But, we need both, and perf bottleneck is in ghash anyway.
249
+ function ctr32(xk, isLE, nonce, src, dst) {
250
+ abytes(nonce, BLOCK_SIZE, 'nonce');
251
+ abytes(src);
252
+ dst = getOutput(src.length, dst);
253
+ const ctr = nonce; // write new value to nonce, so it can be re-used
254
+ const c32 = u32(ctr);
255
+ const view = createView(ctr);
256
+ const src32 = u32(src);
257
+ const dst32 = u32(dst);
258
+ const ctrPos = isLE ? 0 : 12;
259
+ const srcLen = src.length;
260
+ // Fill block (empty, ctr=0)
261
+ let ctrNum = view.getUint32(ctrPos, isLE); // read current counter value
262
+ let { s0, s1, s2, s3 } = encrypt(xk, c32[0], c32[1], c32[2], c32[3]);
263
+ // process blocks
264
+ for (let i = 0; i + 4 <= src32.length; i += 4) {
265
+ dst32[i + 0] = src32[i + 0] ^ s0;
266
+ dst32[i + 1] = src32[i + 1] ^ s1;
267
+ dst32[i + 2] = src32[i + 2] ^ s2;
268
+ dst32[i + 3] = src32[i + 3] ^ s3;
269
+ ctrNum = (ctrNum + 1) >>> 0; // u32 wrap
270
+ view.setUint32(ctrPos, ctrNum, isLE);
271
+ ({ s0, s1, s2, s3 } = encrypt(xk, c32[0], c32[1], c32[2], c32[3]));
272
+ }
273
+ // leftovers (less than a block)
274
+ const start = BLOCK_SIZE * Math.floor(src32.length / BLOCK_SIZE32);
275
+ if (start < srcLen) {
276
+ const b32 = new Uint32Array([s0, s1, s2, s3]);
277
+ const buf = u8(b32);
278
+ for (let i = start, pos = 0; i < srcLen; i++, pos++)
279
+ dst[i] = src[i] ^ buf[pos];
280
+ clean(b32);
281
+ }
282
+ return dst;
283
+ }
284
+ /**
285
+ * **CTR** (Counter Mode): Turns a block cipher into a stream cipher using a counter and IV (nonce).
286
+ * Efficient and parallelizable. Requires a unique nonce per encryption. Unauthenticated: needs MAC.
287
+ */
288
+ export const ctr = /* @__PURE__ */ wrapCipher({ blockSize: 16, nonceLength: 16 }, function aesctr(key, nonce) {
289
+ function processCtr(buf, dst) {
290
+ abytes(buf);
291
+ if (dst !== undefined) {
292
+ abytes(dst);
293
+ if (!isAligned32(dst))
294
+ throw new Error('unaligned destination');
295
+ }
296
+ const xk = expandKeyLE(key);
297
+ const n = copyBytes(nonce); // align + avoid changing
298
+ const toClean = [xk, n];
299
+ if (!isAligned32(buf))
300
+ toClean.push((buf = copyBytes(buf)));
301
+ const out = ctrCounter(xk, n, buf, dst);
302
+ clean(...toClean);
303
+ return out;
304
+ }
305
+ return {
306
+ encrypt: (plaintext, dst) => processCtr(plaintext, dst),
307
+ decrypt: (ciphertext, dst) => processCtr(ciphertext, dst),
308
+ };
309
+ });
310
+ function validateBlockDecrypt(data) {
311
+ abytes(data);
312
+ if (data.length % BLOCK_SIZE !== 0) {
313
+ throw new Error('aes-(cbc/ecb).decrypt ciphertext should consist of blocks with size ' + BLOCK_SIZE);
314
+ }
315
+ }
316
+ function validateBlockEncrypt(plaintext, pcks5, dst) {
317
+ abytes(plaintext);
318
+ let outLen = plaintext.length;
319
+ const remaining = outLen % BLOCK_SIZE;
320
+ if (!pcks5 && remaining !== 0)
321
+ throw new Error('aec/(cbc-ecb): unpadded plaintext with disabled padding');
322
+ if (!isAligned32(plaintext))
323
+ plaintext = copyBytes(plaintext);
324
+ const b = u32(plaintext);
325
+ if (pcks5) {
326
+ let left = BLOCK_SIZE - remaining;
327
+ if (!left)
328
+ left = BLOCK_SIZE; // if no bytes left, create empty padding block
329
+ outLen = outLen + left;
330
+ }
331
+ dst = getOutput(outLen, dst);
332
+ complexOverlapBytes(plaintext, dst);
333
+ const o = u32(dst);
334
+ return { b, o, out: dst };
335
+ }
336
+ function validatePCKS(data, pcks5) {
337
+ if (!pcks5)
338
+ return data;
339
+ const len = data.length;
340
+ if (!len)
341
+ throw new Error('aes/pcks5: empty ciphertext not allowed');
342
+ const lastByte = data[len - 1];
343
+ if (lastByte <= 0 || lastByte > 16)
344
+ throw new Error('aes/pcks5: wrong padding');
345
+ const out = data.subarray(0, -lastByte);
346
+ for (let i = 0; i < lastByte; i++)
347
+ if (data[len - i - 1] !== lastByte)
348
+ throw new Error('aes/pcks5: wrong padding');
349
+ return out;
350
+ }
351
+ function padPCKS(left) {
352
+ const tmp = new Uint8Array(16);
353
+ const tmp32 = u32(tmp);
354
+ tmp.set(left);
355
+ const paddingByte = BLOCK_SIZE - left.length;
356
+ for (let i = BLOCK_SIZE - paddingByte; i < BLOCK_SIZE; i++)
357
+ tmp[i] = paddingByte;
358
+ return tmp32;
359
+ }
360
+ /**
361
+ * **ECB** (Electronic Codebook): Deterministic encryption; identical plaintext blocks yield
362
+ * identical ciphertexts. Not secure due to pattern leakage.
363
+ * See [AES Penguin](https://words.filippo.io/the-ecb-penguin/).
364
+ */
365
+ export const ecb = /* @__PURE__ */ wrapCipher({ blockSize: 16 }, function aesecb(key, opts = {}) {
366
+ const pcks5 = !opts.disablePadding;
367
+ return {
368
+ encrypt(plaintext, dst) {
369
+ const { b, o, out: _out } = validateBlockEncrypt(plaintext, pcks5, dst);
370
+ const xk = expandKeyLE(key);
371
+ let i = 0;
372
+ for (; i + 4 <= b.length;) {
373
+ const { s0, s1, s2, s3 } = encrypt(xk, b[i + 0], b[i + 1], b[i + 2], b[i + 3]);
374
+ ((o[i++] = s0), (o[i++] = s1), (o[i++] = s2), (o[i++] = s3));
375
+ }
376
+ if (pcks5) {
377
+ const tmp32 = padPCKS(plaintext.subarray(i * 4));
378
+ const { s0, s1, s2, s3 } = encrypt(xk, tmp32[0], tmp32[1], tmp32[2], tmp32[3]);
379
+ ((o[i++] = s0), (o[i++] = s1), (o[i++] = s2), (o[i++] = s3));
380
+ }
381
+ clean(xk);
382
+ return _out;
383
+ },
384
+ decrypt(ciphertext, dst) {
385
+ validateBlockDecrypt(ciphertext);
386
+ const xk = expandKeyDecLE(key);
387
+ dst = getOutput(ciphertext.length, dst);
388
+ const toClean = [xk];
389
+ if (!isAligned32(ciphertext))
390
+ toClean.push((ciphertext = copyBytes(ciphertext)));
391
+ complexOverlapBytes(ciphertext, dst);
392
+ const b = u32(ciphertext);
393
+ const o = u32(dst);
394
+ for (let i = 0; i + 4 <= b.length;) {
395
+ const { s0, s1, s2, s3 } = decrypt(xk, b[i + 0], b[i + 1], b[i + 2], b[i + 3]);
396
+ ((o[i++] = s0), (o[i++] = s1), (o[i++] = s2), (o[i++] = s3));
397
+ }
398
+ clean(...toClean);
399
+ return validatePCKS(dst, pcks5);
400
+ },
401
+ };
402
+ });
403
+ /**
404
+ * **CBC** (Cipher Block Chaining): Each plaintext block is XORed with the
405
+ * previous block of ciphertext before encryption.
406
+ * Hard to use: requires proper padding and an IV. Unauthenticated: needs MAC.
407
+ */
408
+ export const cbc = /* @__PURE__ */ wrapCipher({ blockSize: 16, nonceLength: 16 }, function aescbc(key, iv, opts = {}) {
409
+ const pcks5 = !opts.disablePadding;
410
+ return {
411
+ encrypt(plaintext, dst) {
412
+ const xk = expandKeyLE(key);
413
+ const { b, o, out: _out } = validateBlockEncrypt(plaintext, pcks5, dst);
414
+ let _iv = iv;
415
+ const toClean = [xk];
416
+ if (!isAligned32(_iv))
417
+ toClean.push((_iv = copyBytes(_iv)));
418
+ const n32 = u32(_iv);
419
+ // prettier-ignore
420
+ let s0 = n32[0], s1 = n32[1], s2 = n32[2], s3 = n32[3];
421
+ let i = 0;
422
+ for (; i + 4 <= b.length;) {
423
+ ((s0 ^= b[i + 0]), (s1 ^= b[i + 1]), (s2 ^= b[i + 2]), (s3 ^= b[i + 3]));
424
+ ({ s0, s1, s2, s3 } = encrypt(xk, s0, s1, s2, s3));
425
+ ((o[i++] = s0), (o[i++] = s1), (o[i++] = s2), (o[i++] = s3));
426
+ }
427
+ if (pcks5) {
428
+ const tmp32 = padPCKS(plaintext.subarray(i * 4));
429
+ ((s0 ^= tmp32[0]), (s1 ^= tmp32[1]), (s2 ^= tmp32[2]), (s3 ^= tmp32[3]));
430
+ ({ s0, s1, s2, s3 } = encrypt(xk, s0, s1, s2, s3));
431
+ ((o[i++] = s0), (o[i++] = s1), (o[i++] = s2), (o[i++] = s3));
432
+ }
433
+ clean(...toClean);
434
+ return _out;
435
+ },
436
+ decrypt(ciphertext, dst) {
437
+ validateBlockDecrypt(ciphertext);
438
+ const xk = expandKeyDecLE(key);
439
+ let _iv = iv;
440
+ const toClean = [xk];
441
+ if (!isAligned32(_iv))
442
+ toClean.push((_iv = copyBytes(_iv)));
443
+ const n32 = u32(_iv);
444
+ dst = getOutput(ciphertext.length, dst);
445
+ if (!isAligned32(ciphertext))
446
+ toClean.push((ciphertext = copyBytes(ciphertext)));
447
+ complexOverlapBytes(ciphertext, dst);
448
+ const b = u32(ciphertext);
449
+ const o = u32(dst);
450
+ // prettier-ignore
451
+ let s0 = n32[0], s1 = n32[1], s2 = n32[2], s3 = n32[3];
452
+ for (let i = 0; i + 4 <= b.length;) {
453
+ // prettier-ignore
454
+ const ps0 = s0, ps1 = s1, ps2 = s2, ps3 = s3;
455
+ ((s0 = b[i + 0]), (s1 = b[i + 1]), (s2 = b[i + 2]), (s3 = b[i + 3]));
456
+ const { s0: o0, s1: o1, s2: o2, s3: o3 } = decrypt(xk, s0, s1, s2, s3);
457
+ ((o[i++] = o0 ^ ps0), (o[i++] = o1 ^ ps1), (o[i++] = o2 ^ ps2), (o[i++] = o3 ^ ps3));
458
+ }
459
+ clean(...toClean);
460
+ return validatePCKS(dst, pcks5);
461
+ },
462
+ };
463
+ });
464
+ /**
465
+ * CFB: Cipher Feedback Mode. The input for the block cipher is the previous cipher output.
466
+ * Unauthenticated: needs MAC.
467
+ */
468
+ export const cfb = /* @__PURE__ */ wrapCipher({ blockSize: 16, nonceLength: 16 }, function aescfb(key, iv) {
469
+ function processCfb(src, isEncrypt, dst) {
470
+ abytes(src);
471
+ const srcLen = src.length;
472
+ dst = getOutput(srcLen, dst);
473
+ if (overlapBytes(src, dst))
474
+ throw new Error('overlapping src and dst not supported.');
475
+ const xk = expandKeyLE(key);
476
+ let _iv = iv;
477
+ const toClean = [xk];
478
+ if (!isAligned32(_iv))
479
+ toClean.push((_iv = copyBytes(_iv)));
480
+ if (!isAligned32(src))
481
+ toClean.push((src = copyBytes(src)));
482
+ const src32 = u32(src);
483
+ const dst32 = u32(dst);
484
+ const next32 = isEncrypt ? dst32 : src32;
485
+ const n32 = u32(_iv);
486
+ // prettier-ignore
487
+ let s0 = n32[0], s1 = n32[1], s2 = n32[2], s3 = n32[3];
488
+ for (let i = 0; i + 4 <= src32.length;) {
489
+ const { s0: e0, s1: e1, s2: e2, s3: e3 } = encrypt(xk, s0, s1, s2, s3);
490
+ dst32[i + 0] = src32[i + 0] ^ e0;
491
+ dst32[i + 1] = src32[i + 1] ^ e1;
492
+ dst32[i + 2] = src32[i + 2] ^ e2;
493
+ dst32[i + 3] = src32[i + 3] ^ e3;
494
+ ((s0 = next32[i++]), (s1 = next32[i++]), (s2 = next32[i++]), (s3 = next32[i++]));
495
+ }
496
+ // leftovers (less than block)
497
+ const start = BLOCK_SIZE * Math.floor(src32.length / BLOCK_SIZE32);
498
+ if (start < srcLen) {
499
+ ({ s0, s1, s2, s3 } = encrypt(xk, s0, s1, s2, s3));
500
+ const buf = u8(new Uint32Array([s0, s1, s2, s3]));
501
+ for (let i = start, pos = 0; i < srcLen; i++, pos++)
502
+ dst[i] = src[i] ^ buf[pos];
503
+ clean(buf);
504
+ }
505
+ clean(...toClean);
506
+ return dst;
507
+ }
508
+ return {
509
+ encrypt: (plaintext, dst) => processCfb(plaintext, true, dst),
510
+ decrypt: (ciphertext, dst) => processCfb(ciphertext, false, dst),
511
+ };
512
+ });
513
+ // TODO: merge with chacha, however gcm has bitLen while chacha has byteLen
514
+ function computeTag(fn, isLE, key, data, AAD) {
515
+ const aadLength = AAD ? AAD.length : 0;
516
+ const h = fn.create(key, data.length + aadLength);
517
+ if (AAD)
518
+ h.update(AAD);
519
+ const num = u64Lengths(8 * data.length, 8 * aadLength, isLE);
520
+ h.update(data);
521
+ h.update(num);
522
+ const res = h.digest();
523
+ clean(num);
524
+ return res;
525
+ }
526
+ /**
527
+ * **GCM** (Galois/Counter Mode): Combines CTR mode with polynomial MAC. Efficient and widely used.
528
+ * Not perfect:
529
+ * a) conservative key wear-out is `2**32` (4B) msgs.
530
+ * b) key wear-out under random nonces is even smaller: `2**23` (8M) messages for `2**-50` chance.
531
+ * c) MAC can be forged: see Poly1305 documentation.
532
+ */
533
+ export const gcm = /* @__PURE__ */ wrapCipher({ blockSize: 16, nonceLength: 12, tagLength: 16, varSizeNonce: true }, function aesgcm(key, nonce, AAD) {
534
+ // NIST 800-38d doesn't enforce minimum nonce length.
535
+ // We enforce 8 bytes for compat with openssl.
536
+ // 12 bytes are recommended. More than 12 bytes would be converted into 12.
537
+ if (nonce.length < 8)
538
+ throw new Error('aes/gcm: invalid nonce length');
539
+ const tagLength = 16;
540
+ function _computeTag(authKey, tagMask, data) {
541
+ const tag = computeTag(ghash, false, authKey, data, AAD);
542
+ for (let i = 0; i < tagMask.length; i++)
543
+ tag[i] ^= tagMask[i];
544
+ return tag;
545
+ }
546
+ function deriveKeys() {
547
+ const xk = expandKeyLE(key);
548
+ const authKey = EMPTY_BLOCK.slice();
549
+ const counter = EMPTY_BLOCK.slice();
550
+ ctr32(xk, false, counter, counter, authKey);
551
+ // NIST 800-38d, page 15: different behavior for 96-bit and non-96-bit nonces
552
+ if (nonce.length === 12) {
553
+ counter.set(nonce);
554
+ }
555
+ else {
556
+ const nonceLen = EMPTY_BLOCK.slice();
557
+ const view = createView(nonceLen);
558
+ view.setBigUint64(8, BigInt(nonce.length * 8), false);
559
+ // ghash(nonce || u64be(0) || u64be(nonceLen*8))
560
+ const g = ghash.create(authKey).update(nonce).update(nonceLen);
561
+ g.digestInto(counter); // digestInto doesn't trigger '.destroy'
562
+ g.destroy();
563
+ }
564
+ const tagMask = ctr32(xk, false, counter, EMPTY_BLOCK);
565
+ return { xk, authKey, counter, tagMask };
566
+ }
567
+ return {
568
+ encrypt(plaintext) {
569
+ const { xk, authKey, counter, tagMask } = deriveKeys();
570
+ const out = new Uint8Array(plaintext.length + tagLength);
571
+ const toClean = [xk, authKey, counter, tagMask];
572
+ if (!isAligned32(plaintext))
573
+ toClean.push((plaintext = copyBytes(plaintext)));
574
+ ctr32(xk, false, counter, plaintext, out.subarray(0, plaintext.length));
575
+ const tag = _computeTag(authKey, tagMask, out.subarray(0, out.length - tagLength));
576
+ toClean.push(tag);
577
+ out.set(tag, plaintext.length);
578
+ clean(...toClean);
579
+ return out;
580
+ },
581
+ decrypt(ciphertext) {
582
+ const { xk, authKey, counter, tagMask } = deriveKeys();
583
+ const toClean = [xk, authKey, tagMask, counter];
584
+ if (!isAligned32(ciphertext))
585
+ toClean.push((ciphertext = copyBytes(ciphertext)));
586
+ const data = ciphertext.subarray(0, -tagLength);
587
+ const passedTag = ciphertext.subarray(-tagLength);
588
+ const tag = _computeTag(authKey, tagMask, data);
589
+ toClean.push(tag);
590
+ if (!equalBytes(tag, passedTag))
591
+ throw new Error('aes/gcm: invalid ghash tag');
592
+ const out = ctr32(xk, false, counter, data);
593
+ clean(...toClean);
594
+ return out;
595
+ },
596
+ };
597
+ });
598
+ const limit = (name, min, max) => (value) => {
599
+ if (!Number.isSafeInteger(value) || min > value || value > max) {
600
+ const minmax = '[' + min + '..' + max + ']';
601
+ throw new Error('' + name + ': expected value in range ' + minmax + ', got ' + value);
602
+ }
603
+ };
604
+ /**
605
+ * **SIV** (Synthetic IV): GCM with nonce-misuse resistance.
606
+ * Repeating nonces reveal only the fact plaintexts are identical.
607
+ * Also suffers from GCM issues: key wear-out limits & MAC forging.
608
+ * See [RFC 8452](https://www.rfc-editor.org/rfc/rfc8452).
609
+ */
610
+ export const gcmsiv = /* @__PURE__ */ wrapCipher({ blockSize: 16, nonceLength: 12, tagLength: 16, varSizeNonce: true }, function aessiv(key, nonce, AAD) {
611
+ const tagLength = 16;
612
+ // From RFC 8452: Section 6
613
+ const AAD_LIMIT = limit('AAD', 0, 2 ** 36);
614
+ const PLAIN_LIMIT = limit('plaintext', 0, 2 ** 36);
615
+ const NONCE_LIMIT = limit('nonce', 12, 12);
616
+ const CIPHER_LIMIT = limit('ciphertext', 16, 2 ** 36 + 16);
617
+ abytes(key);
618
+ validateKeyLength(key);
619
+ NONCE_LIMIT(nonce.length);
620
+ if (AAD !== undefined)
621
+ AAD_LIMIT(AAD.length);
622
+ function deriveKeys() {
623
+ const xk = expandKeyLE(key);
624
+ const encKey = new Uint8Array(key.length);
625
+ const authKey = new Uint8Array(16);
626
+ const toClean = [xk, encKey];
627
+ let _nonce = nonce;
628
+ if (!isAligned32(_nonce))
629
+ toClean.push((_nonce = copyBytes(_nonce)));
630
+ const n32 = u32(_nonce);
631
+ // prettier-ignore
632
+ let s0 = 0, s1 = n32[0], s2 = n32[1], s3 = n32[2];
633
+ let counter = 0;
634
+ for (const derivedKey of [authKey, encKey].map(u32)) {
635
+ const d32 = u32(derivedKey);
636
+ for (let i = 0; i < d32.length; i += 2) {
637
+ // aes(u32le(0) || nonce)[:8] || aes(u32le(1) || nonce)[:8] ...
638
+ const { s0: o0, s1: o1 } = encrypt(xk, s0, s1, s2, s3);
639
+ d32[i + 0] = o0;
640
+ d32[i + 1] = o1;
641
+ s0 = ++counter; // increment counter inside state
642
+ }
643
+ }
644
+ const res = { authKey, encKey: expandKeyLE(encKey) };
645
+ // Cleanup
646
+ clean(...toClean);
647
+ return res;
648
+ }
649
+ function _computeTag(encKey, authKey, data) {
650
+ const tag = computeTag(polyval, true, authKey, data, AAD);
651
+ // Compute the expected tag by XORing S_s and the nonce, clearing the
652
+ // most significant bit of the last byte and encrypting with the
653
+ // message-encryption key.
654
+ for (let i = 0; i < 12; i++)
655
+ tag[i] ^= nonce[i];
656
+ tag[15] &= 0x7f; // Clear the highest bit
657
+ // encrypt tag as block
658
+ const t32 = u32(tag);
659
+ // prettier-ignore
660
+ let s0 = t32[0], s1 = t32[1], s2 = t32[2], s3 = t32[3];
661
+ ({ s0, s1, s2, s3 } = encrypt(encKey, s0, s1, s2, s3));
662
+ ((t32[0] = s0), (t32[1] = s1), (t32[2] = s2), (t32[3] = s3));
663
+ return tag;
664
+ }
665
+ // actual decrypt/encrypt of message.
666
+ function processSiv(encKey, tag, input) {
667
+ let block = copyBytes(tag);
668
+ block[15] |= 0x80; // Force highest bit
669
+ const res = ctr32(encKey, true, block, input);
670
+ // Cleanup
671
+ clean(block);
672
+ return res;
673
+ }
674
+ return {
675
+ encrypt(plaintext) {
676
+ PLAIN_LIMIT(plaintext.length);
677
+ const { encKey, authKey } = deriveKeys();
678
+ const tag = _computeTag(encKey, authKey, plaintext);
679
+ const toClean = [encKey, authKey, tag];
680
+ if (!isAligned32(plaintext))
681
+ toClean.push((plaintext = copyBytes(plaintext)));
682
+ const out = new Uint8Array(plaintext.length + tagLength);
683
+ out.set(tag, plaintext.length);
684
+ out.set(processSiv(encKey, tag, plaintext));
685
+ // Cleanup
686
+ clean(...toClean);
687
+ return out;
688
+ },
689
+ decrypt(ciphertext) {
690
+ CIPHER_LIMIT(ciphertext.length);
691
+ const tag = ciphertext.subarray(-tagLength);
692
+ const { encKey, authKey } = deriveKeys();
693
+ const toClean = [encKey, authKey];
694
+ if (!isAligned32(ciphertext))
695
+ toClean.push((ciphertext = copyBytes(ciphertext)));
696
+ const plaintext = processSiv(encKey, tag, ciphertext.subarray(0, -tagLength));
697
+ const expectedTag = _computeTag(encKey, authKey, plaintext);
698
+ toClean.push(expectedTag);
699
+ if (!equalBytes(tag, expectedTag)) {
700
+ clean(...toClean);
701
+ throw new Error('invalid polyval tag');
702
+ }
703
+ // Cleanup
704
+ clean(...toClean);
705
+ return plaintext;
706
+ },
707
+ };
708
+ });
709
+ function isBytes32(a) {
710
+ return (a instanceof Uint32Array || (ArrayBuffer.isView(a) && a.constructor.name === 'Uint32Array'));
711
+ }
712
+ function encryptBlock(xk, block) {
713
+ abytes(block, 16, 'block');
714
+ if (!isBytes32(xk))
715
+ throw new Error('_encryptBlock accepts result of expandKeyLE');
716
+ const b32 = u32(block);
717
+ let { s0, s1, s2, s3 } = encrypt(xk, b32[0], b32[1], b32[2], b32[3]);
718
+ ((b32[0] = s0), (b32[1] = s1), (b32[2] = s2), (b32[3] = s3));
719
+ return block;
720
+ }
721
+ function decryptBlock(xk, block) {
722
+ abytes(block, 16, 'block');
723
+ if (!isBytes32(xk))
724
+ throw new Error('_decryptBlock accepts result of expandKeyLE');
725
+ const b32 = u32(block);
726
+ let { s0, s1, s2, s3 } = decrypt(xk, b32[0], b32[1], b32[2], b32[3]);
727
+ ((b32[0] = s0), (b32[1] = s1), (b32[2] = s2), (b32[3] = s3));
728
+ return block;
729
+ }
730
+ /**
731
+ * AES-W (base for AESKW/AESKWP).
732
+ * Specs: [SP800-38F](https://nvlpubs.nist.gov/nistpubs/SpecialPublications/NIST.SP.800-38F.pdf),
733
+ * [RFC 3394](https://www.rfc-editor.org/rfc/rfc3394),
734
+ * [RFC 5649](https://www.rfc-editor.org/rfc/rfc5649).
735
+ */
736
+ const AESW = {
737
+ /*
738
+ High-level pseudocode:
739
+ ```
740
+ A: u64 = IV
741
+ out = []
742
+ for (let i=0, ctr = 0; i<6; i++) {
743
+ for (const chunk of chunks(plaintext, 8)) {
744
+ A ^= swapEndianess(ctr++)
745
+ [A, res] = chunks(encrypt(A || chunk), 8);
746
+ out ||= res
747
+ }
748
+ }
749
+ out = A || out
750
+ ```
751
+ Decrypt is the same, but reversed.
752
+ */
753
+ encrypt(kek, out) {
754
+ // Size is limited to 4GB, otherwise ctr will overflow and we'll need to switch to bigints.
755
+ // If you need it larger, open an issue.
756
+ if (out.length >= 2 ** 32)
757
+ throw new Error('plaintext should be less than 4gb');
758
+ const xk = expandKeyLE(kek);
759
+ if (out.length === 16)
760
+ encryptBlock(xk, out);
761
+ else {
762
+ const o32 = u32(out);
763
+ // prettier-ignore
764
+ let a0 = o32[0], a1 = o32[1]; // A
765
+ for (let j = 0, ctr = 1; j < 6; j++) {
766
+ for (let pos = 2; pos < o32.length; pos += 2, ctr++) {
767
+ const { s0, s1, s2, s3 } = encrypt(xk, a0, a1, o32[pos], o32[pos + 1]);
768
+ // A = MSB(64, B) ^ t where t = (n*j)+i
769
+ ((a0 = s0), (a1 = s1 ^ byteSwap(ctr)), (o32[pos] = s2), (o32[pos + 1] = s3));
770
+ }
771
+ }
772
+ ((o32[0] = a0), (o32[1] = a1)); // out = A || out
773
+ }
774
+ xk.fill(0);
775
+ },
776
+ decrypt(kek, out) {
777
+ if (out.length - 8 >= 2 ** 32)
778
+ throw new Error('ciphertext should be less than 4gb');
779
+ const xk = expandKeyDecLE(kek);
780
+ const chunks = out.length / 8 - 1; // first chunk is IV
781
+ if (chunks === 1)
782
+ decryptBlock(xk, out);
783
+ else {
784
+ const o32 = u32(out);
785
+ // prettier-ignore
786
+ let a0 = o32[0], a1 = o32[1]; // A
787
+ for (let j = 0, ctr = chunks * 6; j < 6; j++) {
788
+ for (let pos = chunks * 2; pos >= 1; pos -= 2, ctr--) {
789
+ a1 ^= byteSwap(ctr);
790
+ const { s0, s1, s2, s3 } = decrypt(xk, a0, a1, o32[pos], o32[pos + 1]);
791
+ ((a0 = s0), (a1 = s1), (o32[pos] = s2), (o32[pos + 1] = s3));
792
+ }
793
+ }
794
+ ((o32[0] = a0), (o32[1] = a1));
795
+ }
796
+ xk.fill(0);
797
+ },
798
+ };
799
+ const AESKW_IV = /* @__PURE__ */ new Uint8Array(8).fill(0xa6); // A6A6A6A6A6A6A6A6
800
+ /**
801
+ * AES-KW (key-wrap). Injects static IV into plaintext, adds counter, encrypts 6 times.
802
+ * Reduces block size from 16 to 8 bytes.
803
+ * For padded version, use aeskwp.
804
+ * [RFC 3394](https://www.rfc-editor.org/rfc/rfc3394/),
805
+ * [NIST.SP.800-38F](https://nvlpubs.nist.gov/nistpubs/SpecialPublications/NIST.SP.800-38F.pdf).
806
+ */
807
+ export const aeskw = /* @__PURE__ */ wrapCipher({ blockSize: 8 }, (kek) => ({
808
+ encrypt(plaintext) {
809
+ if (!plaintext.length || plaintext.length % 8 !== 0)
810
+ throw new Error('invalid plaintext length');
811
+ if (plaintext.length === 8)
812
+ throw new Error('8-byte keys not allowed in AESKW, use AESKWP instead');
813
+ const out = concatBytes(AESKW_IV, plaintext);
814
+ AESW.encrypt(kek, out);
815
+ return out;
816
+ },
817
+ decrypt(ciphertext) {
818
+ // ciphertext must be at least 24 bytes and a multiple of 8 bytes
819
+ // 24 because should have at least two block (1 iv + 2).
820
+ // Replace with 16 to enable '8-byte keys'
821
+ if (ciphertext.length % 8 !== 0 || ciphertext.length < 3 * 8)
822
+ throw new Error('invalid ciphertext length');
823
+ const out = copyBytes(ciphertext);
824
+ AESW.decrypt(kek, out);
825
+ if (!equalBytes(out.subarray(0, 8), AESKW_IV))
826
+ throw new Error('integrity check failed');
827
+ out.subarray(0, 8).fill(0); // ciphertext.subarray(0, 8) === IV, but we clean it anyway
828
+ return out.subarray(8);
829
+ },
830
+ }));
831
+ /*
832
+ We don't support 8-byte keys. The rabbit hole:
833
+
834
+ - Wycheproof says: "NIST SP 800-38F does not define the wrapping of 8 byte keys.
835
+ RFC 3394 Section 2 on the other hand specifies that 8 byte keys are wrapped
836
+ by directly encrypting one block with AES."
837
+ - https://github.com/C2SP/wycheproof/blob/master/doc/key_wrap.md
838
+ - "RFC 3394 specifies in Section 2, that the input for the key wrap
839
+ algorithm must be at least two blocks and otherwise the constant
840
+ field and key are simply encrypted with ECB as a single block"
841
+ - What RFC 3394 actually says (in Section 2):
842
+ - "Before being wrapped, the key data is parsed into n blocks of 64 bits.
843
+ The only restriction the key wrap algorithm places on n is that n be
844
+ at least two"
845
+ - "For key data with length less than or equal to 64 bits, the constant
846
+ field used in this specification and the key data form a single
847
+ 128-bit codebook input making this key wrap unnecessary."
848
+ - Which means "assert(n >= 2)" and "use something else for 8 byte keys"
849
+ - NIST SP800-38F actually prohibits 8-byte in "5.3.1 Mandatory Limits".
850
+ It states that plaintext for KW should be "2 to 2^54 -1 semiblocks".
851
+ - So, where does "directly encrypt single block with AES" come from?
852
+ - Not RFC 3394. Pseudocode of key wrap in 2.2 explicitly uses
853
+ loop of 6 for any code path
854
+ - There is a weird W3C spec:
855
+ https://www.w3.org/TR/2002/REC-xmlenc-core-20021210/Overview.html#kw-aes128
856
+ - This spec is outdated, as admitted by Wycheproof authors
857
+ - There is RFC 5649 for padded key wrap, which is padding construction on
858
+ top of AESKW. In '4.1.2' it says: "If the padded plaintext contains exactly
859
+ eight octets, then prepend the AIV as defined in Section 3 above to P[1] and
860
+ encrypt the resulting 128-bit block using AES in ECB mode [Modes] with key
861
+ K (the KEK). In this case, the output is two 64-bit blocks C[0] and C[1]:"
862
+ - Browser subtle crypto is actually crashes on wrapping keys less than 16 bytes:
863
+ `Error: error:1C8000E6:Provider routines::invalid input length] { opensslErrorStack: [ 'error:030000BD:digital envelope routines::update error' ]`
864
+
865
+ In the end, seems like a bug in Wycheproof.
866
+ The 8-byte check can be easily disabled inside of AES_W.
867
+ */
868
+ const AESKWP_IV = 0xa65959a6; // single u32le value
869
+ /**
870
+ * AES-KW, but with padding and allows random keys.
871
+ * Second u32 of IV is used as counter for length.
872
+ * [RFC 5649](https://www.rfc-editor.org/rfc/rfc5649)
873
+ */
874
+ export const aeskwp = /* @__PURE__ */ wrapCipher({ blockSize: 8 }, (kek) => ({
875
+ encrypt(plaintext) {
876
+ if (!plaintext.length)
877
+ throw new Error('invalid plaintext length');
878
+ const padded = Math.ceil(plaintext.length / 8) * 8;
879
+ const out = new Uint8Array(8 + padded);
880
+ out.set(plaintext, 8);
881
+ const out32 = u32(out);
882
+ out32[0] = AESKWP_IV;
883
+ out32[1] = byteSwap(plaintext.length);
884
+ AESW.encrypt(kek, out);
885
+ return out;
886
+ },
887
+ decrypt(ciphertext) {
888
+ // 16 because should have at least one block
889
+ if (ciphertext.length < 16)
890
+ throw new Error('invalid ciphertext length');
891
+ const out = copyBytes(ciphertext);
892
+ const o32 = u32(out);
893
+ AESW.decrypt(kek, out);
894
+ const len = byteSwap(o32[1]) >>> 0;
895
+ const padded = Math.ceil(len / 8) * 8;
896
+ if (o32[0] !== AESKWP_IV || out.length - 8 !== padded)
897
+ throw new Error('integrity check failed');
898
+ for (let i = len; i < padded; i++)
899
+ if (out[8 + i] !== 0)
900
+ throw new Error('integrity check failed');
901
+ out.subarray(0, 8).fill(0); // ciphertext.subarray(0, 8) === IV, but we clean it anyway
902
+ return out.subarray(8, 8 + len);
903
+ },
904
+ }));
905
+ class _AesCtrDRBG {
906
+ blockLen;
907
+ key;
908
+ nonce;
909
+ state;
910
+ reseedCnt;
911
+ constructor(keyLen, seed, personalization) {
912
+ this.blockLen = ctr.blockSize;
913
+ const keyLenBytes = keyLen / 8;
914
+ const nonceLen = 16;
915
+ this.state = new Uint8Array(keyLenBytes + nonceLen);
916
+ this.key = this.state.subarray(0, keyLenBytes);
917
+ this.nonce = this.state.subarray(keyLenBytes, keyLenBytes + nonceLen);
918
+ this.reseedCnt = 1;
919
+ incBytes(this.nonce, false, 1);
920
+ this.addEntropy(seed, personalization);
921
+ }
922
+ update(data) {
923
+ // cannot re-use state here, because we will wipe current key
924
+ ctr(this.key, this.nonce).encrypt(new Uint8Array(this.state.length), this.state);
925
+ if (data) {
926
+ abytes(data);
927
+ for (let i = 0; i < data.length; i++)
928
+ this.state[i] ^= data[i];
929
+ }
930
+ incBytes(this.nonce, false, 1);
931
+ }
932
+ addEntropy(seed, info) {
933
+ abytes(seed, this.state.length, 'seed');
934
+ const _seed = seed.slice();
935
+ if (info) {
936
+ abytes(info);
937
+ if (info.length > _seed.length)
938
+ throw new Error('info length is too big');
939
+ for (let i = 0; i < info.length; i++)
940
+ _seed[i] ^= info[i];
941
+ }
942
+ this.update(_seed);
943
+ _seed.fill(0);
944
+ this.reseedCnt = 1;
945
+ }
946
+ randomBytes(len, info) {
947
+ anumber(len);
948
+ if (this.reseedCnt++ >= 2 ** 48)
949
+ throw new Error('entropy exhausted');
950
+ if (info)
951
+ this.update(info);
952
+ const res = new Uint8Array(len);
953
+ ctr(this.key, this.nonce).encrypt(res, res);
954
+ incBytes(this.nonce, false, Math.ceil(len / this.blockLen));
955
+ this.update(info);
956
+ return res;
957
+ }
958
+ clean() {
959
+ this.state.fill(0);
960
+ this.reseedCnt = 0;
961
+ }
962
+ }
963
+ const createAesDrbg = (keyLen) => {
964
+ return (seed, personalization = undefined) => new _AesCtrDRBG(keyLen, seed, personalization);
965
+ };
966
+ /**
967
+ * AES-CTR DRBG 128-bit - CSPRNG (cryptographically secure pseudorandom number generator).
968
+ * It's best to limit usage to non-production, non-critical cases: for example, test-only.
969
+ */
970
+ export const rngAesCtrDrbg128 = /* @__PURE__ */ createAesDrbg(128);
971
+ /**
972
+ * AES-CTR DRBG 256-bit - CSPRNG (cryptographically secure pseudorandom number generator).
973
+ * It's best to limit usage to non-production, non-critical cases: for example, test-only.
974
+ */
975
+ export const rngAesCtrDrbg256 = /* @__PURE__ */ createAesDrbg(256);
976
+ //#region CMAC
977
+ /**
978
+ * Left-shift by one bit and conditionally XOR with 0x87:
979
+ * ```
980
+ * if MSB(L) is equal to 0
981
+ * then K1 := L << 1;
982
+ * else K1 := (L << 1) XOR const_Rb;
983
+ * ```
984
+ *
985
+ * Specs: [RFC 4493, Section 2.3](https://www.rfc-editor.org/rfc/rfc4493.html#section-2.3),
986
+ * [RFC 5297 Section 2.3](https://datatracker.ietf.org/doc/html/rfc5297.html#section-2.3)
987
+ *
988
+ * @returns modified `block` (for chaining)
989
+ */
990
+ function dbl(block) {
991
+ let carry = 0;
992
+ // Left shift by 1 bit
993
+ for (let i = BLOCK_SIZE - 1; i >= 0; i--) {
994
+ const newCarry = (block[i] & 0x80) >>> 7;
995
+ block[i] = (block[i] << 1) | carry;
996
+ carry = newCarry;
997
+ }
998
+ // XOR with 0x87 if there was a carry from the most significant bit
999
+ if (carry) {
1000
+ block[BLOCK_SIZE - 1] ^= 0x87;
1001
+ }
1002
+ return block;
1003
+ }
1004
+ /**
1005
+ * `a XOR b`, running in-site on `a`.
1006
+ * @param a left operand and output
1007
+ * @param b right operand
1008
+ * @returns `a` (for chaining)
1009
+ */
1010
+ function xorBlock(a, b) {
1011
+ if (a.length !== b.length)
1012
+ throw new Error('xorBlock: blocks must have same length');
1013
+ for (let i = 0; i < a.length; i++) {
1014
+ a[i] = a[i] ^ b[i];
1015
+ }
1016
+ return a;
1017
+ }
1018
+ /**
1019
+ * xorend as defined in [RFC 5297 Section 2.1](https://datatracker.ietf.org/doc/html/rfc5297.html#section-2.1).
1020
+ *
1021
+ * ```
1022
+ * leftmost(A, len(A)-len(B)) || (rightmost(A, len(B)) xor B)
1023
+ * ```
1024
+ */
1025
+ function xorend(a, b) {
1026
+ if (b.length > a.length) {
1027
+ throw new Error('xorend: len(B) must be less than or equal to len(A)');
1028
+ }
1029
+ // keep leftmost part of `a` unchanged
1030
+ // and xor only the rightmost part:
1031
+ const offset = a.length - b.length;
1032
+ for (let i = 0; i < b.length; i++) {
1033
+ a[offset + i] = a[offset + i] ^ b[i];
1034
+ }
1035
+ return a;
1036
+ }
1037
+ /**
1038
+ * Internal CMAC class.
1039
+ */
1040
+ class _CMAC {
1041
+ buffer;
1042
+ destroyed;
1043
+ k1;
1044
+ k2;
1045
+ xk;
1046
+ constructor(key) {
1047
+ abytes(key);
1048
+ validateKeyLength(key);
1049
+ this.xk = expandKeyLE(key);
1050
+ this.buffer = new Uint8Array(0);
1051
+ this.destroyed = false;
1052
+ // L = AES_encrypt(K, const_Zero)
1053
+ const L = new Uint8Array(BLOCK_SIZE);
1054
+ encryptBlock(this.xk, L);
1055
+ // Generate subkeys K1 and K2 from the main key according to
1056
+ // [RFC 4493, Section 2.3](https://www.rfc-editor.org/rfc/rfc4493.html#section-2.3)
1057
+ // K1
1058
+ this.k1 = dbl(L);
1059
+ this.k2 = dbl(new Uint8Array(this.k1));
1060
+ }
1061
+ update(data) {
1062
+ const { destroyed, buffer } = this;
1063
+ if (destroyed)
1064
+ throw new Error('CMAC instance was destroyed');
1065
+ abytes(data);
1066
+ const newBuffer = new Uint8Array(buffer.length + data.length);
1067
+ newBuffer.set(buffer);
1068
+ newBuffer.set(data, buffer.length);
1069
+ this.buffer = newBuffer;
1070
+ return this;
1071
+ }
1072
+ // see https://www.rfc-editor.org/rfc/rfc4493.html#section-2.4
1073
+ digest() {
1074
+ if (this.destroyed)
1075
+ throw new Error('CMAC instance was destroyed');
1076
+ const { buffer } = this;
1077
+ const msgLen = buffer.length;
1078
+ // Step 2:
1079
+ let n = Math.ceil(msgLen / BLOCK_SIZE); // n := ceil(len/const_Bsize);
1080
+ // Step 3:
1081
+ let flag; // denoting if last block is complete or not
1082
+ if (n === 0) {
1083
+ n = 1;
1084
+ flag = false;
1085
+ }
1086
+ else {
1087
+ flag = msgLen % BLOCK_SIZE === 0; // if len mod const_Bsize is 0
1088
+ }
1089
+ // Step 4:
1090
+ const lastBlockStart = (n - 1) * BLOCK_SIZE;
1091
+ const lastBlockData = buffer.subarray(lastBlockStart);
1092
+ let m_last;
1093
+ if (flag) {
1094
+ // M_last := M_n XOR K1;
1095
+ m_last = xorBlock(new Uint8Array(lastBlockData), this.k1);
1096
+ }
1097
+ else {
1098
+ // M_last := padding(M_n) XOR K2;
1099
+ //
1100
+ // [...] padding(x) is the concatenation of x and a single '1',
1101
+ // followed by the minimum number of '0's, so that the total length is
1102
+ // equal to 128 bits.
1103
+ const padded = new Uint8Array(BLOCK_SIZE);
1104
+ padded.set(lastBlockData);
1105
+ padded[lastBlockData.length] = 0x80; // single '1' bit
1106
+ m_last = xorBlock(padded, this.k2);
1107
+ }
1108
+ // Step 5:
1109
+ let x = new Uint8Array(BLOCK_SIZE); // X := const_Zero;
1110
+ // Step 6:
1111
+ for (let i = 0; i < n - 1; i++) {
1112
+ const m_i = buffer.subarray(i * BLOCK_SIZE, (i + 1) * BLOCK_SIZE); // M_i
1113
+ xorBlock(x, m_i); // Y := X XOR M_i;
1114
+ encryptBlock(this.xk, x); // X := AES-128(K,Y);
1115
+ }
1116
+ // Step 7:
1117
+ xorBlock(x, m_last); // Y := M_last XOR X;
1118
+ encryptBlock(this.xk, x); // T := AES-128(K,Y);
1119
+ // cleanup:
1120
+ clean(m_last);
1121
+ return x; // T
1122
+ }
1123
+ destroy() {
1124
+ const { buffer, destroyed, xk, k1, k2 } = this;
1125
+ if (destroyed)
1126
+ return;
1127
+ this.destroyed = true;
1128
+ clean(buffer, xk, k1, k2);
1129
+ }
1130
+ }
1131
+ /**
1132
+ * AES-CMAC (Cipher-based Message Authentication Code).
1133
+ * Specs: [RFC 4493](https://www.rfc-editor.org/rfc/rfc4493.html).
1134
+ */
1135
+ export const cmac = (key, message) => new _CMAC(key).update(message).digest();
1136
+ cmac.create = (key) => new _CMAC(key);
1137
+ /**
1138
+ * S2V (Synthetic Initialization Vector) function as described in [RFC 5297 Section 2.4](https://datatracker.ietf.org/doc/html/rfc5297.html#section-2.4).
1139
+ *
1140
+ * ```
1141
+ * S2V(K, S1, ..., Sn) {
1142
+ * if n = 0 then
1143
+ * return V = AES-CMAC(K, <one>)
1144
+ * fi
1145
+ * D = AES-CMAC(K, <zero>)
1146
+ * for i = 1 to n-1 do
1147
+ * D = dbl(D) xor AES-CMAC(K, Si)
1148
+ * done
1149
+ * if len(Sn) >= 128 then
1150
+ * T = Sn xorend D
1151
+ * else
1152
+ * T = dbl(D) xor pad(Sn)
1153
+ * fi
1154
+ * return V = AES-CMAC(K, T)
1155
+ * }
1156
+ * ```
1157
+ *
1158
+ * S2V takes a key and a vector of strings S1, S2, ..., Sn and returns a 128-bit string.
1159
+ * The S2V function is used to generate a synthetic IV for AES-SIV.
1160
+ *
1161
+ * @param key - AES key (128, 192, or 256 bits)
1162
+ * @param strings - Array of byte arrays to process
1163
+ * @returns 128-bit synthetic IV
1164
+ */
1165
+ function s2v(key, strings) {
1166
+ validateKeyLength(key);
1167
+ const len = strings.length;
1168
+ if (len > 127) {
1169
+ // see https://datatracker.ietf.org/doc/html/rfc5297.html#section-7
1170
+ throw new Error('s2v: number of input strings must be less than or equal to 127');
1171
+ }
1172
+ if (len === 0)
1173
+ return cmac(key, ONE_BLOCK);
1174
+ // D = AES-CMAC(K, <zero>)
1175
+ let d = cmac(key, EMPTY_BLOCK);
1176
+ // for i = 1 to n-1 do
1177
+ // D = dbl(D) xor AES-CMAC(K, Si)
1178
+ for (let i = 0; i < len - 1; i++) {
1179
+ dbl(d);
1180
+ const cmacResult = cmac(key, strings[i]);
1181
+ xorBlock(d, cmacResult);
1182
+ clean(cmacResult);
1183
+ }
1184
+ const s_n = strings[len - 1];
1185
+ let t;
1186
+ // if len(Sn) >= 128 then
1187
+ if (s_n.byteLength >= BLOCK_SIZE) {
1188
+ // T = Sn xorend D
1189
+ t = xorend(Uint8Array.from(s_n), d);
1190
+ }
1191
+ else {
1192
+ // pad(Sn):
1193
+ const paddedSn = new Uint8Array(BLOCK_SIZE);
1194
+ paddedSn.set(s_n);
1195
+ paddedSn[s_n.length] = 0x80; // padding: 0x80 followed by zeros
1196
+ // T = dbl(D) xor pad(Sn)
1197
+ t = xorBlock(dbl(d), paddedSn);
1198
+ clean(paddedSn);
1199
+ }
1200
+ // V = AES-CMAC(K, T)
1201
+ const result = cmac(key, t);
1202
+ clean(d, t);
1203
+ return result;
1204
+ }
1205
+ /** Use `gcmsiv` or `aessiv`. */
1206
+ export const siv = () => {
1207
+ throw new Error('"siv" from v1 is now "gcmsiv"');
1208
+ };
1209
+ /**
1210
+ * **SIV**: Synthetic Initialization Vector (SIV) Authenticated Encryption
1211
+ * Nonce is derived from the plaintext and AAD using the S2V function.
1212
+ * See [RFC 5297](https://datatracker.ietf.org/doc/html/rfc5297.html).
1213
+ */
1214
+ export const aessiv = /* @__PURE__ */ wrapCipher({ blockSize: 16, tagLength: 16 }, function aessiv(key, ...AAD) {
1215
+ // From RFC 5297: Section 6.1, 6.2, 6.3:
1216
+ const PLAIN_LIMIT = limit('plaintext', 0, 2 ** 132);
1217
+ const CIPHER_LIMIT = limit('ciphertext', 16, 2 ** 132 + 16);
1218
+ if (AAD.length > 126) {
1219
+ // see https://datatracker.ietf.org/doc/html/rfc5297.html#section-7
1220
+ throw new Error('"AAD" number of elements must be less than or equal to 126');
1221
+ }
1222
+ AAD.forEach((aad) => abytes(aad));
1223
+ abytes(key);
1224
+ if (![32, 48, 64].includes(key.length))
1225
+ throw new Error('"aes key" expected Uint8Array of length 32/48/64, got length=' + key.length);
1226
+ // The key is split into equal halves, K1 = leftmost(K, len(K)/2) and
1227
+ // K2 = rightmost(K, len(K)/2). K1 is used for S2V and K2 is used for CTR.
1228
+ const k1 = key.subarray(0, key.length / 2);
1229
+ const k2 = key.subarray(key.length / 2);
1230
+ return {
1231
+ // https://datatracker.ietf.org/doc/html/rfc5297.html#section-2.6
1232
+ encrypt(plaintext) {
1233
+ PLAIN_LIMIT(plaintext.length);
1234
+ const v = s2v(k1, [...AAD, plaintext]);
1235
+ // clear out the 31st and 63rd (rightmost) bit:
1236
+ const q = Uint8Array.from(v);
1237
+ q[8] &= 0x7f;
1238
+ q[12] &= 0x7f;
1239
+ // encrypt:
1240
+ const c = ctr(k2, q).encrypt(plaintext);
1241
+ return concatBytes(v, c);
1242
+ },
1243
+ // https://datatracker.ietf.org/doc/html/rfc5297.html#section-2.7
1244
+ decrypt(ciphertext) {
1245
+ CIPHER_LIMIT(ciphertext.length);
1246
+ const v = ciphertext.subarray(0, BLOCK_SIZE);
1247
+ const c = ciphertext.subarray(BLOCK_SIZE);
1248
+ // clear out the 31st and 63rd (rightmost) bit:
1249
+ const q = Uint8Array.from(v);
1250
+ q[8] &= 0x7f;
1251
+ q[12] &= 0x7f;
1252
+ // decrypt:
1253
+ const p = ctr(k2, q).decrypt(c);
1254
+ // verify tag:
1255
+ const t = s2v(k1, [...AAD, p]);
1256
+ if (equalBytes(t, v)) {
1257
+ return p;
1258
+ }
1259
+ else {
1260
+ throw new Error('invalid siv tag');
1261
+ }
1262
+ },
1263
+ };
1264
+ });
1265
+ //#endregion
1266
+ /** Unsafe low-level internal methods. May change at any time. */
1267
+ export const unsafe = {
1268
+ expandKeyLE,
1269
+ expandKeyDecLE,
1270
+ encrypt,
1271
+ decrypt,
1272
+ encryptBlock,
1273
+ decryptBlock,
1274
+ ctrCounter,
1275
+ ctr32,
1276
+ dbl,
1277
+ xorBlock,
1278
+ xorend,
1279
+ s2v,
1280
+ };
1281
+ //# sourceMappingURL=aes.js.map