react-native-quick-crypto 1.1.0 → 1.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (815) hide show
  1. package/QuickCrypto.podspec +1 -0
  2. package/android/CMakeLists.txt +4 -0
  3. package/android/build.gradle +5 -1
  4. package/cpp/argon2/HybridArgon2.cpp +10 -3
  5. package/cpp/blake3/HybridBlake3.cpp +5 -3
  6. package/cpp/cipher/CCMCipher.cpp +35 -26
  7. package/cpp/cipher/CCMCipher.hpp +2 -4
  8. package/cpp/cipher/ChaCha20Cipher.cpp +19 -27
  9. package/cpp/cipher/ChaCha20Cipher.hpp +2 -4
  10. package/cpp/cipher/ChaCha20Poly1305Cipher.cpp +41 -36
  11. package/cpp/cipher/ChaCha20Poly1305Cipher.hpp +2 -4
  12. package/cpp/cipher/GCMCipher.cpp +17 -20
  13. package/cpp/cipher/HybridCipher.cpp +44 -47
  14. package/cpp/cipher/HybridCipher.hpp +17 -1
  15. package/cpp/cipher/HybridRsaCipher.cpp +93 -56
  16. package/cpp/cipher/OCBCipher.cpp +5 -5
  17. package/cpp/cipher/XChaCha20Poly1305Cipher.cpp +27 -32
  18. package/cpp/cipher/XSalsa20Cipher.cpp +78 -16
  19. package/cpp/cipher/XSalsa20Cipher.hpp +25 -3
  20. package/cpp/cipher/XSalsa20Poly1305Cipher.cpp +32 -41
  21. package/cpp/dh/HybridDiffieHellman.cpp +29 -0
  22. package/cpp/ec/HybridEcKeyPair.cpp +35 -33
  23. package/cpp/ec/HybridEcKeyPair.hpp +3 -7
  24. package/cpp/ecdh/HybridECDH.cpp +23 -0
  25. package/cpp/ed25519/HybridEdKeyPair.cpp +73 -117
  26. package/cpp/ed25519/HybridEdKeyPair.hpp +5 -9
  27. package/cpp/hash/HybridHash.cpp +5 -7
  28. package/cpp/hkdf/HybridHkdf.cpp +6 -4
  29. package/cpp/hmac/HybridHmac.cpp +4 -6
  30. package/cpp/keys/HybridKeyObjectHandle.cpp +630 -2
  31. package/cpp/keys/HybridKeyObjectHandle.hpp +21 -1
  32. package/cpp/kmac/HybridKmac.cpp +4 -4
  33. package/cpp/mldsa/HybridMlDsaKeyPair.cpp +37 -49
  34. package/cpp/mlkem/HybridMlKemKeyPair.cpp +39 -43
  35. package/cpp/pbkdf2/HybridPbkdf2.cpp +7 -8
  36. package/cpp/rsa/HybridRsaKeyPair.cpp +5 -8
  37. package/cpp/rsa/HybridRsaKeyPair.hpp +4 -7
  38. package/cpp/scrypt/HybridScrypt.cpp +6 -4
  39. package/cpp/sign/HybridSignHandle.cpp +47 -72
  40. package/cpp/sign/HybridVerifyHandle.cpp +47 -67
  41. package/cpp/slhdsa/HybridSlhDsaKeyPair.cpp +245 -0
  42. package/cpp/slhdsa/HybridSlhDsaKeyPair.hpp +48 -0
  43. package/cpp/turboshake/HybridTurboShake.cpp +379 -0
  44. package/cpp/turboshake/HybridTurboShake.hpp +28 -0
  45. package/cpp/utils/HybridUtils.cpp +195 -43
  46. package/cpp/utils/HybridUtils.hpp +9 -2
  47. package/cpp/utils/QuickCryptoUtils.hpp +72 -0
  48. package/deps/blake3/README.md +6 -7
  49. package/deps/blake3/c/blake3.c +3 -2
  50. package/deps/blake3/c/blake3.h +2 -2
  51. package/deps/blake3/c/blake3_dispatch.c +2 -2
  52. package/deps/blake3/c/blake3_impl.h +1 -1
  53. package/deps/blake3/c/blake3_neon.c +5 -4
  54. package/deps/ncrypto/include/ncrypto/version.h +2 -2
  55. package/deps/ncrypto/include/ncrypto.h +9 -2
  56. package/deps/ncrypto/src/ncrypto.cpp +130 -35
  57. package/lib/commonjs/argon2.js +51 -2
  58. package/lib/commonjs/argon2.js.map +1 -1
  59. package/lib/commonjs/cipher.js +109 -11
  60. package/lib/commonjs/cipher.js.map +1 -1
  61. package/lib/commonjs/dhKeyPair.js +3 -0
  62. package/lib/commonjs/dhKeyPair.js.map +1 -1
  63. package/lib/commonjs/dsa.js +11 -2
  64. package/lib/commonjs/dsa.js.map +1 -1
  65. package/lib/commonjs/ec.js +37 -30
  66. package/lib/commonjs/ec.js.map +1 -1
  67. package/lib/commonjs/ed.js +60 -6
  68. package/lib/commonjs/ed.js.map +1 -1
  69. package/lib/commonjs/hash.js +67 -10
  70. package/lib/commonjs/hash.js.map +1 -1
  71. package/lib/commonjs/hkdf.js +33 -6
  72. package/lib/commonjs/hkdf.js.map +1 -1
  73. package/lib/commonjs/hmac.js +15 -5
  74. package/lib/commonjs/hmac.js.map +1 -1
  75. package/lib/commonjs/keys/classes.js +33 -7
  76. package/lib/commonjs/keys/classes.js.map +1 -1
  77. package/lib/commonjs/keys/generateKeyPair.js +85 -4
  78. package/lib/commonjs/keys/generateKeyPair.js.map +1 -1
  79. package/lib/commonjs/keys/index.js +50 -2
  80. package/lib/commonjs/keys/index.js.map +1 -1
  81. package/lib/commonjs/keys/publicCipher.js +10 -4
  82. package/lib/commonjs/keys/publicCipher.js.map +1 -1
  83. package/lib/commonjs/keys/signVerify.js +9 -2
  84. package/lib/commonjs/keys/signVerify.js.map +1 -1
  85. package/lib/commonjs/keys/utils.js +59 -1
  86. package/lib/commonjs/keys/utils.js.map +1 -1
  87. package/lib/commonjs/random.js +74 -11
  88. package/lib/commonjs/random.js.map +1 -1
  89. package/lib/commonjs/rsa.js +15 -5
  90. package/lib/commonjs/rsa.js.map +1 -1
  91. package/lib/commonjs/scrypt.js +47 -6
  92. package/lib/commonjs/scrypt.js.map +1 -1
  93. package/lib/commonjs/slhdsa.js +70 -0
  94. package/lib/commonjs/slhdsa.js.map +1 -0
  95. package/lib/commonjs/specs/slhDsaKeyPair.nitro.js +6 -0
  96. package/lib/commonjs/specs/slhDsaKeyPair.nitro.js.map +1 -0
  97. package/lib/commonjs/specs/turboshake.nitro.js +6 -0
  98. package/lib/commonjs/specs/turboshake.nitro.js.map +1 -0
  99. package/lib/commonjs/subtle.js +975 -253
  100. package/lib/commonjs/subtle.js.map +1 -1
  101. package/lib/commonjs/utils/cipher.js +18 -7
  102. package/lib/commonjs/utils/cipher.js.map +1 -1
  103. package/lib/commonjs/utils/conversion.js +86 -28
  104. package/lib/commonjs/utils/conversion.js.map +1 -1
  105. package/lib/commonjs/utils/errors.js +63 -4
  106. package/lib/commonjs/utils/errors.js.map +1 -1
  107. package/lib/commonjs/utils/timingSafeEqual.js +7 -2
  108. package/lib/commonjs/utils/timingSafeEqual.js.map +1 -1
  109. package/lib/commonjs/utils/types.js.map +1 -1
  110. package/lib/commonjs/utils/validation.js +46 -0
  111. package/lib/commonjs/utils/validation.js.map +1 -1
  112. package/lib/commonjs/x509certificate.js +6 -6
  113. package/lib/commonjs/x509certificate.js.map +1 -1
  114. package/lib/module/argon2.js +51 -2
  115. package/lib/module/argon2.js.map +1 -1
  116. package/lib/module/cipher.js +109 -11
  117. package/lib/module/cipher.js.map +1 -1
  118. package/lib/module/dhKeyPair.js +3 -0
  119. package/lib/module/dhKeyPair.js.map +1 -1
  120. package/lib/module/dsa.js +11 -2
  121. package/lib/module/dsa.js.map +1 -1
  122. package/lib/module/ec.js +38 -31
  123. package/lib/module/ec.js.map +1 -1
  124. package/lib/module/ed.js +61 -7
  125. package/lib/module/ed.js.map +1 -1
  126. package/lib/module/hash.js +67 -10
  127. package/lib/module/hash.js.map +1 -1
  128. package/lib/module/hkdf.js +33 -6
  129. package/lib/module/hkdf.js.map +1 -1
  130. package/lib/module/hmac.js +15 -5
  131. package/lib/module/hmac.js.map +1 -1
  132. package/lib/module/keys/classes.js +31 -5
  133. package/lib/module/keys/classes.js.map +1 -1
  134. package/lib/module/keys/generateKeyPair.js +86 -5
  135. package/lib/module/keys/generateKeyPair.js.map +1 -1
  136. package/lib/module/keys/index.js +50 -2
  137. package/lib/module/keys/index.js.map +1 -1
  138. package/lib/module/keys/publicCipher.js +10 -4
  139. package/lib/module/keys/publicCipher.js.map +1 -1
  140. package/lib/module/keys/signVerify.js +9 -2
  141. package/lib/module/keys/signVerify.js.map +1 -1
  142. package/lib/module/keys/utils.js +57 -1
  143. package/lib/module/keys/utils.js.map +1 -1
  144. package/lib/module/random.js +74 -12
  145. package/lib/module/random.js.map +1 -1
  146. package/lib/module/rsa.js +14 -4
  147. package/lib/module/rsa.js.map +1 -1
  148. package/lib/module/scrypt.js +47 -6
  149. package/lib/module/scrypt.js.map +1 -1
  150. package/lib/module/slhdsa.js +64 -0
  151. package/lib/module/slhdsa.js.map +1 -0
  152. package/lib/module/specs/slhDsaKeyPair.nitro.js +4 -0
  153. package/lib/module/specs/slhDsaKeyPair.nitro.js.map +1 -0
  154. package/lib/module/specs/turboshake.nitro.js +4 -0
  155. package/lib/module/specs/turboshake.nitro.js.map +1 -0
  156. package/lib/module/subtle.js +976 -254
  157. package/lib/module/subtle.js.map +1 -1
  158. package/lib/module/utils/cipher.js +18 -7
  159. package/lib/module/utils/cipher.js.map +1 -1
  160. package/lib/module/utils/conversion.js +84 -28
  161. package/lib/module/utils/conversion.js.map +1 -1
  162. package/lib/module/utils/errors.js +61 -4
  163. package/lib/module/utils/errors.js.map +1 -1
  164. package/lib/module/utils/timingSafeEqual.js +8 -3
  165. package/lib/module/utils/timingSafeEqual.js.map +1 -1
  166. package/lib/module/utils/types.js.map +1 -1
  167. package/lib/module/utils/validation.js +44 -0
  168. package/lib/module/utils/validation.js.map +1 -1
  169. package/lib/module/x509certificate.js +6 -6
  170. package/lib/module/x509certificate.js.map +1 -1
  171. package/lib/typescript/argon2.d.ts.map +1 -1
  172. package/lib/typescript/cipher.d.ts +2 -2
  173. package/lib/typescript/cipher.d.ts.map +1 -1
  174. package/lib/typescript/dhKeyPair.d.ts.map +1 -1
  175. package/lib/typescript/dsa.d.ts.map +1 -1
  176. package/lib/typescript/ec.d.ts.map +1 -1
  177. package/lib/typescript/ed.d.ts.map +1 -1
  178. package/lib/typescript/hash.d.ts +2 -2
  179. package/lib/typescript/hash.d.ts.map +1 -1
  180. package/lib/typescript/hkdf.d.ts.map +1 -1
  181. package/lib/typescript/hmac.d.ts +2 -2
  182. package/lib/typescript/hmac.d.ts.map +1 -1
  183. package/lib/typescript/index.d.ts +13 -8
  184. package/lib/typescript/index.d.ts.map +1 -1
  185. package/lib/typescript/keys/classes.d.ts +10 -1
  186. package/lib/typescript/keys/classes.d.ts.map +1 -1
  187. package/lib/typescript/keys/generateKeyPair.d.ts +12 -1
  188. package/lib/typescript/keys/generateKeyPair.d.ts.map +1 -1
  189. package/lib/typescript/keys/index.d.ts +3 -1
  190. package/lib/typescript/keys/index.d.ts.map +1 -1
  191. package/lib/typescript/keys/publicCipher.d.ts.map +1 -1
  192. package/lib/typescript/keys/signVerify.d.ts.map +1 -1
  193. package/lib/typescript/keys/utils.d.ts +21 -4
  194. package/lib/typescript/keys/utils.d.ts.map +1 -1
  195. package/lib/typescript/random.d.ts +5 -1
  196. package/lib/typescript/random.d.ts.map +1 -1
  197. package/lib/typescript/rsa.d.ts.map +1 -1
  198. package/lib/typescript/scrypt.d.ts.map +1 -1
  199. package/lib/typescript/slhdsa.d.ts +19 -0
  200. package/lib/typescript/slhdsa.d.ts.map +1 -0
  201. package/lib/typescript/specs/keyObjectHandle.nitro.d.ts +9 -0
  202. package/lib/typescript/specs/keyObjectHandle.nitro.d.ts.map +1 -1
  203. package/lib/typescript/specs/slhDsaKeyPair.nitro.d.ts +16 -0
  204. package/lib/typescript/specs/slhDsaKeyPair.nitro.d.ts.map +1 -0
  205. package/lib/typescript/specs/turboshake.nitro.d.ts +11 -0
  206. package/lib/typescript/specs/turboshake.nitro.d.ts.map +1 -0
  207. package/lib/typescript/specs/utils.nitro.d.ts +0 -2
  208. package/lib/typescript/specs/utils.nitro.d.ts.map +1 -1
  209. package/lib/typescript/subtle.d.ts +3 -2
  210. package/lib/typescript/subtle.d.ts.map +1 -1
  211. package/lib/typescript/utils/cipher.d.ts +13 -1
  212. package/lib/typescript/utils/cipher.d.ts.map +1 -1
  213. package/lib/typescript/utils/conversion.d.ts +13 -9
  214. package/lib/typescript/utils/conversion.d.ts.map +1 -1
  215. package/lib/typescript/utils/errors.d.ts +12 -0
  216. package/lib/typescript/utils/errors.d.ts.map +1 -1
  217. package/lib/typescript/utils/timingSafeEqual.d.ts.map +1 -1
  218. package/lib/typescript/utils/types.d.ts +32 -15
  219. package/lib/typescript/utils/types.d.ts.map +1 -1
  220. package/lib/typescript/utils/validation.d.ts +3 -1
  221. package/lib/typescript/utils/validation.d.ts.map +1 -1
  222. package/lib/typescript/x509certificate.d.ts.map +1 -1
  223. package/nitrogen/generated/android/QuickCrypto+autolinking.cmake +2 -0
  224. package/nitrogen/generated/android/QuickCryptoOnLoad.cpp +20 -0
  225. package/nitrogen/generated/ios/QuickCryptoAutolinking.mm +20 -0
  226. package/nitrogen/generated/shared/c++/AsymmetricKeyType.hpp +48 -0
  227. package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.cpp +9 -0
  228. package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.hpp +9 -0
  229. package/nitrogen/generated/shared/c++/HybridSlhDsaKeyPairSpec.cpp +29 -0
  230. package/nitrogen/generated/shared/c++/HybridSlhDsaKeyPairSpec.hpp +72 -0
  231. package/nitrogen/generated/shared/c++/HybridTurboShakeSpec.cpp +22 -0
  232. package/nitrogen/generated/shared/c++/HybridTurboShakeSpec.hpp +70 -0
  233. package/nitrogen/generated/shared/c++/HybridUtilsSpec.cpp +0 -2
  234. package/nitrogen/generated/shared/c++/HybridUtilsSpec.hpp +0 -3
  235. package/nitrogen/generated/shared/c++/JWK.hpp +9 -1
  236. package/nitrogen/generated/shared/c++/JWKkty.hpp +4 -0
  237. package/nitrogen/generated/shared/c++/KangarooTwelveVariant.hpp +76 -0
  238. package/nitrogen/generated/shared/c++/TurboShakeVariant.hpp +76 -0
  239. package/package.json +38 -7
  240. package/src/argon2.ts +80 -2
  241. package/src/cipher.ts +139 -15
  242. package/src/dhKeyPair.ts +8 -0
  243. package/src/dsa.ts +19 -2
  244. package/src/ec.ts +52 -29
  245. package/src/ed.ts +95 -16
  246. package/src/hash.ts +125 -12
  247. package/src/hkdf.ts +44 -6
  248. package/src/hmac.ts +17 -7
  249. package/src/keys/classes.ts +46 -5
  250. package/src/keys/generateKeyPair.ts +151 -5
  251. package/src/keys/index.ts +73 -3
  252. package/src/keys/publicCipher.ts +10 -4
  253. package/src/keys/signVerify.ts +13 -2
  254. package/src/keys/utils.ts +78 -5
  255. package/src/random.ts +104 -11
  256. package/src/rsa.ts +26 -4
  257. package/src/scrypt.ts +73 -6
  258. package/src/slhdsa.ts +146 -0
  259. package/src/specs/keyObjectHandle.nitro.ts +17 -0
  260. package/src/specs/slhDsaKeyPair.nitro.ts +29 -0
  261. package/src/specs/turboshake.nitro.ts +21 -0
  262. package/src/specs/utils.nitro.ts +0 -2
  263. package/src/subtle.ts +1246 -333
  264. package/src/utils/cipher.ts +30 -8
  265. package/src/utils/conversion.ts +129 -40
  266. package/src/utils/errors.ts +72 -4
  267. package/src/utils/timingSafeEqual.ts +8 -3
  268. package/src/utils/types.ts +80 -15
  269. package/src/utils/validation.ts +70 -1
  270. package/src/x509certificate.ts +5 -6
  271. package/deps/blake3/.cargo/config.toml +0 -2
  272. package/deps/blake3/.git-blame-ignore-revs +0 -2
  273. package/deps/blake3/.github/workflows/build_b3sum.py +0 -38
  274. package/deps/blake3/.github/workflows/ci.yml +0 -491
  275. package/deps/blake3/.github/workflows/tag.yml +0 -43
  276. package/deps/blake3/.github/workflows/upload_github_release_asset.py +0 -73
  277. package/deps/blake3/CONTRIBUTING.md +0 -31
  278. package/deps/blake3/Cargo.toml +0 -135
  279. package/deps/blake3/b3sum/Cargo.lock +0 -513
  280. package/deps/blake3/b3sum/Cargo.toml +0 -26
  281. package/deps/blake3/b3sum/README.md +0 -72
  282. package/deps/blake3/b3sum/src/main.rs +0 -564
  283. package/deps/blake3/b3sum/src/unit_tests.rs +0 -235
  284. package/deps/blake3/b3sum/tests/cli_tests.rs +0 -680
  285. package/deps/blake3/b3sum/what_does_check_do.md +0 -176
  286. package/deps/blake3/benches/bench.rs +0 -623
  287. package/deps/blake3/build.rs +0 -389
  288. package/deps/blake3/c/CMakeLists.txt +0 -383
  289. package/deps/blake3/c/CMakePresets.json +0 -73
  290. package/deps/blake3/c/Makefile.testing +0 -82
  291. package/deps/blake3/c/blake3-config.cmake.in +0 -14
  292. package/deps/blake3/c/blake3_avx2.c +0 -326
  293. package/deps/blake3/c/blake3_avx2_x86-64_unix.S +0 -1815
  294. package/deps/blake3/c/blake3_avx2_x86-64_windows_gnu.S +0 -1817
  295. package/deps/blake3/c/blake3_avx2_x86-64_windows_msvc.asm +0 -1828
  296. package/deps/blake3/c/blake3_avx512.c +0 -1388
  297. package/deps/blake3/c/blake3_avx512_x86-64_unix.S +0 -4824
  298. package/deps/blake3/c/blake3_avx512_x86-64_windows_gnu.S +0 -2615
  299. package/deps/blake3/c/blake3_avx512_x86-64_windows_msvc.asm +0 -2634
  300. package/deps/blake3/c/blake3_c_rust_bindings/Cargo.toml +0 -32
  301. package/deps/blake3/c/blake3_c_rust_bindings/README.md +0 -4
  302. package/deps/blake3/c/blake3_c_rust_bindings/benches/bench.rs +0 -477
  303. package/deps/blake3/c/blake3_c_rust_bindings/build.rs +0 -253
  304. package/deps/blake3/c/blake3_c_rust_bindings/cross_test.sh +0 -31
  305. package/deps/blake3/c/blake3_c_rust_bindings/src/lib.rs +0 -333
  306. package/deps/blake3/c/blake3_c_rust_bindings/src/test.rs +0 -696
  307. package/deps/blake3/c/blake3_sse2.c +0 -566
  308. package/deps/blake3/c/blake3_sse2_x86-64_unix.S +0 -2291
  309. package/deps/blake3/c/blake3_sse2_x86-64_windows_gnu.S +0 -2332
  310. package/deps/blake3/c/blake3_sse2_x86-64_windows_msvc.asm +0 -2350
  311. package/deps/blake3/c/blake3_sse41.c +0 -560
  312. package/deps/blake3/c/blake3_sse41_x86-64_unix.S +0 -2028
  313. package/deps/blake3/c/blake3_sse41_x86-64_windows_gnu.S +0 -2069
  314. package/deps/blake3/c/blake3_sse41_x86-64_windows_msvc.asm +0 -2089
  315. package/deps/blake3/c/blake3_tbb.cpp +0 -37
  316. package/deps/blake3/c/dependencies/CMakeLists.txt +0 -3
  317. package/deps/blake3/c/dependencies/tbb/CMakeLists.txt +0 -28
  318. package/deps/blake3/c/example.c +0 -36
  319. package/deps/blake3/c/example_tbb.c +0 -57
  320. package/deps/blake3/c/libblake3.pc.in +0 -12
  321. package/deps/blake3/c/main.c +0 -166
  322. package/deps/blake3/c/test.py +0 -97
  323. package/deps/blake3/media/B3.svg +0 -70
  324. package/deps/blake3/media/BLAKE3.svg +0 -85
  325. package/deps/blake3/media/speed.svg +0 -1474
  326. package/deps/blake3/reference_impl/Cargo.toml +0 -8
  327. package/deps/blake3/reference_impl/README.md +0 -14
  328. package/deps/blake3/reference_impl/reference_impl.rs +0 -374
  329. package/deps/blake3/src/ffi_avx2.rs +0 -65
  330. package/deps/blake3/src/ffi_avx512.rs +0 -169
  331. package/deps/blake3/src/ffi_neon.rs +0 -82
  332. package/deps/blake3/src/ffi_sse2.rs +0 -126
  333. package/deps/blake3/src/ffi_sse41.rs +0 -126
  334. package/deps/blake3/src/guts.rs +0 -60
  335. package/deps/blake3/src/hazmat.rs +0 -704
  336. package/deps/blake3/src/io.rs +0 -64
  337. package/deps/blake3/src/join.rs +0 -92
  338. package/deps/blake3/src/lib.rs +0 -1835
  339. package/deps/blake3/src/platform.rs +0 -587
  340. package/deps/blake3/src/portable.rs +0 -198
  341. package/deps/blake3/src/rust_avx2.rs +0 -474
  342. package/deps/blake3/src/rust_sse2.rs +0 -775
  343. package/deps/blake3/src/rust_sse41.rs +0 -766
  344. package/deps/blake3/src/test.rs +0 -1049
  345. package/deps/blake3/src/traits.rs +0 -227
  346. package/deps/blake3/src/wasm32_simd.rs +0 -794
  347. package/deps/blake3/test_vectors/Cargo.toml +0 -19
  348. package/deps/blake3/test_vectors/cross_test.sh +0 -25
  349. package/deps/blake3/test_vectors/src/bin/generate.rs +0 -4
  350. package/deps/blake3/test_vectors/src/lib.rs +0 -350
  351. package/deps/blake3/test_vectors/test_vectors.json +0 -217
  352. package/deps/blake3/tools/compiler_version/Cargo.toml +0 -7
  353. package/deps/blake3/tools/compiler_version/build.rs +0 -6
  354. package/deps/blake3/tools/compiler_version/src/main.rs +0 -27
  355. package/deps/blake3/tools/instruction_set_support/Cargo.toml +0 -6
  356. package/deps/blake3/tools/instruction_set_support/src/main.rs +0 -10
  357. package/deps/blake3/tools/release.md +0 -16
  358. package/deps/ncrypto/.bazelignore +0 -4
  359. package/deps/ncrypto/.bazelrc +0 -1
  360. package/deps/ncrypto/.bazelversion +0 -1
  361. package/deps/ncrypto/.clang-format +0 -111
  362. package/deps/ncrypto/.github/workflows/bazel.yml +0 -58
  363. package/deps/ncrypto/.github/workflows/commitlint.yml +0 -16
  364. package/deps/ncrypto/.github/workflows/linter.yml +0 -38
  365. package/deps/ncrypto/.github/workflows/macos.yml +0 -43
  366. package/deps/ncrypto/.github/workflows/release-please.yml +0 -16
  367. package/deps/ncrypto/.github/workflows/ubuntu.yml +0 -128
  368. package/deps/ncrypto/.github/workflows/visual-studio.yml +0 -49
  369. package/deps/ncrypto/.python-version +0 -1
  370. package/deps/ncrypto/.release-please-manifest.json +0 -3
  371. package/deps/ncrypto/BUILD.bazel +0 -44
  372. package/deps/ncrypto/CHANGELOG.md +0 -37
  373. package/deps/ncrypto/CMakeLists.txt +0 -79
  374. package/deps/ncrypto/MODULE.bazel +0 -16
  375. package/deps/ncrypto/MODULE.bazel.lock +0 -461
  376. package/deps/ncrypto/cmake/CPM.cmake +0 -1225
  377. package/deps/ncrypto/cmake/ncrypto-flags.cmake +0 -17
  378. package/deps/ncrypto/ncrypto.pc.in +0 -10
  379. package/deps/ncrypto/patches/0001-Expose-libdecrepit-so-NodeJS-can-use-it-for-ncrypto.patch +0 -28
  380. package/deps/ncrypto/pyproject.toml +0 -38
  381. package/deps/ncrypto/release-please-config.json +0 -11
  382. package/deps/ncrypto/src/CMakeLists.txt +0 -40
  383. package/deps/ncrypto/tests/BUILD.bazel +0 -11
  384. package/deps/ncrypto/tests/CMakeLists.txt +0 -7
  385. package/deps/ncrypto/tests/basic.cpp +0 -856
  386. package/deps/ncrypto/tools/run-clang-format.sh +0 -42
  387. package/deps/simdutf/.clang-format +0 -4
  388. package/deps/simdutf/.github/ISSUE_TEMPLATE/bug_report.md +0 -62
  389. package/deps/simdutf/.github/ISSUE_TEMPLATE/config.yml +0 -1
  390. package/deps/simdutf/.github/ISSUE_TEMPLATE/feature_request.md +0 -35
  391. package/deps/simdutf/.github/ISSUE_TEMPLATE/standard-issue-template.md +0 -29
  392. package/deps/simdutf/.github/pull_request_template.md +0 -51
  393. package/deps/simdutf/.github/workflows/aarch64.yml +0 -39
  394. package/deps/simdutf/.github/workflows/alpine.yml +0 -27
  395. package/deps/simdutf/.github/workflows/amalgamation_demos.yml +0 -34
  396. package/deps/simdutf/.github/workflows/armv7.yml +0 -32
  397. package/deps/simdutf/.github/workflows/atomic_fuzz.yml +0 -25
  398. package/deps/simdutf/.github/workflows/cifuzz.yml +0 -37
  399. package/deps/simdutf/.github/workflows/clangformat.yml +0 -36
  400. package/deps/simdutf/.github/workflows/debian-latestcxxstandards.yml +0 -40
  401. package/deps/simdutf/.github/workflows/debian.yml +0 -33
  402. package/deps/simdutf/.github/workflows/documentation.yml +0 -36
  403. package/deps/simdutf/.github/workflows/emscripten.yml +0 -19
  404. package/deps/simdutf/.github/workflows/loongarch64-gcc-14.2.yml +0 -39
  405. package/deps/simdutf/.github/workflows/macos-latest.yml +0 -29
  406. package/deps/simdutf/.github/workflows/msys2-clang.yml +0 -48
  407. package/deps/simdutf/.github/workflows/msys2.yml +0 -50
  408. package/deps/simdutf/.github/workflows/ppc64le.yml +0 -29
  409. package/deps/simdutf/.github/workflows/rvv-1024-clang-18.yml +0 -35
  410. package/deps/simdutf/.github/workflows/rvv-128-clang-17.yml +0 -35
  411. package/deps/simdutf/.github/workflows/rvv-256-gcc-14.yml +0 -31
  412. package/deps/simdutf/.github/workflows/s390x.yml +0 -29
  413. package/deps/simdutf/.github/workflows/selective-amalgamation.yml +0 -29
  414. package/deps/simdutf/.github/workflows/typos.yml +0 -19
  415. package/deps/simdutf/.github/workflows/ubuntu22-cxx20.yml +0 -30
  416. package/deps/simdutf/.github/workflows/ubuntu22.yml +0 -32
  417. package/deps/simdutf/.github/workflows/ubuntu22_gcc12.yml +0 -27
  418. package/deps/simdutf/.github/workflows/ubuntu22sani.yml +0 -29
  419. package/deps/simdutf/.github/workflows/ubuntu24-cxxstandards.yml +0 -34
  420. package/deps/simdutf/.github/workflows/ubuntu24-unsignedchar.yml +0 -34
  421. package/deps/simdutf/.github/workflows/ubuntu24.yml +0 -32
  422. package/deps/simdutf/.github/workflows/ubuntu24sani.yml +0 -36
  423. package/deps/simdutf/.github/workflows/ubuntu24sani_clang.yml +0 -29
  424. package/deps/simdutf/.github/workflows/vs17-arm-ci.yml +0 -21
  425. package/deps/simdutf/.github/workflows/vs17-ci-cxx20.yml +0 -41
  426. package/deps/simdutf/.github/workflows/vs17-ci.yml +0 -41
  427. package/deps/simdutf/.github/workflows/vs17-clang-ci.yml +0 -41
  428. package/deps/simdutf/.github/workflows/vs17-cxxstandards.yml +0 -36
  429. package/deps/simdutf/AI_USAGE_POLICY.md +0 -56
  430. package/deps/simdutf/AUTHORS +0 -6
  431. package/deps/simdutf/CMakeLists.txt +0 -231
  432. package/deps/simdutf/CONTRIBUTING.md +0 -214
  433. package/deps/simdutf/CONTRIBUTORS +0 -1
  434. package/deps/simdutf/Doxyfile +0 -2584
  435. package/deps/simdutf/Makefile.crosscompile +0 -54
  436. package/deps/simdutf/README-RVV.md +0 -16
  437. package/deps/simdutf/SECURITY.md +0 -8
  438. package/deps/simdutf/benchmarks/CMakeLists.txt +0 -101
  439. package/deps/simdutf/benchmarks/alignment.cpp +0 -150
  440. package/deps/simdutf/benchmarks/base64/CMakeLists.txt +0 -30
  441. package/deps/simdutf/benchmarks/base64/benchmark_base64.cpp +0 -875
  442. package/deps/simdutf/benchmarks/base64/libbase64_spaces.h +0 -49
  443. package/deps/simdutf/benchmarks/base64/node_base64.h +0 -227
  444. package/deps/simdutf/benchmarks/base64/openssl3_base64.h +0 -334
  445. package/deps/simdutf/benchmarks/benchmark.cpp +0 -65
  446. package/deps/simdutf/benchmarks/benchmark_to_well_formed_utf16.cpp +0 -347
  447. package/deps/simdutf/benchmarks/competition/.clang-format-ignore +0 -5
  448. package/deps/simdutf/benchmarks/competition/CppCon2018/utf_utils.cpp +0 -1276
  449. package/deps/simdutf/benchmarks/competition/CppCon2018/utf_utils.h +0 -595
  450. package/deps/simdutf/benchmarks/competition/README.md +0 -7
  451. package/deps/simdutf/benchmarks/competition/hoehrmann/hoehrmann.h +0 -91
  452. package/deps/simdutf/benchmarks/competition/inoue2008/inoue_utf8_to_utf16.h +0 -444
  453. package/deps/simdutf/benchmarks/competition/inoue2008/inoue_utf8_to_utf16_tables.h +0 -13183
  454. package/deps/simdutf/benchmarks/competition/inoue2008/script.py +0 -73
  455. package/deps/simdutf/benchmarks/competition/llvm/ConvertUTF.cpp +0 -738
  456. package/deps/simdutf/benchmarks/competition/llvm/ConvertUTF.h +0 -293
  457. package/deps/simdutf/benchmarks/competition/u8u16/COPYRIGHT +0 -8
  458. package/deps/simdutf/benchmarks/competition/u8u16/Makefile +0 -44
  459. package/deps/simdutf/benchmarks/competition/u8u16/OSL3.0.txt +0 -169
  460. package/deps/simdutf/benchmarks/competition/u8u16/Profiling/BOM_Profiler.h +0 -148
  461. package/deps/simdutf/benchmarks/competition/u8u16/Profiling/i386_timer.h +0 -45
  462. package/deps/simdutf/benchmarks/competition/u8u16/Profiling/ppc_timer.c +0 -34
  463. package/deps/simdutf/benchmarks/competition/u8u16/README +0 -56
  464. package/deps/simdutf/benchmarks/competition/u8u16/config/config_defs.h +0 -43
  465. package/deps/simdutf/benchmarks/competition/u8u16/config/g4_config.h +0 -27
  466. package/deps/simdutf/benchmarks/competition/u8u16/config/mmx_config.h +0 -16
  467. package/deps/simdutf/benchmarks/competition/u8u16/config/p4_config.h +0 -18
  468. package/deps/simdutf/benchmarks/competition/u8u16/config/p4_ideal_config.h +0 -16
  469. package/deps/simdutf/benchmarks/competition/u8u16/config/spu_config.h +0 -28
  470. package/deps/simdutf/benchmarks/competition/u8u16/config/ssse3_config.h +0 -20
  471. package/deps/simdutf/benchmarks/competition/u8u16/iconv_u8u16.c +0 -2
  472. package/deps/simdutf/benchmarks/competition/u8u16/lib/altivec_simd.h +0 -440
  473. package/deps/simdutf/benchmarks/competition/u8u16/lib/libgen/make_basic_ops.py +0 -121
  474. package/deps/simdutf/benchmarks/competition/u8u16/lib/libgen/make_half_operand_versions.py +0 -158
  475. package/deps/simdutf/benchmarks/competition/u8u16/lib/libgen/make_test.py +0 -270
  476. package/deps/simdutf/benchmarks/competition/u8u16/lib/mmx_simd.h +0 -141
  477. package/deps/simdutf/benchmarks/competition/u8u16/lib/mmx_simd_basic.h +0 -216
  478. package/deps/simdutf/benchmarks/competition/u8u16/lib/mmx_simd_built_in.h +0 -119
  479. package/deps/simdutf/benchmarks/competition/u8u16/lib/mmx_simd_modified.h +0 -2430
  480. package/deps/simdutf/benchmarks/competition/u8u16/lib/outline.txt +0 -39
  481. package/deps/simdutf/benchmarks/competition/u8u16/lib/spu_simd.h +0 -421
  482. package/deps/simdutf/benchmarks/competition/u8u16/lib/sse_simd.h +0 -836
  483. package/deps/simdutf/benchmarks/competition/u8u16/lib/stdint.h +0 -222
  484. package/deps/simdutf/benchmarks/competition/u8u16/libu8u16_BE.c +0 -4
  485. package/deps/simdutf/benchmarks/competition/u8u16/libu8u16_LE.c +0 -5
  486. package/deps/simdutf/benchmarks/competition/u8u16/proto/u8u16.py +0 -390
  487. package/deps/simdutf/benchmarks/competition/u8u16/src/Makefile +0 -18
  488. package/deps/simdutf/benchmarks/competition/u8u16/src/bytelex.h +0 -448
  489. package/deps/simdutf/benchmarks/competition/u8u16/src/charsets/ASCII_EBCDIC.h +0 -284
  490. package/deps/simdutf/benchmarks/competition/u8u16/src/libu8u16.c +0 -1975
  491. package/deps/simdutf/benchmarks/competition/u8u16/src/libu8u16.pdf +0 -0
  492. package/deps/simdutf/benchmarks/competition/u8u16/src/libu8u16.w +0 -2263
  493. package/deps/simdutf/benchmarks/competition/u8u16/src/multiliteral.h +0 -239
  494. package/deps/simdutf/benchmarks/competition/u8u16/src/u8u16.c +0 -232
  495. package/deps/simdutf/benchmarks/competition/u8u16/src/x8x16.c +0 -194
  496. package/deps/simdutf/benchmarks/competition/u8u16/src/xml_error.c +0 -193
  497. package/deps/simdutf/benchmarks/competition/u8u16/src/xml_error.h +0 -167
  498. package/deps/simdutf/benchmarks/competition/u8u16/src/xmldecl.c +0 -288
  499. package/deps/simdutf/benchmarks/competition/u8u16/src/xmldecl.h +0 -117
  500. package/deps/simdutf/benchmarks/competition/u8u16/u8u16_g4.c +0 -2
  501. package/deps/simdutf/benchmarks/competition/u8u16/u8u16_mmx.c +0 -2
  502. package/deps/simdutf/benchmarks/competition/u8u16/u8u16_p4.c +0 -3
  503. package/deps/simdutf/benchmarks/competition/u8u16/u8u16_p4_ideal.c +0 -2
  504. package/deps/simdutf/benchmarks/competition/u8u16/u8u16_spu.c +0 -2
  505. package/deps/simdutf/benchmarks/competition/u8u16/u8u16_ssse3.c +0 -3
  506. package/deps/simdutf/benchmarks/competition/u8u16/x8x16_p4.c +0 -2
  507. package/deps/simdutf/benchmarks/competition/utf8lut/LICENSE +0 -23
  508. package/deps/simdutf/benchmarks/competition/utf8lut/data/test_minimal.txt +0 -44
  509. package/deps/simdutf/benchmarks/competition/utf8lut/readme.md +0 -106
  510. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_clang_corr_tests.cmd +0 -11
  511. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_clang_corr_tests.sh +0 -13
  512. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_gcc_corr_tests.sh +0 -13
  513. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_gcc_example.sh +0 -13
  514. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_gcc_file_conv.sh +0 -14
  515. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_gcc_iconv_lib.sh +0 -11
  516. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_gcc_iconv_sample.sh +0 -8
  517. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_mingw_corr_tests.cmd +0 -12
  518. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_mingw_example.cmd +0 -13
  519. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_mingw_file_conv.cmd +0 -14
  520. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_mingw_iconv_lib.cmd +0 -11
  521. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_mingw_iconv_sample.cmd +0 -8
  522. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_msvc_corr_tests.cmd +0 -11
  523. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_msvc_example.cmd +0 -12
  524. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_msvc_file_conv.cmd +0 -13
  525. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_msvc_iconv_lib.cmd +0 -10
  526. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_msvc_iconv_sample.cmd +0 -9
  527. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/html_table.py +0 -25
  528. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/measure.py +0 -94
  529. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/resize.py +0 -20
  530. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/wipe_all.cmd +0 -2
  531. package/deps/simdutf/benchmarks/competition/utf8lut/scripts/wipe_interm.cmd +0 -1
  532. package/deps/simdutf/benchmarks/competition/utf8lut/src/base/CustomMemcpy.h +0 -75
  533. package/deps/simdutf/benchmarks/competition/utf8lut/src/base/PerfDefs.h +0 -47
  534. package/deps/simdutf/benchmarks/competition/utf8lut/src/base/Timing.cpp +0 -17
  535. package/deps/simdutf/benchmarks/competition/utf8lut/src/base/Timing.h +0 -76
  536. package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/AllProcessors.cpp +0 -35
  537. package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/BaseBufferProcessor.cpp +0 -117
  538. package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/BaseBufferProcessor.h +0 -210
  539. package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/BufferDecoder.h +0 -158
  540. package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/BufferEncoder.h +0 -104
  541. package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/ProcessorPlugins.h +0 -334
  542. package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/ProcessorSelector.h +0 -186
  543. package/deps/simdutf/benchmarks/competition/utf8lut/src/core/DecoderLut.cpp +0 -140
  544. package/deps/simdutf/benchmarks/competition/utf8lut/src/core/DecoderLut.h +0 -42
  545. package/deps/simdutf/benchmarks/competition/utf8lut/src/core/DecoderProcess.h +0 -100
  546. package/deps/simdutf/benchmarks/competition/utf8lut/src/core/Dfa.h +0 -57
  547. package/deps/simdutf/benchmarks/competition/utf8lut/src/core/EncoderLut.cpp +0 -85
  548. package/deps/simdutf/benchmarks/competition/utf8lut/src/core/EncoderLut.h +0 -27
  549. package/deps/simdutf/benchmarks/competition/utf8lut/src/core/EncoderProcess.h +0 -126
  550. package/deps/simdutf/benchmarks/competition/utf8lut/src/core/ProcessTrivial.h +0 -108
  551. package/deps/simdutf/benchmarks/competition/utf8lut/src/iconv/iconv.cpp +0 -139
  552. package/deps/simdutf/benchmarks/competition/utf8lut/src/iconv/iconv.h +0 -74
  553. package/deps/simdutf/benchmarks/competition/utf8lut/src/message/MessageConverter.cpp +0 -65
  554. package/deps/simdutf/benchmarks/competition/utf8lut/src/message/MessageConverter.h +0 -91
  555. package/deps/simdutf/benchmarks/competition/utf8lut/src/tests/CorrectnessTests.cpp +0 -772
  556. package/deps/simdutf/benchmarks/competition/utf8lut/src/tests/Example.cpp +0 -12
  557. package/deps/simdutf/benchmarks/competition/utf8lut/src/tests/FileConverter.cpp +0 -486
  558. package/deps/simdutf/benchmarks/competition/utf8lut/src/tests/iconv_sample.c +0 -162
  559. package/deps/simdutf/benchmarks/competition/utf8lut/src/utf8lut.h +0 -15
  560. package/deps/simdutf/benchmarks/competition/utf8sse4/fromutf8-sse.cpp +0 -292
  561. package/deps/simdutf/benchmarks/competition/utfcpp/LICENSE +0 -23
  562. package/deps/simdutf/benchmarks/competition/utfcpp/README.md +0 -1503
  563. package/deps/simdutf/benchmarks/competition/utfcpp/source/utf8/checked.h +0 -335
  564. package/deps/simdutf/benchmarks/competition/utfcpp/source/utf8/core.h +0 -338
  565. package/deps/simdutf/benchmarks/competition/utfcpp/source/utf8/cpp11.h +0 -103
  566. package/deps/simdutf/benchmarks/competition/utfcpp/source/utf8/cpp17.h +0 -103
  567. package/deps/simdutf/benchmarks/competition/utfcpp/source/utf8/unchecked.h +0 -274
  568. package/deps/simdutf/benchmarks/competition/utfcpp/source/utf8.h +0 -34
  569. package/deps/simdutf/benchmarks/dataset/README.md +0 -155
  570. package/deps/simdutf/benchmarks/dataset/emoji.txt +0 -204
  571. package/deps/simdutf/benchmarks/dataset/scripts/utf8type.py +0 -40
  572. package/deps/simdutf/benchmarks/dataset/wikipedia_mars/Makefile +0 -80
  573. package/deps/simdutf/benchmarks/dataset/wikipedia_mars/convert_to_utf6.py +0 -20
  574. package/deps/simdutf/benchmarks/find/CMakeLists.txt +0 -6
  575. package/deps/simdutf/benchmarks/find/findbenchmark.cpp +0 -63
  576. package/deps/simdutf/benchmarks/find/findbenchmarker.h +0 -46
  577. package/deps/simdutf/benchmarks/shortbench.cpp +0 -555
  578. package/deps/simdutf/benchmarks/src/CMakeLists.txt +0 -52
  579. package/deps/simdutf/benchmarks/src/apple_arm_events.h +0 -1104
  580. package/deps/simdutf/benchmarks/src/benchmark.cpp +0 -3899
  581. package/deps/simdutf/benchmarks/src/benchmark.h +0 -317
  582. package/deps/simdutf/benchmarks/src/benchmark_base.cpp +0 -144
  583. package/deps/simdutf/benchmarks/src/benchmark_base.h +0 -98
  584. package/deps/simdutf/benchmarks/src/cmdline.cpp +0 -176
  585. package/deps/simdutf/benchmarks/src/cmdline.h +0 -35
  586. package/deps/simdutf/benchmarks/src/event_counter.h +0 -162
  587. package/deps/simdutf/benchmarks/src/linux-perf-events.h +0 -104
  588. package/deps/simdutf/benchmarks/stream.cpp +0 -209
  589. package/deps/simdutf/benchmarks/threaded.cpp +0 -123
  590. package/deps/simdutf/cmake/CPM.cmake +0 -1363
  591. package/deps/simdutf/cmake/JoinPaths.cmake +0 -23
  592. package/deps/simdutf/cmake/add_cpp_test.cmake +0 -68
  593. package/deps/simdutf/cmake/simdutf-config.cmake.in +0 -2
  594. package/deps/simdutf/cmake/simdutf-flags.cmake +0 -26
  595. package/deps/simdutf/cmake/toolchains-ci/riscv64-linux-gnu.cmake +0 -4
  596. package/deps/simdutf/cmake/toolchains-dev/README.md +0 -32
  597. package/deps/simdutf/cmake/toolchains-dev/aarch64.cmake +0 -14
  598. package/deps/simdutf/cmake/toolchains-dev/loongarch64.cmake +0 -22
  599. package/deps/simdutf/cmake/toolchains-dev/powerpc64.cmake +0 -16
  600. package/deps/simdutf/cmake/toolchains-dev/powerpc64le.cmake +0 -16
  601. package/deps/simdutf/cmake/toolchains-dev/riscv64.cmake +0 -16
  602. package/deps/simdutf/cmake/toolchains-dev/rvv-spike.cmake +0 -38
  603. package/deps/simdutf/doc/avx512.png +0 -0
  604. package/deps/simdutf/doc/logo.png +0 -0
  605. package/deps/simdutf/doc/logo.svg +0 -165
  606. package/deps/simdutf/doc/node2023.png +0 -0
  607. package/deps/simdutf/doc/shortinput.md +0 -78
  608. package/deps/simdutf/doc/utf16utf8.png +0 -0
  609. package/deps/simdutf/doc/utf8utf16.png +0 -0
  610. package/deps/simdutf/doc/widelogo.png +0 -0
  611. package/deps/simdutf/doxygen.py +0 -50
  612. package/deps/simdutf/fuzz/.clang-format +0 -9
  613. package/deps/simdutf/fuzz/CMakeLists.txt +0 -45
  614. package/deps/simdutf/fuzz/README.md +0 -168
  615. package/deps/simdutf/fuzz/atomic_base64.cpp +0 -448
  616. package/deps/simdutf/fuzz/base64.cpp +0 -278
  617. package/deps/simdutf/fuzz/build.sh +0 -83
  618. package/deps/simdutf/fuzz/conversion.cpp +0 -669
  619. package/deps/simdutf/fuzz/helpers/.clang-format-ignore +0 -1
  620. package/deps/simdutf/fuzz/helpers/common.h +0 -135
  621. package/deps/simdutf/fuzz/helpers/nameof.hpp +0 -1258
  622. package/deps/simdutf/fuzz/main.cpp +0 -72
  623. package/deps/simdutf/fuzz/minimize_and_cleanse.sh +0 -87
  624. package/deps/simdutf/fuzz/misc.cpp +0 -216
  625. package/deps/simdutf/fuzz/random_fuzz.sh +0 -154
  626. package/deps/simdutf/fuzz/roundtrip.cpp +0 -588
  627. package/deps/simdutf/fuzz/safe_conversion.cpp +0 -104
  628. package/deps/simdutf/riscv/Dockerfile +0 -16
  629. package/deps/simdutf/riscv/README.md +0 -24
  630. package/deps/simdutf/riscv/remove-docker-station +0 -8
  631. package/deps/simdutf/riscv/run-docker-station +0 -31
  632. package/deps/simdutf/scripts/.flake8 +0 -2
  633. package/deps/simdutf/scripts/Makefile +0 -2
  634. package/deps/simdutf/scripts/README_ADD_FUNCTION.md +0 -49
  635. package/deps/simdutf/scripts/add_function.py +0 -330
  636. package/deps/simdutf/scripts/amalgamation_tests.py +0 -156
  637. package/deps/simdutf/scripts/base64/Makefile +0 -2
  638. package/deps/simdutf/scripts/base64/README.md +0 -2
  639. package/deps/simdutf/scripts/base64/avx512.py +0 -76
  640. package/deps/simdutf/scripts/base64/neon_decode.py +0 -143
  641. package/deps/simdutf/scripts/base64/neon_generate_lut.py +0 -101
  642. package/deps/simdutf/scripts/base64/sse.py +0 -252
  643. package/deps/simdutf/scripts/base64/sseregular.py +0 -160
  644. package/deps/simdutf/scripts/base64/sseurl.py +0 -283
  645. package/deps/simdutf/scripts/base64/table.py +0 -59
  646. package/deps/simdutf/scripts/base64bench_print.py +0 -145
  647. package/deps/simdutf/scripts/benchmark-all.py +0 -119
  648. package/deps/simdutf/scripts/benchmark_print.py +0 -324
  649. package/deps/simdutf/scripts/check_feature_macros.py +0 -156
  650. package/deps/simdutf/scripts/check_typos.sh +0 -13
  651. package/deps/simdutf/scripts/clang_format.sh +0 -35
  652. package/deps/simdutf/scripts/clang_format_docker.sh +0 -38
  653. package/deps/simdutf/scripts/common.py +0 -24
  654. package/deps/simdutf/scripts/compilation_benchmark.py +0 -55
  655. package/deps/simdutf/scripts/compile_many_variations.sh +0 -64
  656. package/deps/simdutf/scripts/create_latex_table.py +0 -62
  657. package/deps/simdutf/scripts/docker/Dockerfile +0 -14
  658. package/deps/simdutf/scripts/docker/Makefile +0 -9
  659. package/deps/simdutf/scripts/docker/README.md +0 -30
  660. package/deps/simdutf/scripts/docker/llvm.gpg +0 -0
  661. package/deps/simdutf/scripts/ppc64_convert_utf16_to_utf8.py +0 -155
  662. package/deps/simdutf/scripts/prepare_doxygen.sh +0 -21
  663. package/deps/simdutf/scripts/release.py +0 -197
  664. package/deps/simdutf/scripts/shortinputplots.py +0 -97
  665. package/deps/simdutf/scripts/sse_convert_utf16_to_utf8.py +0 -422
  666. package/deps/simdutf/scripts/sse_convert_utf32_to_utf16.py +0 -105
  667. package/deps/simdutf/scripts/sse_utf8_utf16_decode.py +0 -186
  668. package/deps/simdutf/scripts/sse_validate_utf16le_proof.py +0 -137
  669. package/deps/simdutf/scripts/sse_validate_utf16le_testcases.py +0 -129
  670. package/deps/simdutf/scripts/table.py +0 -207
  671. package/deps/simdutf/scripts/tests/new.txt +0 -33
  672. package/deps/simdutf/scripts/tests/old.txt +0 -33
  673. package/deps/simdutf/scripts/tests/results.txt +0 -272
  674. package/deps/simdutf/simdutf.pc.in +0 -11
  675. package/deps/simdutf/singleheader/.flake8 +0 -2
  676. package/deps/simdutf/singleheader/CMakeLists.txt +0 -64
  677. package/deps/simdutf/singleheader/README-dev.md +0 -81
  678. package/deps/simdutf/singleheader/README.md +0 -19
  679. package/deps/simdutf/singleheader/amalgamate.py +0 -513
  680. package/deps/simdutf/singleheader/amalgamation_demo.c +0 -59
  681. package/deps/simdutf/singleheader/amalgamation_demo.cpp +0 -54
  682. package/deps/simdutf/singleheader/test-features.py +0 -262
  683. package/deps/simdutf/src/CMakeLists.txt +0 -78
  684. package/deps/simdutf/tests/CMakeLists.txt +0 -483
  685. package/deps/simdutf/tests/atomic_base64_tests.cpp +0 -2845
  686. package/deps/simdutf/tests/base64_tests.cpp +0 -3617
  687. package/deps/simdutf/tests/basic_fuzzer.cpp +0 -805
  688. package/deps/simdutf/tests/bele_tests.cpp +0 -182
  689. package/deps/simdutf/tests/constexpr_base64_tests.cpp +0 -387
  690. package/deps/simdutf/tests/convert_latin1_to_utf16be_tests.cpp +0 -52
  691. package/deps/simdutf/tests/convert_latin1_to_utf16le_tests.cpp +0 -80
  692. package/deps/simdutf/tests/convert_latin1_to_utf32_tests.cpp +0 -66
  693. package/deps/simdutf/tests/convert_latin1_to_utf8_tests.cpp +0 -120
  694. package/deps/simdutf/tests/convert_utf16_to_utf8_safe_tests.cpp +0 -203
  695. package/deps/simdutf/tests/convert_utf16_to_utf8_with_replacement_tests.cpp +0 -276
  696. package/deps/simdutf/tests/convert_utf16be_to_latin1_tests.cpp +0 -109
  697. package/deps/simdutf/tests/convert_utf16be_to_latin1_tests_with_errors.cpp +0 -136
  698. package/deps/simdutf/tests/convert_utf16be_to_utf32_tests.cpp +0 -193
  699. package/deps/simdutf/tests/convert_utf16be_to_utf32_with_errors_tests.cpp +0 -381
  700. package/deps/simdutf/tests/convert_utf16be_to_utf8_tests.cpp +0 -259
  701. package/deps/simdutf/tests/convert_utf16be_to_utf8_with_errors_tests.cpp +0 -266
  702. package/deps/simdutf/tests/convert_utf16le_to_latin1_tests.cpp +0 -148
  703. package/deps/simdutf/tests/convert_utf16le_to_latin1_tests_with_errors.cpp +0 -176
  704. package/deps/simdutf/tests/convert_utf16le_to_utf32_tests.cpp +0 -213
  705. package/deps/simdutf/tests/convert_utf16le_to_utf32_with_errors_tests.cpp +0 -318
  706. package/deps/simdutf/tests/convert_utf16le_to_utf8_tests.cpp +0 -343
  707. package/deps/simdutf/tests/convert_utf16le_to_utf8_with_errors_tests.cpp +0 -271
  708. package/deps/simdutf/tests/convert_utf32_to_latin1_tests.cpp +0 -111
  709. package/deps/simdutf/tests/convert_utf32_to_latin1_with_errors_tests.cpp +0 -96
  710. package/deps/simdutf/tests/convert_utf32_to_utf16be_tests.cpp +0 -148
  711. package/deps/simdutf/tests/convert_utf32_to_utf16be_with_errors_tests.cpp +0 -192
  712. package/deps/simdutf/tests/convert_utf32_to_utf16le_tests.cpp +0 -166
  713. package/deps/simdutf/tests/convert_utf32_to_utf16le_with_errors_tests.cpp +0 -215
  714. package/deps/simdutf/tests/convert_utf32_to_utf8_tests.cpp +0 -181
  715. package/deps/simdutf/tests/convert_utf32_to_utf8_with_errors_tests.cpp +0 -261
  716. package/deps/simdutf/tests/convert_utf8_to_latin1_tests.cpp +0 -516
  717. package/deps/simdutf/tests/convert_utf8_to_latin1_with_errors_tests.cpp +0 -579
  718. package/deps/simdutf/tests/convert_utf8_to_utf16be_tests.cpp +0 -412
  719. package/deps/simdutf/tests/convert_utf8_to_utf16be_with_errors_tests.cpp +0 -480
  720. package/deps/simdutf/tests/convert_utf8_to_utf16le_tests.cpp +0 -671
  721. package/deps/simdutf/tests/convert_utf8_to_utf16le_with_errors_tests.cpp +0 -455
  722. package/deps/simdutf/tests/convert_utf8_to_utf32_tests.cpp +0 -1204
  723. package/deps/simdutf/tests/convert_utf8_to_utf32_with_errors_tests.cpp +0 -337
  724. package/deps/simdutf/tests/convert_valid_utf16be_to_latin1_tests.cpp +0 -37
  725. package/deps/simdutf/tests/convert_valid_utf16be_to_utf32_tests.cpp +0 -97
  726. package/deps/simdutf/tests/convert_valid_utf16be_to_utf8_tests.cpp +0 -126
  727. package/deps/simdutf/tests/convert_valid_utf16le_to_latin1_tests.cpp +0 -71
  728. package/deps/simdutf/tests/convert_valid_utf16le_to_utf32_tests.cpp +0 -122
  729. package/deps/simdutf/tests/convert_valid_utf16le_to_utf8_tests.cpp +0 -244
  730. package/deps/simdutf/tests/convert_valid_utf32_to_latin1_tests.cpp +0 -49
  731. package/deps/simdutf/tests/convert_valid_utf32_to_utf16be_tests.cpp +0 -92
  732. package/deps/simdutf/tests/convert_valid_utf32_to_utf16le_tests.cpp +0 -114
  733. package/deps/simdutf/tests/convert_valid_utf32_to_utf8_tests.cpp +0 -109
  734. package/deps/simdutf/tests/convert_valid_utf8_to_latin1_tests.cpp +0 -84
  735. package/deps/simdutf/tests/convert_valid_utf8_to_utf16be_tests.cpp +0 -124
  736. package/deps/simdutf/tests/convert_valid_utf8_to_utf16le_tests.cpp +0 -221
  737. package/deps/simdutf/tests/convert_valid_utf8_to_utf32_tests.cpp +0 -155
  738. package/deps/simdutf/tests/count_utf16be.cpp +0 -64
  739. package/deps/simdutf/tests/count_utf16le.cpp +0 -61
  740. package/deps/simdutf/tests/count_utf8.cpp +0 -87
  741. package/deps/simdutf/tests/detect_encodings_tests.cpp +0 -312
  742. package/deps/simdutf/tests/embed/valid_utf8.txt +0 -1
  743. package/deps/simdutf/tests/embed_tests.cpp +0 -22
  744. package/deps/simdutf/tests/find_tests.cpp +0 -77
  745. package/deps/simdutf/tests/fixed_string_tests.cpp +0 -153
  746. package/deps/simdutf/tests/helpers/CMakeLists.txt +0 -25
  747. package/deps/simdutf/tests/helpers/compiletime_conversions.h +0 -222
  748. package/deps/simdutf/tests/helpers/fixed_string.h +0 -267
  749. package/deps/simdutf/tests/helpers/random_int.cpp +0 -30
  750. package/deps/simdutf/tests/helpers/random_int.h +0 -39
  751. package/deps/simdutf/tests/helpers/random_utf16.cpp +0 -123
  752. package/deps/simdutf/tests/helpers/random_utf16.h +0 -52
  753. package/deps/simdutf/tests/helpers/random_utf32.cpp +0 -41
  754. package/deps/simdutf/tests/helpers/random_utf32.h +0 -40
  755. package/deps/simdutf/tests/helpers/random_utf8.cpp +0 -93
  756. package/deps/simdutf/tests/helpers/random_utf8.h +0 -36
  757. package/deps/simdutf/tests/helpers/test.cpp +0 -231
  758. package/deps/simdutf/tests/helpers/test.h +0 -193
  759. package/deps/simdutf/tests/helpers/transcode_test_base.cpp +0 -1257
  760. package/deps/simdutf/tests/helpers/transcode_test_base.h +0 -683
  761. package/deps/simdutf/tests/helpers/utf16.h +0 -27
  762. package/deps/simdutf/tests/installation_tests/find/CMakeLists.txt +0 -43
  763. package/deps/simdutf/tests/installation_tests/from_fetch/CMakeLists.txt +0 -47
  764. package/deps/simdutf/tests/internal_tests.cpp +0 -27
  765. package/deps/simdutf/tests/null_safety_tests.cpp +0 -94
  766. package/deps/simdutf/tests/random_fuzzer.cpp +0 -779
  767. package/deps/simdutf/tests/readme_tests.cpp +0 -274
  768. package/deps/simdutf/tests/reference/CMakeLists.txt +0 -23
  769. package/deps/simdutf/tests/reference/decode_utf16.h +0 -81
  770. package/deps/simdutf/tests/reference/decode_utf32.h +0 -47
  771. package/deps/simdutf/tests/reference/encode_latin1.cpp +0 -1
  772. package/deps/simdutf/tests/reference/encode_latin1.h +0 -32
  773. package/deps/simdutf/tests/reference/encode_utf16.cpp +0 -49
  774. package/deps/simdutf/tests/reference/encode_utf16.h +0 -20
  775. package/deps/simdutf/tests/reference/encode_utf32.cpp +0 -1
  776. package/deps/simdutf/tests/reference/encode_utf32.h +0 -36
  777. package/deps/simdutf/tests/reference/encode_utf8.cpp +0 -1
  778. package/deps/simdutf/tests/reference/encode_utf8.h +0 -40
  779. package/deps/simdutf/tests/reference/validate_utf16.cpp +0 -60
  780. package/deps/simdutf/tests/reference/validate_utf16.h +0 -14
  781. package/deps/simdutf/tests/reference/validate_utf16_to_latin1.cpp +0 -35
  782. package/deps/simdutf/tests/reference/validate_utf16_to_latin1.h +0 -13
  783. package/deps/simdutf/tests/reference/validate_utf32.cpp +0 -27
  784. package/deps/simdutf/tests/reference/validate_utf32.h +0 -12
  785. package/deps/simdutf/tests/reference/validate_utf32_to_latin1.cpp +0 -27
  786. package/deps/simdutf/tests/reference/validate_utf32_to_latin1.h +0 -12
  787. package/deps/simdutf/tests/reference/validate_utf8.cpp +0 -82
  788. package/deps/simdutf/tests/reference/validate_utf8.h +0 -11
  789. package/deps/simdutf/tests/reference/validate_utf8_to_latin1.cpp +0 -43
  790. package/deps/simdutf/tests/reference/validate_utf8_to_latin1.h +0 -12
  791. package/deps/simdutf/tests/select_implementation.cpp +0 -43
  792. package/deps/simdutf/tests/simdutf_c_tests.cpp +0 -244
  793. package/deps/simdutf/tests/span_tests.cpp +0 -401
  794. package/deps/simdutf/tests/special_tests.cpp +0 -559
  795. package/deps/simdutf/tests/straight_c_test.c +0 -187
  796. package/deps/simdutf/tests/text_encoding_tests.cpp +0 -77
  797. package/deps/simdutf/tests/to_well_formed_utf16_tests.cpp +0 -377
  798. package/deps/simdutf/tests/utf8_length_from_utf16_tests.cpp +0 -202
  799. package/deps/simdutf/tests/validate_ascii_basic_tests.cpp +0 -165
  800. package/deps/simdutf/tests/validate_ascii_with_errors_tests.cpp +0 -77
  801. package/deps/simdutf/tests/validate_utf16be_basic_tests.cpp +0 -175
  802. package/deps/simdutf/tests/validate_utf16be_with_errors_tests.cpp +0 -188
  803. package/deps/simdutf/tests/validate_utf16le_basic_tests.cpp +0 -268
  804. package/deps/simdutf/tests/validate_utf16le_with_errors_tests.cpp +0 -274
  805. package/deps/simdutf/tests/validate_utf32_basic_tests.cpp +0 -92
  806. package/deps/simdutf/tests/validate_utf32_with_errors_tests.cpp +0 -114
  807. package/deps/simdutf/tests/validate_utf8_basic_tests.cpp +0 -178
  808. package/deps/simdutf/tests/validate_utf8_brute_force_tests.cpp +0 -88
  809. package/deps/simdutf/tests/validate_utf8_puzzler_tests.cpp +0 -33
  810. package/deps/simdutf/tests/validate_utf8_with_errors_tests.cpp +0 -228
  811. package/deps/simdutf/tools/CMakeLists.txt +0 -85
  812. package/deps/simdutf/tools/fastbase64.cpp +0 -250
  813. package/deps/simdutf/tools/sutf.cpp +0 -556
  814. package/deps/simdutf/tools/sutf.h +0 -40
  815. package/lib/tsconfig.tsbuildinfo +0 -1
@@ -1 +1 @@
1
- {"version":3,"names":["NitroModules","Stream","StringDecoder","Buffer","binaryLikeToArrayBuffer","getDefaultEncoding","getUIntOption","normalizeEncoding","validateEncoding","CipherUtils","native","createHybridObject","getSupportedCiphers","getCipherInfo","name","keyLength","ivLength","getCiphers","options","length","undefined","CipherCommon","Transform","_decoder","_decoderEncoding","constructor","isCipher","cipherType","cipherKey","iv","streamOptions","transformKeys","key","authTagLen","factory","createCipher","getDecoder","encoding","normalized","Error","update","data","inputEncoding","outputEncoding","defaultEncoding","ArrayBuffer","isView","ret","write","from","final","end","_transform","chunk","callback","push","_flush","setAutoPadding","autoPadding","res","setAAD","buffer","plaintextLength","getAuthTag","setAuthTag","tag","Cipheriv","Decipheriv","createDecipheriv","algorithm","createCipheriv","xsalsa20","nonce","output","counter","result","Uint8Array"],"sourceRoot":"../../src","sources":["cipher.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["NitroModules","Stream","StringDecoder","Buffer","binaryLikeToArrayBuffer","getDefaultEncoding","getUIntOption","normalizeEncoding","validateEncoding","CipherUtils","native","createHybridObject","getSupportedCiphers","getCipherInfo","name","keyLength","ivLength","getCiphers","options","length","undefined","LIBSODIUM_CIPHER_PARAMS","xsalsa20","validateCipherParams","cipherType","keyByteLength","ivByteLength","TypeError","RangeError","lower","toLowerCase","sodium","info","expectedIv","CipherCommon","Transform","_decoder","_decoderEncoding","constructor","isCipher","cipherKey","iv","streamOptions","transformKeys","key","authTagLen","cipherKeyAB","ivAB","byteLength","factory","createCipher","getDecoder","encoding","normalized","Error","update","data","inputEncoding","outputEncoding","defaultEncoding","ArrayBuffer","isView","ret","write","from","final","end","_transform","chunk","callback","push","err","_flush","setAutoPadding","autoPadding","res","setAAD","buffer","plaintextLength","getAuthTag","setAuthTag","tag","Cipheriv","Decipheriv","createDecipheriv","algorithm","createCipheriv","nonce","output","counter","result","Uint8Array"],"sourceRoot":"../../src","sources":["cipher.ts"],"mappings":"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","ignoreList":[]}
@@ -62,6 +62,9 @@ function dh_formatKeyPairOutput(dh, encoding) {
62
62
  const priv = KeyObject.createKeyObject('private', privateKeyData, KFormatType.DER, KeyEncoding.PKCS8);
63
63
  let publicKey;
64
64
  let privateKey;
65
+ if (publicFormat === 'raw-public' || privateFormat === 'raw-private' || privateFormat === 'raw-seed') {
66
+ throw new Error('Raw key formats are not supported for DH keys');
67
+ }
65
68
  if (publicFormat === -1) {
66
69
  publicKey = pub;
67
70
  } else {
@@ -1 +1 @@
1
- {"version":3,"names":["NitroModules","Buffer","KeyObject","KFormatType","KeyEncoding","DH_GROUPS","DhKeyPairGen","constructor","options","native","createHybridObject","groupName","prime","primeLength","generator","group","Error","primeBuf","from","setPrime","buffer","slice","byteOffset","byteLength","gen","parseInt","setGenerator","setPrimeLength","generateKeyPair","generateKeyPairSync","dh_prepareKeyGenParams","dh_formatKeyPairOutput","dh","encoding","publicFormat","privateFormat","cipher","passphrase","publicKeyData","getPublicKey","privateKeyData","getPrivateKey","pub","createKeyObject","DER","SPKI","priv","PKCS8","publicKey","privateKey","format","PEM","exported","handle","exportKey","Uint8Array","toString","dh_generateKeyPairNode","dh_generateKeyPairNodeSync"],"sourceRoot":"../../src","sources":["dhKeyPair.ts"],"mappings":";;AAAA,SAASA,YAAY,QAAQ,4BAA4B;AACzD,SAASC,MAAM,QAAQ,gCAAgC;AACvD,SAASC,SAAS,QAA2C,gBAAgB;AAG7E,SAASC,WAAW,EAAEC,WAAW,QAAQ,SAAS;AAClD,SAASC,SAAS,QAAQ,aAAa;AAEvC,OAAO,MAAMC,YAAY,CAAC;EAGxBC,WAAWA,CAACC,OAA+B,EAAE;IAC3C,IAAI,CAACC,MAAM,GAAGT,YAAY,CAACU,kBAAkB,CAAY,WAAW,CAAC;IAErE,MAAM;MAAEC,SAAS;MAAEC,KAAK;MAAEC,WAAW;MAAEC;IAAU,CAAC,GAAGN,OAAO;IAE5D,IAAIG,SAAS,EAAE;MACb;MACA,MAAMI,KAAK,GAAGV,SAAS,CAACM,SAAS,CAAC;MAClC,IAAI,CAACI,KAAK,EAAE;QACV,MAAM,IAAIC,KAAK,CAAC,qBAAqBL,SAAS,EAAE,CAAC;MACnD;MACA,MAAMM,QAAQ,GAAGhB,MAAM,CAACiB,IAAI,CAACH,KAAK,CAACH,KAAK,EAAE,KAAK,CAAC;MAChD,IAAI,CAACH,MAAM,CAACU,QAAQ,CAClBF,QAAQ,CAACG,MAAM,CAACC,KAAK,CACnBJ,QAAQ,CAACK,UAAU,EACnBL,QAAQ,CAACK,UAAU,GAAGL,QAAQ,CAACM,UACjC,CACF,CAAC;MACD,MAAMC,GAAG,GAAGC,QAAQ,CAACV,KAAK,CAACD,SAAS,EAAE,EAAE,CAAC;MACzC,IAAI,CAACL,MAAM,CAACiB,YAAY,CAACF,GAAG,CAAC;IAC/B,CAAC,MAAM,IAAIZ,KAAK,EAAE;MAChB;MACA,MAAMK,QAAQ,GAAGhB,MAAM,CAACiB,IAAI,CAACN,KAAK,CAAC;MACnC,IAAI,CAACH,MAAM,CAACU,QAAQ,CAClBF,QAAQ,CAACG,MAAM,CAACC,KAAK,CACnBJ,QAAQ,CAACK,UAAU,EACnBL,QAAQ,CAACK,UAAU,GAAGL,QAAQ,CAACM,UACjC,CACF,CAAC;MACD,IAAI,CAACd,MAAM,CAACiB,YAAY,CAACZ,SAAS,IAAI,CAAC,CAAC;IAC1C,CAAC,MAAM,IAAID,WAAW,EAAE;MACtB,IAAI,CAACJ,MAAM,CAACkB,cAAc,CAACd,WAAW,CAAC;MACvC,IAAI,CAACJ,MAAM,CAACiB,YAAY,CAACZ,SAAS,IAAI,CAAC,CAAC;IAC1C,CAAC,MAAM;MACL,MAAM,IAAIE,KAAK,CACb,qEACF,CAAC;IACH;EACF;EAEA,MAAMY,eAAeA,CAAA,EAAkB;IACrC,MAAM,IAAI,CAACnB,MAAM,CAACmB,eAAe,CAAC,CAAC;EACrC;EAEAC,mBAAmBA,CAAA,EAAS;IAC1B,IAAI,CAACpB,MAAM,CAACoB,mBAAmB,CAAC,CAAC;EACnC;AACF;AAEA,SAASC,sBAAsBA,CAC7BtB,OAA2C,EAC7B;EACd,IAAI,CAACA,OAAO,EAAE;IACZ,MAAM,IAAIQ,KAAK,CAAC,4CAA4C,CAAC;EAC/D;EAEA,OAAO,IAAIV,YAAY,CAACE,OAAO,CAAC;AAClC;AAEA,SAASuB,sBAAsBA,CAC7BC,EAAgB,EAChBC,QAA0B,EAI1B;EACA,MAAM;IAAEC,YAAY;IAAEC,aAAa;IAAEC,MAAM;IAAEC;EAAW,CAAC,GAAGJ,QAAQ;EAEpE,MAAMK,aAAa,GAAGN,EAAE,CAACvB,MAAM,CAAC8B,YAAY,CAAC,CAAC;EAC9C,MAAMC,cAAc,GAAGR,EAAE,CAACvB,MAAM,CAACgC,aAAa,CAAC,CAAC;EAEhD,MAAMC,GAAG,GAAGxC,SAAS,CAACyC,eAAe,CACnC,QAAQ,EACRL,aAAa,EACbnC,WAAW,CAACyC,GAAG,EACfxC,WAAW,CAACyC,IACd,CAAoB;EAEpB,MAAMC,IAAI,GAAG5C,SAAS,CAACyC,eAAe,CACpC,SAAS,EACTH,cAAc,EACdrC,WAAW,CAACyC,GAAG,EACfxC,WAAW,CAAC2C,KACd,CAAqB;EAErB,IAAIC,SAA0D;EAC9D,IAAIC,UAA4D;EAEhE,IAAIf,YAAY,KAAK,CAAC,CAAC,EAAE;IACvBc,SAAS,GAAGN,GAAG;EACjB,CAAC,MAAM;IACL,MAAMQ,MAAM,GACVhB,YAAY,KAAK/B,WAAW,CAACgD,GAAG,GAAGhD,WAAW,CAACgD,GAAG,GAAGhD,WAAW,CAACyC,GAAG;IACtE,MAAMQ,QAAQ,GAAGV,GAAG,CAACW,MAAM,CAACC,SAAS,CAACJ,MAAM,EAAE9C,WAAW,CAACyC,IAAI,CAAC;IAC/D,IAAIK,MAAM,KAAK/C,WAAW,CAACgD,GAAG,EAAE;MAC9BH,SAAS,GAAG/C,MAAM,CAACiB,IAAI,CAAC,IAAIqC,UAAU,CAACH,QAAQ,CAAC,CAAC,CAACI,QAAQ,CAAC,OAAO,CAAC;IACrE,CAAC,MAAM;MACLR,SAAS,GAAGI,QAAQ;IACtB;EACF;EAEA,IAAIjB,aAAa,KAAK,CAAC,CAAC,EAAE;IACxBc,UAAU,GAAGH,IAAI;EACnB,CAAC,MAAM;IACL,MAAMI,MAAM,GACVf,aAAa,KAAKhC,WAAW,CAACgD,GAAG,GAAGhD,WAAW,CAACgD,GAAG,GAAGhD,WAAW,CAACyC,GAAG;IACvE,MAAMQ,QAAQ,GAAGN,IAAI,CAACO,MAAM,CAACC,SAAS,CACpCJ,MAAM,EACN9C,WAAW,CAAC2C,KAAK,EACjBX,MAAM,EACNC,UACF,CAAC;IACD,IAAIa,MAAM,KAAK/C,WAAW,CAACgD,GAAG,EAAE;MAC9BF,UAAU,GAAGhD,MAAM,CAACiB,IAAI,CAAC,IAAIqC,UAAU,CAACH,QAAQ,CAAC,CAAC,CAACI,QAAQ,CAAC,OAAO,CAAC;IACtE,CAAC,MAAM;MACLP,UAAU,GAAGG,QAAQ;IACvB;EACF;EAEA,OAAO;IAAEJ,SAAS;IAAEC;EAAW,CAAC;AAClC;AAEA,OAAO,eAAeQ,sBAAsBA,CAC1CjD,OAA2C,EAC3CyB,QAA0B,EAIzB;EACD,MAAMD,EAAE,GAAGF,sBAAsB,CAACtB,OAAO,CAAC;EAC1C,MAAMwB,EAAE,CAACJ,eAAe,CAAC,CAAC;EAC1B,OAAOG,sBAAsB,CAACC,EAAE,EAAEC,QAAQ,CAAC;AAC7C;AAEA,OAAO,SAASyB,0BAA0BA,CACxClD,OAA2C,EAC3CyB,QAA0B,EAI1B;EACA,MAAMD,EAAE,GAAGF,sBAAsB,CAACtB,OAAO,CAAC;EAC1CwB,EAAE,CAACH,mBAAmB,CAAC,CAAC;EACxB,OAAOE,sBAAsB,CAACC,EAAE,EAAEC,QAAQ,CAAC;AAC7C","ignoreList":[]}
1
+ {"version":3,"names":["NitroModules","Buffer","KeyObject","KFormatType","KeyEncoding","DH_GROUPS","DhKeyPairGen","constructor","options","native","createHybridObject","groupName","prime","primeLength","generator","group","Error","primeBuf","from","setPrime","buffer","slice","byteOffset","byteLength","gen","parseInt","setGenerator","setPrimeLength","generateKeyPair","generateKeyPairSync","dh_prepareKeyGenParams","dh_formatKeyPairOutput","dh","encoding","publicFormat","privateFormat","cipher","passphrase","publicKeyData","getPublicKey","privateKeyData","getPrivateKey","pub","createKeyObject","DER","SPKI","priv","PKCS8","publicKey","privateKey","format","PEM","exported","handle","exportKey","Uint8Array","toString","dh_generateKeyPairNode","dh_generateKeyPairNodeSync"],"sourceRoot":"../../src","sources":["dhKeyPair.ts"],"mappings":";;AAAA,SAASA,YAAY,QAAQ,4BAA4B;AACzD,SAASC,MAAM,QAAQ,gCAAgC;AACvD,SAASC,SAAS,QAA2C,gBAAgB;AAG7E,SAASC,WAAW,EAAEC,WAAW,QAAQ,SAAS;AAClD,SAASC,SAAS,QAAQ,aAAa;AAEvC,OAAO,MAAMC,YAAY,CAAC;EAGxBC,WAAWA,CAACC,OAA+B,EAAE;IAC3C,IAAI,CAACC,MAAM,GAAGT,YAAY,CAACU,kBAAkB,CAAY,WAAW,CAAC;IAErE,MAAM;MAAEC,SAAS;MAAEC,KAAK;MAAEC,WAAW;MAAEC;IAAU,CAAC,GAAGN,OAAO;IAE5D,IAAIG,SAAS,EAAE;MACb;MACA,MAAMI,KAAK,GAAGV,SAAS,CAACM,SAAS,CAAC;MAClC,IAAI,CAACI,KAAK,EAAE;QACV,MAAM,IAAIC,KAAK,CAAC,qBAAqBL,SAAS,EAAE,CAAC;MACnD;MACA,MAAMM,QAAQ,GAAGhB,MAAM,CAACiB,IAAI,CAACH,KAAK,CAACH,KAAK,EAAE,KAAK,CAAC;MAChD,IAAI,CAACH,MAAM,CAACU,QAAQ,CAClBF,QAAQ,CAACG,MAAM,CAACC,KAAK,CACnBJ,QAAQ,CAACK,UAAU,EACnBL,QAAQ,CAACK,UAAU,GAAGL,QAAQ,CAACM,UACjC,CACF,CAAC;MACD,MAAMC,GAAG,GAAGC,QAAQ,CAACV,KAAK,CAACD,SAAS,EAAE,EAAE,CAAC;MACzC,IAAI,CAACL,MAAM,CAACiB,YAAY,CAACF,GAAG,CAAC;IAC/B,CAAC,MAAM,IAAIZ,KAAK,EAAE;MAChB;MACA,MAAMK,QAAQ,GAAGhB,MAAM,CAACiB,IAAI,CAACN,KAAK,CAAC;MACnC,IAAI,CAACH,MAAM,CAACU,QAAQ,CAClBF,QAAQ,CAACG,MAAM,CAACC,KAAK,CACnBJ,QAAQ,CAACK,UAAU,EACnBL,QAAQ,CAACK,UAAU,GAAGL,QAAQ,CAACM,UACjC,CACF,CAAC;MACD,IAAI,CAACd,MAAM,CAACiB,YAAY,CAACZ,SAAS,IAAI,CAAC,CAAC;IAC1C,CAAC,MAAM,IAAID,WAAW,EAAE;MACtB,IAAI,CAACJ,MAAM,CAACkB,cAAc,CAACd,WAAW,CAAC;MACvC,IAAI,CAACJ,MAAM,CAACiB,YAAY,CAACZ,SAAS,IAAI,CAAC,CAAC;IAC1C,CAAC,MAAM;MACL,MAAM,IAAIE,KAAK,CACb,qEACF,CAAC;IACH;EACF;EAEA,MAAMY,eAAeA,CAAA,EAAkB;IACrC,MAAM,IAAI,CAACnB,MAAM,CAACmB,eAAe,CAAC,CAAC;EACrC;EAEAC,mBAAmBA,CAAA,EAAS;IAC1B,IAAI,CAACpB,MAAM,CAACoB,mBAAmB,CAAC,CAAC;EACnC;AACF;AAEA,SAASC,sBAAsBA,CAC7BtB,OAA2C,EAC7B;EACd,IAAI,CAACA,OAAO,EAAE;IACZ,MAAM,IAAIQ,KAAK,CAAC,4CAA4C,CAAC;EAC/D;EAEA,OAAO,IAAIV,YAAY,CAACE,OAAO,CAAC;AAClC;AAEA,SAASuB,sBAAsBA,CAC7BC,EAAgB,EAChBC,QAA0B,EAI1B;EACA,MAAM;IAAEC,YAAY;IAAEC,aAAa;IAAEC,MAAM;IAAEC;EAAW,CAAC,GAAGJ,QAAQ;EAEpE,MAAMK,aAAa,GAAGN,EAAE,CAACvB,MAAM,CAAC8B,YAAY,CAAC,CAAC;EAC9C,MAAMC,cAAc,GAAGR,EAAE,CAACvB,MAAM,CAACgC,aAAa,CAAC,CAAC;EAEhD,MAAMC,GAAG,GAAGxC,SAAS,CAACyC,eAAe,CACnC,QAAQ,EACRL,aAAa,EACbnC,WAAW,CAACyC,GAAG,EACfxC,WAAW,CAACyC,IACd,CAAoB;EAEpB,MAAMC,IAAI,GAAG5C,SAAS,CAACyC,eAAe,CACpC,SAAS,EACTH,cAAc,EACdrC,WAAW,CAACyC,GAAG,EACfxC,WAAW,CAAC2C,KACd,CAAqB;EAErB,IAAIC,SAA0D;EAC9D,IAAIC,UAA4D;EAEhE,IACEf,YAAY,KAAK,YAAY,IAC7BC,aAAa,KAAK,aAAa,IAC/BA,aAAa,KAAK,UAAU,EAC5B;IACA,MAAM,IAAInB,KAAK,CAAC,+CAA+C,CAAC;EAClE;EAEA,IAAIkB,YAAY,KAAK,CAAC,CAAC,EAAE;IACvBc,SAAS,GAAGN,GAAG;EACjB,CAAC,MAAM;IACL,MAAMQ,MAAM,GACVhB,YAAY,KAAK/B,WAAW,CAACgD,GAAG,GAAGhD,WAAW,CAACgD,GAAG,GAAGhD,WAAW,CAACyC,GAAG;IACtE,MAAMQ,QAAQ,GAAGV,GAAG,CAACW,MAAM,CAACC,SAAS,CAACJ,MAAM,EAAE9C,WAAW,CAACyC,IAAI,CAAC;IAC/D,IAAIK,MAAM,KAAK/C,WAAW,CAACgD,GAAG,EAAE;MAC9BH,SAAS,GAAG/C,MAAM,CAACiB,IAAI,CAAC,IAAIqC,UAAU,CAACH,QAAQ,CAAC,CAAC,CAACI,QAAQ,CAAC,OAAO,CAAC;IACrE,CAAC,MAAM;MACLR,SAAS,GAAGI,QAAQ;IACtB;EACF;EAEA,IAAIjB,aAAa,KAAK,CAAC,CAAC,EAAE;IACxBc,UAAU,GAAGH,IAAI;EACnB,CAAC,MAAM;IACL,MAAMI,MAAM,GACVf,aAAa,KAAKhC,WAAW,CAACgD,GAAG,GAAGhD,WAAW,CAACgD,GAAG,GAAGhD,WAAW,CAACyC,GAAG;IACvE,MAAMQ,QAAQ,GAAGN,IAAI,CAACO,MAAM,CAACC,SAAS,CACpCJ,MAAM,EACN9C,WAAW,CAAC2C,KAAK,EACjBX,MAAM,EACNC,UACF,CAAC;IACD,IAAIa,MAAM,KAAK/C,WAAW,CAACgD,GAAG,EAAE;MAC9BF,UAAU,GAAGhD,MAAM,CAACiB,IAAI,CAAC,IAAIqC,UAAU,CAACH,QAAQ,CAAC,CAAC,CAACI,QAAQ,CAAC,OAAO,CAAC;IACtE,CAAC,MAAM;MACLP,UAAU,GAAGG,QAAQ;IACvB;EACF;EAEA,OAAO;IAAEJ,SAAS;IAAEC;EAAW,CAAC;AAClC;AAEA,OAAO,eAAeQ,sBAAsBA,CAC1CjD,OAA2C,EAC3CyB,QAA0B,EAIzB;EACD,MAAMD,EAAE,GAAGF,sBAAsB,CAACtB,OAAO,CAAC;EAC1C,MAAMwB,EAAE,CAACJ,eAAe,CAAC,CAAC;EAC1B,OAAOG,sBAAsB,CAACC,EAAE,EAAEC,QAAQ,CAAC;AAC7C;AAEA,OAAO,SAASyB,0BAA0BA,CACxClD,OAA2C,EAC3CyB,QAA0B,EAI1B;EACA,MAAMD,EAAE,GAAGF,sBAAsB,CAACtB,OAAO,CAAC;EAC1CwB,EAAE,CAACH,mBAAmB,CAAC,CAAC;EACxB,OAAOE,sBAAsB,CAACC,EAAE,EAAEC,QAAQ,CAAC;AAC7C","ignoreList":[]}
package/lib/module/dsa.js CHANGED
@@ -19,6 +19,12 @@ export class Dsa {
19
19
  this.native.generateKeyPairSync();
20
20
  }
21
21
  }
22
+
23
+ // FIPS 186-4 §4.2: only L = 1024, 2048, 3072 are sanctioned. NIST has
24
+ // deprecated DSA-1024 for new applications, but we retain it for
25
+ // interop with legacy systems and match Node's permissive default. We
26
+ // reject anything below 1024 outright.
27
+ const DSA_MIN_MODULUS_LENGTH = 1024;
22
28
  function dsa_prepareKeyGenParams(options) {
23
29
  if (!options) {
24
30
  throw new Error('Options are required for DSA key generation');
@@ -27,8 +33,8 @@ function dsa_prepareKeyGenParams(options) {
27
33
  modulusLength,
28
34
  divisorLength
29
35
  } = options;
30
- if (!modulusLength || modulusLength <= 0) {
31
- throw new Error('Invalid or missing modulusLength for DSA key generation');
36
+ if (!modulusLength || modulusLength < DSA_MIN_MODULUS_LENGTH) {
37
+ throw new RangeError(`DSA modulusLength must be at least ${DSA_MIN_MODULUS_LENGTH} bits ` + `(got ${modulusLength ?? 0})`);
32
38
  }
33
39
  return new Dsa(modulusLength, divisorLength);
34
40
  }
@@ -45,6 +51,9 @@ function dsa_formatKeyPairOutput(dsa, encoding) {
45
51
  const priv = KeyObject.createKeyObject('private', privateKeyData, KFormatType.DER, KeyEncoding.PKCS8);
46
52
  let publicKey;
47
53
  let privateKey;
54
+ if (publicFormat === 'raw-public' || privateFormat === 'raw-private' || privateFormat === 'raw-seed') {
55
+ throw new Error('Raw key formats are not supported for DSA keys');
56
+ }
48
57
  if (publicFormat === -1) {
49
58
  publicKey = pub;
50
59
  } else {
@@ -1 +1 @@
1
- {"version":3,"names":["NitroModules","Buffer","KeyObject","KFormatType","KeyEncoding","Dsa","constructor","modulusLength","divisorLength","native","createHybridObject","setModulusLength","undefined","setDivisorLength","generateKeyPair","generateKeyPairSync","dsa_prepareKeyGenParams","options","Error","dsa_formatKeyPairOutput","dsa","encoding","publicFormat","privateFormat","cipher","passphrase","publicKeyData","getPublicKey","privateKeyData","getPrivateKey","pub","createKeyObject","DER","SPKI","priv","PKCS8","publicKey","privateKey","format","PEM","exported","handle","exportKey","from","Uint8Array","toString","dsa_generateKeyPairNode","dsa_generateKeyPairNodeSync"],"sourceRoot":"../../src","sources":["dsa.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["NitroModules","Buffer","KeyObject","KFormatType","KeyEncoding","Dsa","constructor","modulusLength","divisorLength","native","createHybridObject","setModulusLength","undefined","setDivisorLength","generateKeyPair","generateKeyPairSync","DSA_MIN_MODULUS_LENGTH","dsa_prepareKeyGenParams","options","Error","RangeError","dsa_formatKeyPairOutput","dsa","encoding","publicFormat","privateFormat","cipher","passphrase","publicKeyData","getPublicKey","privateKeyData","getPrivateKey","pub","createKeyObject","DER","SPKI","priv","PKCS8","publicKey","privateKey","format","PEM","exported","handle","exportKey","from","Uint8Array","toString","dsa_generateKeyPairNode","dsa_generateKeyPairNodeSync"],"sourceRoot":"../../src","sources":["dsa.ts"],"mappings":";;AAAA,SAASA,YAAY,QAAQ,4BAA4B;AACzD,SAASC,MAAM,QAAQ,gCAAgC;AACvD,SAASC,SAAS,QAA2C,gBAAgB;AAG7E,SAASC,WAAW,EAAEC,WAAW,QAAQ,SAAS;AAElD,OAAO,MAAMC,GAAG,CAAC;EAGfC,WAAWA,CAACC,aAAqB,EAAEC,aAAsB,EAAE;IACzD,IAAI,CAACC,MAAM,GAAGT,YAAY,CAACU,kBAAkB,CAAa,YAAY,CAAC;IACvE,IAAI,CAACD,MAAM,CAACE,gBAAgB,CAACJ,aAAa,CAAC;IAC3C,IAAIC,aAAa,KAAKI,SAAS,IAAIJ,aAAa,IAAI,CAAC,EAAE;MACrD,IAAI,CAACC,MAAM,CAACI,gBAAgB,CAACL,aAAa,CAAC;IAC7C;EACF;EAEA,MAAMM,eAAeA,CAAA,EAAkB;IACrC,MAAM,IAAI,CAACL,MAAM,CAACK,eAAe,CAAC,CAAC;EACrC;EAEAC,mBAAmBA,CAAA,EAAS;IAC1B,IAAI,CAACN,MAAM,CAACM,mBAAmB,CAAC,CAAC;EACnC;AACF;;AAEA;AACA;AACA;AACA;AACA,MAAMC,sBAAsB,GAAG,IAAI;AAEnC,SAASC,uBAAuBA,CAC9BC,OAA2C,EACtC;EACL,IAAI,CAACA,OAAO,EAAE;IACZ,MAAM,IAAIC,KAAK,CAAC,6CAA6C,CAAC;EAChE;EAEA,MAAM;IAAEZ,aAAa;IAAEC;EAAc,CAAC,GAAGU,OAAO;EAEhD,IAAI,CAACX,aAAa,IAAIA,aAAa,GAAGS,sBAAsB,EAAE;IAC5D,MAAM,IAAII,UAAU,CAClB,sCAAsCJ,sBAAsB,QAAQ,GAClE,QAAQT,aAAa,IAAI,CAAC,GAC9B,CAAC;EACH;EAEA,OAAO,IAAIF,GAAG,CAACE,aAAa,EAAEC,aAAa,CAAC;AAC9C;AAEA,SAASa,uBAAuBA,CAC9BC,GAAQ,EACRC,QAA0B,EAI1B;EACA,MAAM;IAAEC,YAAY;IAAEC,aAAa;IAAEC,MAAM;IAAEC;EAAW,CAAC,GAAGJ,QAAQ;EAEpE,MAAMK,aAAa,GAAGN,GAAG,CAACb,MAAM,CAACoB,YAAY,CAAC,CAAC;EAC/C,MAAMC,cAAc,GAAGR,GAAG,CAACb,MAAM,CAACsB,aAAa,CAAC,CAAC;EAEjD,MAAMC,GAAG,GAAG9B,SAAS,CAAC+B,eAAe,CACnC,QAAQ,EACRL,aAAa,EACbzB,WAAW,CAAC+B,GAAG,EACf9B,WAAW,CAAC+B,IACd,CAAoB;EAEpB,MAAMC,IAAI,GAAGlC,SAAS,CAAC+B,eAAe,CACpC,SAAS,EACTH,cAAc,EACd3B,WAAW,CAAC+B,GAAG,EACf9B,WAAW,CAACiC,KACd,CAAqB;EAErB,IAAIC,SAA0D;EAC9D,IAAIC,UAA4D;EAEhE,IACEf,YAAY,KAAK,YAAY,IAC7BC,aAAa,KAAK,aAAa,IAC/BA,aAAa,KAAK,UAAU,EAC5B;IACA,MAAM,IAAIN,KAAK,CAAC,gDAAgD,CAAC;EACnE;EAEA,IAAIK,YAAY,KAAK,CAAC,CAAC,EAAE;IACvBc,SAAS,GAAGN,GAAG;EACjB,CAAC,MAAM;IACL,MAAMQ,MAAM,GACVhB,YAAY,KAAKrB,WAAW,CAACsC,GAAG,GAAGtC,WAAW,CAACsC,GAAG,GAAGtC,WAAW,CAAC+B,GAAG;IACtE,MAAMQ,QAAQ,GAAGV,GAAG,CAACW,MAAM,CAACC,SAAS,CAACJ,MAAM,EAAEpC,WAAW,CAAC+B,IAAI,CAAC;IAC/D,IAAIK,MAAM,KAAKrC,WAAW,CAACsC,GAAG,EAAE;MAC9BH,SAAS,GAAGrC,MAAM,CAAC4C,IAAI,CAAC,IAAIC,UAAU,CAACJ,QAAQ,CAAC,CAAC,CAACK,QAAQ,CAAC,OAAO,CAAC;IACrE,CAAC,MAAM;MACLT,SAAS,GAAGI,QAAQ;IACtB;EACF;EAEA,IAAIjB,aAAa,KAAK,CAAC,CAAC,EAAE;IACxBc,UAAU,GAAGH,IAAI;EACnB,CAAC,MAAM;IACL,MAAMI,MAAM,GACVf,aAAa,KAAKtB,WAAW,CAACsC,GAAG,GAAGtC,WAAW,CAACsC,GAAG,GAAGtC,WAAW,CAAC+B,GAAG;IACvE,MAAMQ,QAAQ,GAAGN,IAAI,CAACO,MAAM,CAACC,SAAS,CACpCJ,MAAM,EACNpC,WAAW,CAACiC,KAAK,EACjBX,MAAM,EACNC,UACF,CAAC;IACD,IAAIa,MAAM,KAAKrC,WAAW,CAACsC,GAAG,EAAE;MAC9BF,UAAU,GAAGtC,MAAM,CAAC4C,IAAI,CAAC,IAAIC,UAAU,CAACJ,QAAQ,CAAC,CAAC,CAACK,QAAQ,CAAC,OAAO,CAAC;IACtE,CAAC,MAAM;MACLR,UAAU,GAAGG,QAAQ;IACvB;EACF;EAEA,OAAO;IAAEJ,SAAS;IAAEC;EAAW,CAAC;AAClC;AAEA,OAAO,eAAeS,uBAAuBA,CAC3C9B,OAA2C,EAC3CK,QAA0B,EAIzB;EACD,MAAMD,GAAG,GAAGL,uBAAuB,CAACC,OAAO,CAAC;EAC5C,MAAMI,GAAG,CAACR,eAAe,CAAC,CAAC;EAC3B,OAAOO,uBAAuB,CAACC,GAAG,EAAEC,QAAQ,CAAC;AAC/C;AAEA,OAAO,SAAS0B,2BAA2BA,CACzC/B,OAA2C,EAC3CK,QAA0B,EAI1B;EACA,MAAMD,GAAG,GAAGL,uBAAuB,CAACC,OAAO,CAAC;EAC5CI,GAAG,CAACP,mBAAmB,CAAC,CAAC;EACzB,OAAOM,uBAAuB,CAACC,GAAG,EAAEC,QAAQ,CAAC;AAC/C","ignoreList":[]}
package/lib/module/ec.js CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
  import { NitroModules } from 'react-native-nitro-modules';
4
4
  import { CryptoKey, KeyObject, PublicKeyObject, PrivateKeyObject } from './keys/classes';
5
- import { bufferLikeToArrayBuffer, getUsagesUnion, hasAnyNotIn, kNamedCurveAliases, lazyDOMException, normalizeHashName, HashContext, KeyEncoding, KFormatType } from './utils';
5
+ import { bufferLikeToArrayBuffer, getUsagesUnion, hasAnyNotIn, kNamedCurveAliases, lazyDOMException, normalizeHashName, validateJwkStructure, HashContext, KeyEncoding, KFormatType } from './utils';
6
6
  import { Buffer } from '@craftzdog/react-native-buffer';
7
7
  import { ECDH } from './ecdh';
8
8
  class EcUtils {
@@ -49,70 +49,62 @@ export function ecImportKey(format, keyData, algorithm, extractable, keyUsages)
49
49
  if (!namedCurve || !kNamedCurveAliases[namedCurve]) {
50
50
  throw lazyDOMException('Unrecognized namedCurve', 'NotSupportedError');
51
51
  }
52
-
53
- // Handle JWK format
54
52
  if (format === 'jwk') {
55
53
  const jwk = keyData;
56
-
57
- // Validate JWK
54
+ if (!jwk || typeof jwk !== 'object') {
55
+ throw lazyDOMException('Invalid keyData', 'DataError');
56
+ }
58
57
  if (jwk.kty !== 'EC') {
59
58
  throw lazyDOMException('Invalid JWK "kty" Parameter', 'DataError');
60
59
  }
61
60
  if (jwk.crv !== namedCurve) {
62
61
  throw lazyDOMException('JWK "crv" does not match the requested algorithm', 'DataError');
63
62
  }
64
-
65
- // Check use parameter if present
66
- if (jwk.use !== undefined) {
67
- const expectedUse = name === 'ECDH' ? 'enc' : 'sig';
68
- if (jwk.use !== expectedUse) {
69
- throw lazyDOMException('Invalid JWK "use" Parameter', 'DataError');
70
- }
71
- }
72
-
73
- // Check alg parameter if present
63
+ const expectedUse = name === 'ECDH' ? 'enc' : 'sig';
64
+ validateJwkStructure(jwk, extractable, keyUsages, expectedUse);
74
65
  if (jwk.alg !== undefined) {
75
66
  let expectedAlg;
76
67
  if (name === 'ECDSA') {
77
- // Map namedCurve to expected ECDSA algorithm
78
68
  expectedAlg = namedCurve === 'P-256' ? 'ES256' : namedCurve === 'P-384' ? 'ES384' : namedCurve === 'P-521' ? 'ES512' : undefined;
79
69
  } else if (name === 'ECDH') {
80
- // ECDH uses ECDH-ES algorithm
81
70
  expectedAlg = 'ECDH-ES';
82
71
  }
83
- if (expectedAlg && jwk.alg !== undefined && jwk.alg !== expectedAlg) {
72
+ if (expectedAlg && jwk.alg !== expectedAlg) {
84
73
  throw lazyDOMException('JWK "alg" does not match the requested algorithm', 'DataError');
85
74
  }
86
75
  }
87
-
88
- // Import using C++ layer
76
+ const isPublicJwk = jwk.d === undefined;
77
+ const validUsagesJwk = name === 'ECDSA' ? isPublicJwk ? ['verify'] : ['sign'] : isPublicJwk ? [] : ['deriveKey', 'deriveBits'];
78
+ if (hasAnyNotIn(keyUsages, validUsagesJwk)) {
79
+ throw lazyDOMException(`Unsupported key usage for a ${name} key`, 'SyntaxError');
80
+ }
89
81
  const handle = NitroModules.createHybridObject('KeyObjectHandle');
90
- const keyType = handle.initJwk(jwk, namedCurve);
82
+ let keyType;
83
+ try {
84
+ keyType = handle.initJwk(jwk, namedCurve);
85
+ } catch (err) {
86
+ throw lazyDOMException('Invalid keyData', {
87
+ name: 'DataError',
88
+ cause: err
89
+ });
90
+ }
91
91
  if (keyType === undefined) {
92
- throw lazyDOMException('Invalid JWK', 'DataError');
92
+ throw lazyDOMException('Invalid keyData', 'DataError');
93
93
  }
94
-
95
- // Create the appropriate KeyObject based on type
96
94
  let keyObject;
97
95
  if (keyType === 1) {
98
96
  keyObject = new PublicKeyObject(handle);
99
97
  } else if (keyType === 2) {
100
98
  keyObject = new PrivateKeyObject(handle);
101
99
  } else {
102
- throw lazyDOMException('Unexpected key type from JWK import', 'DataError');
100
+ throw lazyDOMException('Invalid keyData', 'DataError');
103
101
  }
104
102
  return new CryptoKey(keyObject, algorithm, keyUsages, extractable);
105
103
  }
106
-
107
- // Handle binary formats (spki, pkcs8, raw)
108
104
  if (format !== 'spki' && format !== 'pkcs8' && format !== 'raw') {
109
105
  throw lazyDOMException(`Unsupported format: ${format}`, 'NotSupportedError');
110
106
  }
111
-
112
- // Determine expected key type based on format
113
107
  const expectedKeyType = format === 'spki' || format === 'raw' ? 'public' : 'private';
114
-
115
- // Validate usages for the key type
116
108
  const isPublicKey = expectedKeyType === 'public';
117
109
  let validUsages;
118
110
  if (name === 'ECDSA') {
@@ -143,6 +135,17 @@ export function ecImportKey(format, keyData, algorithm, extractable, keyUsages)
143
135
  } else {
144
136
  // Use standard DER import for spki/pkcs8
145
137
  keyObject = KeyObject.createKeyObject(expectedKeyType, keyBuffer, KFormatType.DER, format === 'spki' ? KeyEncoding.SPKI : KeyEncoding.PKCS8);
138
+
139
+ // Validate the imported curve matches the requested algorithm.namedCurve.
140
+ const expectedAlias = kNamedCurveAliases[namedCurve];
141
+ if (keyObject.handle.keyDetail().namedCurve !== expectedAlias) {
142
+ throw lazyDOMException('Named curve mismatch', 'DataError');
143
+ }
144
+ }
145
+
146
+ // Verify the public/private point lies on the named curve.
147
+ if (!keyObject.handle.checkEcKeyData()) {
148
+ throw lazyDOMException('Invalid keyData', 'DataError');
146
149
  }
147
150
  return new CryptoKey(keyObject, algorithm, keyUsages, extractable);
148
151
  }
@@ -270,6 +273,8 @@ function ec_formatKeyPairOutput(ec, encoding) {
270
273
  let privateKey;
271
274
  if (publicFormat === -1) {
272
275
  publicKey = pub;
276
+ } else if (publicFormat === 'raw-public') {
277
+ publicKey = Buffer.from(pub.handle.exportECPublicRaw(publicType === 'compressed'));
273
278
  } else {
274
279
  const format = publicFormat === KFormatType.PEM ? KFormatType.PEM : KFormatType.DER;
275
280
  const keyEncoding = publicType === KeyEncoding.SPKI ? KeyEncoding.SPKI : KeyEncoding.SPKI;
@@ -282,6 +287,8 @@ function ec_formatKeyPairOutput(ec, encoding) {
282
287
  }
283
288
  if (privateFormat === -1) {
284
289
  privateKey = priv;
290
+ } else if (privateFormat === 'raw-private') {
291
+ privateKey = Buffer.from(priv.handle.exportECPrivateRaw());
285
292
  } else {
286
293
  const format = privateFormat === KFormatType.PEM ? KFormatType.PEM : KFormatType.DER;
287
294
  const keyEncoding = privateType === KeyEncoding.PKCS8 ? KeyEncoding.PKCS8 : privateType === KeyEncoding.SEC1 ? KeyEncoding.SEC1 : KeyEncoding.PKCS8;
@@ -1 +1 @@
1
- {"version":3,"names":["NitroModules","CryptoKey","KeyObject","PublicKeyObject","PrivateKeyObject","bufferLikeToArrayBuffer","getUsagesUnion","hasAnyNotIn","kNamedCurveAliases","lazyDOMException","normalizeHashName","HashContext","KeyEncoding","KFormatType","Buffer","ECDH","EcUtils","native","_native","createHybridObject","getSupportedCurves","getCurves","Ec","constructor","curve","setCurve","generateKeyPair","publicKey","getPublicKey","privateKey","getPrivateKey","generateKeyPairSync","ecImportKey","format","keyData","algorithm","extractable","keyUsages","name","namedCurve","jwk","kty","crv","use","undefined","expectedUse","alg","expectedAlg","handle","keyType","initJwk","keyObject","expectedKeyType","isPublicKey","validUsages","keyBuffer","curveAlias","initECRaw","createKeyObject","DER","SPKI","PKCS8","ecdsaSignVerify","key","data","hash","signature","isSign","type","hashName","normalizedHashName","WebCrypto","ec","encoding","exportKey","importKey","usages","dataBuffer","sign","signatureBuffer","verify","ec_generateKeyPair","_options","Object","keys","includes","publicUsages","privateUsages","keyAlgorithm","publicKeyData","privateKeyData","pub","priv","ec_prepareKeyGenParams","options","Error","ec_formatKeyPairOutput","publicFormat","publicType","privateFormat","privateType","cipher","passphrase","PEM","keyEncoding","exported","from","Uint8Array","toString","SEC1","ec_generateKeyPairNode","ec_generateKeyPairNodeSync","ecDeriveBits","baseKey","length","public","opensslCurve","ecdh","jwkPrivate","exportJwk","d","privateBytes","setPrivateKey","jwkPublic","x","y","publicBytes","concat","secret","computeSecret","secretBuf","buffer","byteLength","Math","ceil","slice","byteOffset"],"sourceRoot":"../../src","sources":["ec.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["NitroModules","CryptoKey","KeyObject","PublicKeyObject","PrivateKeyObject","bufferLikeToArrayBuffer","getUsagesUnion","hasAnyNotIn","kNamedCurveAliases","lazyDOMException","normalizeHashName","validateJwkStructure","HashContext","KeyEncoding","KFormatType","Buffer","ECDH","EcUtils","native","_native","createHybridObject","getSupportedCurves","getCurves","Ec","constructor","curve","setCurve","generateKeyPair","publicKey","getPublicKey","privateKey","getPrivateKey","generateKeyPairSync","ecImportKey","format","keyData","algorithm","extractable","keyUsages","name","namedCurve","jwk","kty","crv","expectedUse","alg","undefined","expectedAlg","isPublicJwk","d","validUsagesJwk","handle","keyType","initJwk","err","cause","keyObject","expectedKeyType","isPublicKey","validUsages","keyBuffer","curveAlias","initECRaw","createKeyObject","DER","SPKI","PKCS8","expectedAlias","keyDetail","checkEcKeyData","ecdsaSignVerify","key","data","hash","signature","isSign","type","hashName","normalizedHashName","WebCrypto","ec","encoding","exportKey","importKey","usages","dataBuffer","sign","signatureBuffer","verify","ec_generateKeyPair","_options","Object","keys","includes","publicUsages","privateUsages","keyAlgorithm","publicKeyData","privateKeyData","pub","priv","ec_prepareKeyGenParams","options","Error","ec_formatKeyPairOutput","publicFormat","publicType","privateFormat","privateType","cipher","passphrase","from","exportECPublicRaw","PEM","keyEncoding","exported","Uint8Array","toString","exportECPrivateRaw","SEC1","ec_generateKeyPairNode","ec_generateKeyPairNodeSync","ecDeriveBits","baseKey","length","public","opensslCurve","ecdh","jwkPrivate","exportJwk","privateBytes","setPrivateKey","jwkPublic","x","y","publicBytes","concat","secret","computeSecret","secretBuf","buffer","byteLength","Math","ceil","slice","byteOffset"],"sourceRoot":"../../src","sources":["ec.ts"],"mappings":"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","ignoreList":[]}
package/lib/module/ed.js CHANGED
@@ -2,9 +2,12 @@
2
2
 
3
3
  import { NitroModules } from 'react-native-nitro-modules';
4
4
  import { Buffer } from '@craftzdog/react-native-buffer';
5
- import { CryptoKey, KeyObject } from './keys/classes';
5
+ import { CryptoKey, KeyObject, PublicKeyObject, PrivateKeyObject as PrivateKeyObjectClass } from './keys/classes';
6
6
  import { binaryLikeToArrayBuffer as toAB, hasAnyNotIn, lazyDOMException, getUsagesUnion, KFormatType, KeyEncoding } from './utils';
7
7
  import { ECDH } from './ecdh';
8
+ function coerceToNumeric(value) {
9
+ return typeof value === 'number' ? value : -1;
10
+ }
8
11
  export class Ed {
9
12
  constructor(type, config) {
10
13
  this.type = type;
@@ -50,10 +53,10 @@ export class Ed {
50
53
  }
51
54
  }
52
55
  async generateKeyPair() {
53
- await this.native.generateKeyPair(this.config.publicFormat ?? -1, this.config.publicType ?? -1, this.config.privateFormat ?? -1, this.config.privateType ?? -1, this.config.cipher, this.config.passphrase);
56
+ await this.native.generateKeyPair(coerceToNumeric(this.config.publicFormat), coerceToNumeric(this.config.publicType), coerceToNumeric(this.config.privateFormat), coerceToNumeric(this.config.privateType), this.config.cipher, this.config.passphrase);
54
57
  }
55
58
  generateKeyPairSync() {
56
- this.native.generateKeyPairSync(this.config.publicFormat ?? -1, this.config.publicType ?? -1, this.config.privateFormat ?? -1, this.config.privateType ?? -1, this.config.cipher, this.config.passphrase);
59
+ this.native.generateKeyPairSync(coerceToNumeric(this.config.publicFormat), coerceToNumeric(this.config.publicType), coerceToNumeric(this.config.privateFormat), coerceToNumeric(this.config.privateType), this.config.cipher, this.config.passphrase);
57
60
  }
58
61
  getPublicKey() {
59
62
  return this.native.getPublicKey();
@@ -91,15 +94,60 @@ export class Ed {
91
94
 
92
95
  // Node API
93
96
  export function diffieHellman(options, callback) {
94
- checkDiffieHellmanOptions(options);
95
- const privateKey = options.privateKey;
97
+ if (!options || typeof options !== 'object') {
98
+ throw new TypeError('options must be an object');
99
+ }
100
+ if (callback !== undefined && typeof callback !== 'function') {
101
+ throw new TypeError('callback must be a function');
102
+ }
103
+ const resolvedOptions = {
104
+ publicKey: resolveDhKeyInput(options.publicKey, 'publicKey'),
105
+ privateKey: resolveDhKeyInput(options.privateKey, 'privateKey')
106
+ };
107
+ checkDiffieHellmanOptions(resolvedOptions);
108
+ const privateKey = resolvedOptions.privateKey;
96
109
  const keyType = privateKey.asymmetricKeyType;
97
110
  if (keyType === 'ec') {
98
- return ecDiffieHellman(options, callback);
111
+ return ecDiffieHellman(resolvedOptions, callback);
112
+ }
113
+ if (keyType === 'dh') {
114
+ throw new Error('crypto.diffieHellman with DH KeyObjects is not supported yet — use the DiffieHellman class for now');
99
115
  }
100
116
  const type = keyType;
101
117
  const ed = new Ed(type, {});
102
- return ed.diffieHellman(options, callback);
118
+ return ed.diffieHellman(resolvedOptions, callback);
119
+ }
120
+ function isRawKeyInput(value) {
121
+ if (!value || typeof value !== 'object') return false;
122
+ const obj = value;
123
+ return obj.format === 'raw-public' || obj.format === 'raw-private' || obj.format === 'raw-seed';
124
+ }
125
+ function resolveDhKeyInput(input, name) {
126
+ if (isRawKeyInput(input)) {
127
+ const expectedKeyType = name === 'publicKey' ? 'public' : 'private';
128
+ if (input.format === 'raw-public' && expectedKeyType !== 'public') {
129
+ throw new Error(`Invalid format 'raw-public' for ${name}`);
130
+ }
131
+ if ((input.format === 'raw-private' || input.format === 'raw-seed') && expectedKeyType !== 'private') {
132
+ throw new Error(`Invalid format '${input.format}' for ${name}`);
133
+ }
134
+ if (input.asymmetricKeyType === 'ec' && !input.namedCurve) {
135
+ throw new Error(`namedCurve is required for EC raw key in ${name}`);
136
+ }
137
+ const handle = NitroModules.createHybridObject('KeyObjectHandle');
138
+ const keyData = toAB(input.key);
139
+ if (input.format === 'raw-public') {
140
+ handle.initRawPublic(input.asymmetricKeyType, keyData, input.namedCurve);
141
+ return new PublicKeyObject(handle);
142
+ }
143
+ if (input.format === 'raw-seed') {
144
+ handle.initRawSeed(input.asymmetricKeyType, keyData);
145
+ return new PrivateKeyObjectClass(handle);
146
+ }
147
+ handle.initRawPrivate(input.asymmetricKeyType, keyData, input.namedCurve);
148
+ return new PrivateKeyObjectClass(handle);
149
+ }
150
+ return input;
103
151
  }
104
152
  function ed_createKeyObjects(ed) {
105
153
  const publicKeyData = ed.getPublicKey();
@@ -128,6 +176,8 @@ function ed_formatKeyPairOutput(ed, encoding) {
128
176
  let privateKey;
129
177
  if (publicFormat == null || publicFormat === -1) {
130
178
  publicKey = pub;
179
+ } else if (publicFormat === 'raw-public') {
180
+ publicKey = Buffer.from(pub.handle.exportRawPublic());
131
181
  } else {
132
182
  const format = publicFormat === KFormatType.PEM ? KFormatType.PEM : KFormatType.DER;
133
183
  const exported = pub.handle.exportKey(format, KeyEncoding.SPKI);
@@ -139,6 +189,10 @@ function ed_formatKeyPairOutput(ed, encoding) {
139
189
  }
140
190
  if (privateFormat == null || privateFormat === -1) {
141
191
  privateKey = priv;
192
+ } else if (privateFormat === 'raw-private') {
193
+ privateKey = Buffer.from(priv.handle.exportRawPrivate());
194
+ } else if (privateFormat === 'raw-seed') {
195
+ privateKey = Buffer.from(priv.handle.exportRawSeed());
142
196
  } else {
143
197
  const format = privateFormat === KFormatType.PEM ? KFormatType.PEM : KFormatType.DER;
144
198
  const exported = priv.handle.exportKey(format, KeyEncoding.PKCS8, cipher, passphrase);
@@ -1 +1 @@
1
- {"version":3,"names":["NitroModules","Buffer","CryptoKey","KeyObject","binaryLikeToArrayBuffer","toAB","hasAnyNotIn","lazyDOMException","getUsagesUnion","KFormatType","KeyEncoding","ECDH","Ed","constructor","type","config","native","createHybridObject","setCurve","diffieHellman","options","callback","privKeyObj","privateKey","pubKeyObj","publicKey","handle","exportKey","ret","Error","from","e","err","undefined","generateKeyPair","publicFormat","publicType","privateFormat","privateType","cipher","passphrase","generateKeyPairSync","getPublicKey","getPrivateKey","getSharedSecret","sign","message","key","signSync","verify","signature","verifySync","checkDiffieHellmanOptions","keyType","asymmetricKeyType","ecDiffieHellman","ed","ed_createKeyObjects","publicKeyData","privateKeyData","pub","createKeyObject","DER","SPKI","priv","PKCS8","ed_formatKeyPairOutput","encoding","format","PEM","exported","Uint8Array","toString","ed_generateKeyPair","isAsync","derConfig","then","catch","String","curveName","namedCurve","ecdh","jwkPrivate","exportJwk","d","setPrivateKey","jwkPublic","x","y","publicBytes","concat","secret","computeSecret","privateKeyAsym","publicKeyAsym","privateCurve","publicCurve","ed_generateKeyPairWebCrypto","extractable","keyUsages","publicUsages","privateUsages","length","algorithmName","name","x_generateKeyPairWebCrypto","xDeriveBits","algorithm","baseKey","public","toLowerCase","privateKeyBytes","keyObject","publicKeyBytes","privateKeyTyped","publicKeyTyped","byteLength","Math","ceil","slice"],"sourceRoot":"../../src","sources":["ed.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["NitroModules","Buffer","CryptoKey","KeyObject","PublicKeyObject","PrivateKeyObject","PrivateKeyObjectClass","binaryLikeToArrayBuffer","toAB","hasAnyNotIn","lazyDOMException","getUsagesUnion","KFormatType","KeyEncoding","ECDH","coerceToNumeric","value","Ed","constructor","type","config","native","createHybridObject","setCurve","diffieHellman","options","callback","privKeyObj","privateKey","pubKeyObj","publicKey","handle","exportKey","ret","Error","from","e","err","undefined","generateKeyPair","publicFormat","publicType","privateFormat","privateType","cipher","passphrase","generateKeyPairSync","getPublicKey","getPrivateKey","getSharedSecret","sign","message","key","signSync","verify","signature","verifySync","TypeError","resolvedOptions","resolveDhKeyInput","checkDiffieHellmanOptions","keyType","asymmetricKeyType","ecDiffieHellman","ed","isRawKeyInput","obj","format","input","name","expectedKeyType","namedCurve","keyData","initRawPublic","initRawSeed","initRawPrivate","ed_createKeyObjects","publicKeyData","privateKeyData","pub","createKeyObject","DER","SPKI","priv","PKCS8","ed_formatKeyPairOutput","encoding","exportRawPublic","PEM","exported","Uint8Array","toString","exportRawPrivate","exportRawSeed","ed_generateKeyPair","isAsync","derConfig","then","catch","String","curveName","ecdh","jwkPrivate","exportJwk","d","setPrivateKey","jwkPublic","x","y","publicBytes","concat","secret","computeSecret","privateKeyAsym","publicKeyAsym","privateCurve","publicCurve","ed_generateKeyPairWebCrypto","extractable","keyUsages","publicUsages","privateUsages","length","algorithmName","x_generateKeyPairWebCrypto","xDeriveBits","algorithm","baseKey","public","toLowerCase","privateKeyBytes","keyObject","publicKeyBytes","privateKeyTyped","publicKeyTyped","byteLength","Math","ceil","slice"],"sourceRoot":"../../src","sources":["ed.ts"],"mappings":"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","ignoreList":[]}