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,4 +1,5 @@
1
1
  #include <cstdio>
2
+ #include <mutex>
2
3
  #include <stdexcept>
3
4
 
4
5
  #include "../utils/base64.h"
@@ -10,10 +11,42 @@
10
11
  #include <openssl/ec.h>
11
12
  #include <openssl/evp.h>
12
13
  #include <openssl/obj_mac.h>
14
+ #include <openssl/provider.h>
13
15
  #include <openssl/rsa.h>
14
16
 
15
17
  namespace margelo::nitro::crypto {
16
18
 
19
+ #if OPENSSL_VERSION_NUMBER >= 0x30600000L
20
+ // Configure loaded providers to prefer seed-only PKCS#8 output for ML-DSA /
21
+ // ML-KEM, falling back to priv-only when no seed is available. Without this,
22
+ // OpenSSL defaults to "seed-priv" — a longer encoding that bundles both —
23
+ // which breaks interop with Node and the exact-length export check in subtle.ts.
24
+ // Mirrors src/crypto/crypto_util.cc in Node.
25
+ static void configurePqcOutputFormats() {
26
+ static std::once_flag once;
27
+ std::call_once(once, []() {
28
+ OSSL_PROVIDER_do_all(
29
+ nullptr,
30
+ [](OSSL_PROVIDER* provider, void*) -> int {
31
+ OSSL_PROVIDER_add_conf_parameter(provider, "ml-kem.output_formats", "seed-only,priv-only");
32
+ OSSL_PROVIDER_add_conf_parameter(provider, "ml-dsa.output_formats", "seed-only,priv-only");
33
+ OSSL_PROVIDER_add_conf_parameter(provider, "slh-dsa.output_formats", "seed-only,priv-only");
34
+ return 1;
35
+ },
36
+ nullptr);
37
+ });
38
+ }
39
+ #endif
40
+
41
+ HybridKeyObjectHandle::HybridKeyObjectHandle() : HybridObject(TAG) {
42
+ #if OPENSSL_VERSION_NUMBER >= 0x30600000L
43
+ // Configure once on first handle construction. Providers are guaranteed
44
+ // loaded by this point (any prior crypto op routed through ncrypto), and
45
+ // the call_once flag makes subsequent constructions cheap.
46
+ configurePqcOutputFormats();
47
+ #endif
48
+ }
49
+
17
50
  // Helper functions for base64url encoding/decoding with BIGNUMs
18
51
  static std::string bn_to_base64url(const BIGNUM* bn, size_t expected_size = 0) {
19
52
  if (!bn)
@@ -142,7 +175,7 @@ std::shared_ptr<ArrayBuffer> HybridKeyObjectHandle::exportKey(std::optional<KFor
142
175
  const char* typeName = EVP_PKEY_get0_type_name(pkey.get());
143
176
  if (typeName != nullptr) {
144
177
  std::string name(typeName);
145
- bool isPqcKey = (name.starts_with("ML-KEM-") || name.starts_with("ML-DSA-"));
178
+ bool isPqcKey = (name.starts_with("ML-KEM-") || name.starts_with("ML-DSA-") || name.starts_with("SLH-DSA-"));
146
179
  if (isPqcKey) {
147
180
  if (keyType == KeyType::PUBLIC) {
148
181
  auto rawData = pkey.rawPublicKey();
@@ -364,9 +397,267 @@ JWK HybridKeyObjectHandle::exportJwk(const JWK& key, bool handleRsaPss) {
364
397
  return result;
365
398
  }
366
399
 
400
+ #if OPENSSL_VERSION_NUMBER >= 0x30500000L
401
+ // Export AKP keys (ML-DSA, ML-KEM)
402
+ {
403
+ const char* typeName = EVP_PKEY_get0_type_name(pkey.get());
404
+ if (typeName != nullptr) {
405
+ std::string name(typeName);
406
+ bool isPqcKey = (name.starts_with("ML-DSA-") || name.starts_with("ML-KEM-") || name.starts_with("SLH-DSA-"));
407
+ if (isPqcKey) {
408
+ result.kty = JWKkty::AKP;
409
+ result.alg = name;
410
+
411
+ auto pubKey = pkey.rawPublicKey();
412
+ if (!pubKey) {
413
+ throw std::runtime_error("Failed to get raw public key for AKP JWK export");
414
+ }
415
+ result.pub = base64url_encode(reinterpret_cast<const unsigned char*>(pubKey.get()), pubKey.size());
416
+
417
+ if (keyType == KeyType::PRIVATE) {
418
+ auto seed = pkey.rawSeed();
419
+ if (!seed) {
420
+ throw std::runtime_error("Key does not have an available seed");
421
+ }
422
+ result.priv = base64url_encode(reinterpret_cast<const unsigned char*>(seed.get()), seed.size());
423
+ }
424
+
425
+ return result;
426
+ }
427
+ }
428
+ }
429
+ #endif
430
+
367
431
  throw std::runtime_error("Unsupported key type for JWK export");
368
432
  }
369
433
 
434
+ // Returns true if the EVP_PKEY type supports raw public key export
435
+ // (CFRG keys: Ed25519, Ed448, X25519, X448; PQC keys: ML-DSA, ML-KEM, SLH-DSA).
436
+ static bool supportsRawPublic(int keyId, const char* typeName) {
437
+ if (keyId == EVP_PKEY_ED25519 || keyId == EVP_PKEY_ED448 || keyId == EVP_PKEY_X25519 || keyId == EVP_PKEY_X448) {
438
+ return true;
439
+ }
440
+ #if OPENSSL_VERSION_NUMBER >= 0x30500000L
441
+ if (keyId == EVP_PKEY_ML_DSA_44 || keyId == EVP_PKEY_ML_DSA_65 || keyId == EVP_PKEY_ML_DSA_87) {
442
+ return true;
443
+ }
444
+ if (typeName != nullptr) {
445
+ std::string name(typeName);
446
+ if (name.starts_with("ML-KEM-") || name.starts_with("ML-DSA-") || name.starts_with("SLH-DSA-")) {
447
+ return true;
448
+ }
449
+ }
450
+ #else
451
+ (void)typeName;
452
+ #endif
453
+ return false;
454
+ }
455
+
456
+ // Returns true if the EVP_PKEY type supports raw private key export
457
+ // (CFRG keys: Ed25519, Ed448, X25519, X448; SLH-DSA private keys).
458
+ static bool supportsRawPrivate(int keyId, const char* typeName) {
459
+ if (keyId == EVP_PKEY_ED25519 || keyId == EVP_PKEY_ED448 || keyId == EVP_PKEY_X25519 || keyId == EVP_PKEY_X448) {
460
+ return true;
461
+ }
462
+ #if OPENSSL_VERSION_NUMBER >= 0x30500000L
463
+ if (typeName != nullptr) {
464
+ std::string name(typeName);
465
+ if (name.starts_with("SLH-DSA-")) {
466
+ return true;
467
+ }
468
+ }
469
+ #else
470
+ (void)typeName;
471
+ #endif
472
+ return false;
473
+ }
474
+
475
+ // Returns true if the EVP_PKEY type supports raw seed export
476
+ // (PQC keys: ML-DSA, ML-KEM, SLH-DSA).
477
+ static bool supportsRawSeed(int keyId, const char* typeName) {
478
+ #if OPENSSL_VERSION_NUMBER >= 0x30500000L
479
+ if (keyId == EVP_PKEY_ML_DSA_44 || keyId == EVP_PKEY_ML_DSA_65 || keyId == EVP_PKEY_ML_DSA_87) {
480
+ return true;
481
+ }
482
+ if (typeName != nullptr) {
483
+ std::string name(typeName);
484
+ if (name.starts_with("ML-KEM-") || name.starts_with("ML-DSA-") || name.starts_with("SLH-DSA-")) {
485
+ return true;
486
+ }
487
+ }
488
+ #else
489
+ (void)keyId;
490
+ (void)typeName;
491
+ #endif
492
+ return false;
493
+ }
494
+
495
+ std::shared_ptr<ArrayBuffer> HybridKeyObjectHandle::exportRawPublic() {
496
+ auto keyType = data_.GetKeyType();
497
+ if (keyType == KeyType::SECRET) {
498
+ throw std::runtime_error("Raw public key export is not supported for secret keys");
499
+ }
500
+
501
+ const auto& pkey = data_.GetAsymmetricKey();
502
+ if (!pkey) {
503
+ throw std::runtime_error("Invalid asymmetric key");
504
+ }
505
+
506
+ int keyId = EVP_PKEY_id(pkey.get());
507
+ const char* typeName = EVP_PKEY_get0_type_name(pkey.get());
508
+
509
+ if (!supportsRawPublic(keyId, typeName)) {
510
+ throw std::runtime_error("The key type does not support raw public key export");
511
+ }
512
+
513
+ auto rawData = pkey.rawPublicKey();
514
+ if (!rawData) {
515
+ throw std::runtime_error("Failed to get raw public key");
516
+ }
517
+ return ToNativeArrayBuffer(reinterpret_cast<const uint8_t*>(rawData.get()), rawData.size());
518
+ }
519
+
520
+ std::shared_ptr<ArrayBuffer> HybridKeyObjectHandle::exportRawPrivate() {
521
+ auto keyType = data_.GetKeyType();
522
+ if (keyType != KeyType::PRIVATE) {
523
+ throw std::runtime_error("Raw private key export requires a private key");
524
+ }
525
+
526
+ const auto& pkey = data_.GetAsymmetricKey();
527
+ if (!pkey) {
528
+ throw std::runtime_error("Invalid asymmetric key");
529
+ }
530
+
531
+ int keyId = EVP_PKEY_id(pkey.get());
532
+ const char* typeName = EVP_PKEY_get0_type_name(pkey.get());
533
+
534
+ if (!supportsRawPrivate(keyId, typeName)) {
535
+ throw std::runtime_error("The key type does not support raw private key export");
536
+ }
537
+
538
+ auto rawData = pkey.rawPrivateKey();
539
+ if (!rawData) {
540
+ throw std::runtime_error("Failed to get raw private key");
541
+ }
542
+ return ToNativeArrayBuffer(reinterpret_cast<const uint8_t*>(rawData.get()), rawData.size());
543
+ }
544
+
545
+ std::shared_ptr<ArrayBuffer> HybridKeyObjectHandle::exportRawSeed() {
546
+ #if OPENSSL_VERSION_NUMBER >= 0x30500000L
547
+ auto keyType = data_.GetKeyType();
548
+ if (keyType != KeyType::PRIVATE) {
549
+ throw std::runtime_error("Raw seed export requires a private key");
550
+ }
551
+
552
+ const auto& pkey = data_.GetAsymmetricKey();
553
+ if (!pkey) {
554
+ throw std::runtime_error("Invalid asymmetric key");
555
+ }
556
+
557
+ int keyId = EVP_PKEY_id(pkey.get());
558
+ const char* typeName = EVP_PKEY_get0_type_name(pkey.get());
559
+
560
+ if (!supportsRawSeed(keyId, typeName)) {
561
+ throw std::runtime_error("The key type does not support raw seed export");
562
+ }
563
+
564
+ auto rawData = pkey.rawSeed();
565
+ if (!rawData) {
566
+ throw std::runtime_error("Key does not have an available seed");
567
+ }
568
+ return ToNativeArrayBuffer(reinterpret_cast<const uint8_t*>(rawData.get()), rawData.size());
569
+ #else
570
+ throw std::runtime_error("Raw seed export requires OpenSSL 3.5+");
571
+ #endif
572
+ }
573
+
574
+ std::shared_ptr<ArrayBuffer> HybridKeyObjectHandle::exportECPublicRaw(bool compressed) {
575
+ auto keyType = data_.GetKeyType();
576
+ if (keyType == KeyType::SECRET) {
577
+ throw std::runtime_error("EC raw public key export is not supported for secret keys");
578
+ }
579
+
580
+ const auto& pkey = data_.GetAsymmetricKey();
581
+ if (!pkey) {
582
+ throw std::runtime_error("Invalid asymmetric key");
583
+ }
584
+
585
+ if (EVP_PKEY_id(pkey.get()) != EVP_PKEY_EC) {
586
+ throw std::runtime_error("Key is not an EC key");
587
+ }
588
+
589
+ const EC_KEY* ec_key = EVP_PKEY_get0_EC_KEY(pkey.get());
590
+ if (!ec_key) {
591
+ throw std::runtime_error("Failed to get EC key");
592
+ }
593
+
594
+ const EC_GROUP* group = EC_KEY_get0_group(ec_key);
595
+ const EC_POINT* point = EC_KEY_get0_public_key(ec_key);
596
+ if (!group || !point) {
597
+ throw std::runtime_error("Failed to get EC public key point");
598
+ }
599
+
600
+ point_conversion_form_t form = compressed ? POINT_CONVERSION_COMPRESSED : POINT_CONVERSION_UNCOMPRESSED;
601
+
602
+ size_t len = EC_POINT_point2oct(group, point, form, nullptr, 0, nullptr);
603
+ if (len == 0) {
604
+ throw std::runtime_error("Failed to compute EC point size");
605
+ }
606
+ std::vector<uint8_t> buf(len);
607
+ if (EC_POINT_point2oct(group, point, form, buf.data(), buf.size(), nullptr) != len) {
608
+ throw std::runtime_error("Failed to encode EC public key point");
609
+ }
610
+ return ToNativeArrayBuffer(buf.data(), buf.size());
611
+ }
612
+
613
+ std::shared_ptr<ArrayBuffer> HybridKeyObjectHandle::exportECPrivateRaw() {
614
+ auto keyType = data_.GetKeyType();
615
+ if (keyType != KeyType::PRIVATE) {
616
+ throw std::runtime_error("EC raw private key export requires a private key");
617
+ }
618
+
619
+ const auto& pkey = data_.GetAsymmetricKey();
620
+ if (!pkey) {
621
+ throw std::runtime_error("Invalid asymmetric key");
622
+ }
623
+
624
+ if (EVP_PKEY_id(pkey.get()) != EVP_PKEY_EC) {
625
+ throw std::runtime_error("Key is not an EC key");
626
+ }
627
+
628
+ const EC_KEY* ec_key = EVP_PKEY_get0_EC_KEY(pkey.get());
629
+ if (!ec_key) {
630
+ throw std::runtime_error("Failed to get EC key");
631
+ }
632
+
633
+ const BIGNUM* priv_bn = EC_KEY_get0_private_key(ec_key);
634
+ if (!priv_bn) {
635
+ throw std::runtime_error("EC key has no private component");
636
+ }
637
+
638
+ const EC_GROUP* group = EC_KEY_get0_group(ec_key);
639
+ if (!group) {
640
+ throw std::runtime_error("Failed to get EC group");
641
+ }
642
+
643
+ BIGNUM* order = BN_new();
644
+ if (!order) {
645
+ throw std::runtime_error("Failed to allocate BIGNUM");
646
+ }
647
+ if (EC_GROUP_get_order(group, order, nullptr) != 1) {
648
+ BN_free(order);
649
+ throw std::runtime_error("Failed to get EC group order");
650
+ }
651
+ size_t order_size = (BN_num_bits(order) + 7) / 8;
652
+ BN_free(order);
653
+
654
+ std::vector<uint8_t> buf(order_size, 0);
655
+ if (BN_bn2binpad(priv_bn, buf.data(), static_cast<int>(order_size)) < 0) {
656
+ throw std::runtime_error("Failed to encode EC private key");
657
+ }
658
+ return ToNativeArrayBuffer(buf.data(), buf.size());
659
+ }
660
+
370
661
  AsymmetricKeyType HybridKeyObjectHandle::getAsymmetricKeyType() {
371
662
  const auto& pkey = data_.GetAsymmetricKey();
372
663
  if (!pkey) {
@@ -407,7 +698,7 @@ AsymmetricKeyType HybridKeyObjectHandle::getAsymmetricKeyType() {
407
698
  }
408
699
 
409
700
  #if OPENSSL_VERSION_NUMBER >= 0x30500000L
410
- // EVP_PKEY_id returns -1 for provider-only key types (e.g. ML-KEM)
701
+ // EVP_PKEY_id returns -1 for provider-only key types (e.g. ML-KEM, SLH-DSA)
411
702
  // Fall back to string-based type name comparison
412
703
  const char* typeName = EVP_PKEY_get0_type_name(pkey.get());
413
704
  if (typeName != nullptr) {
@@ -418,6 +709,30 @@ AsymmetricKeyType HybridKeyObjectHandle::getAsymmetricKeyType() {
418
709
  return AsymmetricKeyType::ML_KEM_768;
419
710
  if (name == "ML-KEM-1024")
420
711
  return AsymmetricKeyType::ML_KEM_1024;
712
+ if (name == "SLH-DSA-SHA2-128s")
713
+ return AsymmetricKeyType::SLH_DSA_SHA2_128S;
714
+ if (name == "SLH-DSA-SHA2-128f")
715
+ return AsymmetricKeyType::SLH_DSA_SHA2_128F;
716
+ if (name == "SLH-DSA-SHA2-192s")
717
+ return AsymmetricKeyType::SLH_DSA_SHA2_192S;
718
+ if (name == "SLH-DSA-SHA2-192f")
719
+ return AsymmetricKeyType::SLH_DSA_SHA2_192F;
720
+ if (name == "SLH-DSA-SHA2-256s")
721
+ return AsymmetricKeyType::SLH_DSA_SHA2_256S;
722
+ if (name == "SLH-DSA-SHA2-256f")
723
+ return AsymmetricKeyType::SLH_DSA_SHA2_256F;
724
+ if (name == "SLH-DSA-SHAKE-128s")
725
+ return AsymmetricKeyType::SLH_DSA_SHAKE_128S;
726
+ if (name == "SLH-DSA-SHAKE-128f")
727
+ return AsymmetricKeyType::SLH_DSA_SHAKE_128F;
728
+ if (name == "SLH-DSA-SHAKE-192s")
729
+ return AsymmetricKeyType::SLH_DSA_SHAKE_192S;
730
+ if (name == "SLH-DSA-SHAKE-192f")
731
+ return AsymmetricKeyType::SLH_DSA_SHAKE_192F;
732
+ if (name == "SLH-DSA-SHAKE-256s")
733
+ return AsymmetricKeyType::SLH_DSA_SHAKE_256S;
734
+ if (name == "SLH-DSA-SHAKE-256f")
735
+ return AsymmetricKeyType::SLH_DSA_SHAKE_256F;
421
736
  }
422
737
  #endif
423
738
 
@@ -703,6 +1018,96 @@ std::optional<KeyType> HybridKeyObjectHandle::initJwk(const JWK& keyData, std::o
703
1018
  }
704
1019
  }
705
1020
 
1021
+ #if OPENSSL_VERSION_NUMBER >= 0x30500000L
1022
+ // Handle AKP keys (ML-DSA, ML-KEM)
1023
+ if (kty == JWKkty::AKP) {
1024
+ if (!keyData.alg.has_value()) {
1025
+ throw std::runtime_error("JWK AKP key missing 'alg' field");
1026
+ }
1027
+ if (!keyData.pub.has_value()) {
1028
+ throw std::runtime_error("JWK AKP key missing 'pub' field");
1029
+ }
1030
+
1031
+ const std::string& alg = keyData.alg.value();
1032
+ int nid = 0;
1033
+ if (alg == "ML-DSA-44")
1034
+ nid = EVP_PKEY_ML_DSA_44;
1035
+ else if (alg == "ML-DSA-65")
1036
+ nid = EVP_PKEY_ML_DSA_65;
1037
+ else if (alg == "ML-DSA-87")
1038
+ nid = EVP_PKEY_ML_DSA_87;
1039
+ else if (alg == "ML-KEM-512")
1040
+ nid = EVP_PKEY_ML_KEM_512;
1041
+ else if (alg == "ML-KEM-768")
1042
+ nid = EVP_PKEY_ML_KEM_768;
1043
+ else if (alg == "ML-KEM-1024")
1044
+ nid = EVP_PKEY_ML_KEM_1024;
1045
+ else if (alg == "SLH-DSA-SHA2-128s")
1046
+ nid = EVP_PKEY_SLH_DSA_SHA2_128S;
1047
+ else if (alg == "SLH-DSA-SHA2-128f")
1048
+ nid = EVP_PKEY_SLH_DSA_SHA2_128F;
1049
+ else if (alg == "SLH-DSA-SHA2-192s")
1050
+ nid = EVP_PKEY_SLH_DSA_SHA2_192S;
1051
+ else if (alg == "SLH-DSA-SHA2-192f")
1052
+ nid = EVP_PKEY_SLH_DSA_SHA2_192F;
1053
+ else if (alg == "SLH-DSA-SHA2-256s")
1054
+ nid = EVP_PKEY_SLH_DSA_SHA2_256S;
1055
+ else if (alg == "SLH-DSA-SHA2-256f")
1056
+ nid = EVP_PKEY_SLH_DSA_SHA2_256F;
1057
+ else if (alg == "SLH-DSA-SHAKE-128s")
1058
+ nid = EVP_PKEY_SLH_DSA_SHAKE_128S;
1059
+ else if (alg == "SLH-DSA-SHAKE-128f")
1060
+ nid = EVP_PKEY_SLH_DSA_SHAKE_128F;
1061
+ else if (alg == "SLH-DSA-SHAKE-192s")
1062
+ nid = EVP_PKEY_SLH_DSA_SHAKE_192S;
1063
+ else if (alg == "SLH-DSA-SHAKE-192f")
1064
+ nid = EVP_PKEY_SLH_DSA_SHAKE_192F;
1065
+ else if (alg == "SLH-DSA-SHAKE-256s")
1066
+ nid = EVP_PKEY_SLH_DSA_SHAKE_256S;
1067
+ else if (alg == "SLH-DSA-SHAKE-256f")
1068
+ nid = EVP_PKEY_SLH_DSA_SHAKE_256F;
1069
+ else
1070
+ throw std::runtime_error("Unsupported JWK AKP \"alg\": " + alg);
1071
+
1072
+ bool isPrivate = keyData.priv.has_value();
1073
+ ncrypto::EVPKeyPointer pkey;
1074
+
1075
+ if (isPrivate) {
1076
+ std::string seedBytes = base64url_decode(keyData.priv.value());
1077
+ ncrypto::Buffer<const unsigned char> buf{
1078
+ .data = reinterpret_cast<const unsigned char*>(seedBytes.data()),
1079
+ .len = seedBytes.size(),
1080
+ };
1081
+ pkey = ncrypto::EVPKeyPointer::NewRawSeed(nid, buf);
1082
+ if (!pkey) {
1083
+ throw std::runtime_error("Invalid JWK AKP key");
1084
+ }
1085
+
1086
+ // Verify the pub field matches the public key derived from the seed.
1087
+ std::string pubBytes = base64url_decode(keyData.pub.value());
1088
+ auto derivedPub = pkey.rawPublicKey();
1089
+ if (!derivedPub || derivedPub.size() != pubBytes.size() || CRYPTO_memcmp(derivedPub.get(), pubBytes.data(), pubBytes.size()) != 0) {
1090
+ throw std::runtime_error("Invalid JWK AKP key");
1091
+ }
1092
+
1093
+ data_ = KeyObjectData::CreateAsymmetric(KeyType::PRIVATE, std::move(pkey));
1094
+ return KeyType::PRIVATE;
1095
+ } else {
1096
+ std::string pubBytes = base64url_decode(keyData.pub.value());
1097
+ ncrypto::Buffer<const unsigned char> buf{
1098
+ .data = reinterpret_cast<const unsigned char*>(pubBytes.data()),
1099
+ .len = pubBytes.size(),
1100
+ };
1101
+ pkey = ncrypto::EVPKeyPointer::NewRawPublic(nid, buf);
1102
+ if (!pkey) {
1103
+ throw std::runtime_error("Invalid JWK AKP key");
1104
+ }
1105
+ data_ = KeyObjectData::CreateAsymmetric(KeyType::PUBLIC, std::move(pkey));
1106
+ return KeyType::PUBLIC;
1107
+ }
1108
+ }
1109
+ #endif
1110
+
706
1111
  throw std::runtime_error("Unsupported JWK key type");
707
1112
  }
708
1113
 
@@ -835,6 +1240,30 @@ bool HybridKeyObjectHandle::initPqcRaw(const std::string& algorithmName, const s
835
1240
  nid = EVP_PKEY_ML_DSA_65;
836
1241
  else if (algorithmName == "ML-DSA-87")
837
1242
  nid = EVP_PKEY_ML_DSA_87;
1243
+ else if (algorithmName == "SLH-DSA-SHA2-128s")
1244
+ nid = EVP_PKEY_SLH_DSA_SHA2_128S;
1245
+ else if (algorithmName == "SLH-DSA-SHA2-128f")
1246
+ nid = EVP_PKEY_SLH_DSA_SHA2_128F;
1247
+ else if (algorithmName == "SLH-DSA-SHA2-192s")
1248
+ nid = EVP_PKEY_SLH_DSA_SHA2_192S;
1249
+ else if (algorithmName == "SLH-DSA-SHA2-192f")
1250
+ nid = EVP_PKEY_SLH_DSA_SHA2_192F;
1251
+ else if (algorithmName == "SLH-DSA-SHA2-256s")
1252
+ nid = EVP_PKEY_SLH_DSA_SHA2_256S;
1253
+ else if (algorithmName == "SLH-DSA-SHA2-256f")
1254
+ nid = EVP_PKEY_SLH_DSA_SHA2_256F;
1255
+ else if (algorithmName == "SLH-DSA-SHAKE-128s")
1256
+ nid = EVP_PKEY_SLH_DSA_SHAKE_128S;
1257
+ else if (algorithmName == "SLH-DSA-SHAKE-128f")
1258
+ nid = EVP_PKEY_SLH_DSA_SHAKE_128F;
1259
+ else if (algorithmName == "SLH-DSA-SHAKE-192s")
1260
+ nid = EVP_PKEY_SLH_DSA_SHAKE_192S;
1261
+ else if (algorithmName == "SLH-DSA-SHAKE-192f")
1262
+ nid = EVP_PKEY_SLH_DSA_SHAKE_192F;
1263
+ else if (algorithmName == "SLH-DSA-SHAKE-256s")
1264
+ nid = EVP_PKEY_SLH_DSA_SHAKE_256S;
1265
+ else if (algorithmName == "SLH-DSA-SHAKE-256f")
1266
+ nid = EVP_PKEY_SLH_DSA_SHAKE_256F;
838
1267
  else
839
1268
  throw std::runtime_error("Unknown PQC algorithm: " + algorithmName);
840
1269
 
@@ -859,6 +1288,193 @@ bool HybridKeyObjectHandle::initPqcRaw(const std::string& algorithmName, const s
859
1288
  #endif
860
1289
  }
861
1290
 
1291
+ // Map a string asymmetricKeyType to an EVP_PKEY NID for OKP/PQC keys.
1292
+ // Returns 0 if the type is not a known OKP or PQC type.
1293
+ static int evpNidForAsymmetricKeyType(const std::string& asymmetricKeyType) {
1294
+ if (asymmetricKeyType == "ed25519")
1295
+ return EVP_PKEY_ED25519;
1296
+ if (asymmetricKeyType == "ed448")
1297
+ return EVP_PKEY_ED448;
1298
+ if (asymmetricKeyType == "x25519")
1299
+ return EVP_PKEY_X25519;
1300
+ if (asymmetricKeyType == "x448")
1301
+ return EVP_PKEY_X448;
1302
+ #if OPENSSL_VERSION_NUMBER >= 0x30500000L
1303
+ if (asymmetricKeyType == "ml-dsa-44")
1304
+ return EVP_PKEY_ML_DSA_44;
1305
+ if (asymmetricKeyType == "ml-dsa-65")
1306
+ return EVP_PKEY_ML_DSA_65;
1307
+ if (asymmetricKeyType == "ml-dsa-87")
1308
+ return EVP_PKEY_ML_DSA_87;
1309
+ if (asymmetricKeyType == "ml-kem-512")
1310
+ return EVP_PKEY_ML_KEM_512;
1311
+ if (asymmetricKeyType == "ml-kem-768")
1312
+ return EVP_PKEY_ML_KEM_768;
1313
+ if (asymmetricKeyType == "ml-kem-1024")
1314
+ return EVP_PKEY_ML_KEM_1024;
1315
+ if (asymmetricKeyType == "slh-dsa-sha2-128s")
1316
+ return EVP_PKEY_SLH_DSA_SHA2_128S;
1317
+ if (asymmetricKeyType == "slh-dsa-sha2-128f")
1318
+ return EVP_PKEY_SLH_DSA_SHA2_128F;
1319
+ if (asymmetricKeyType == "slh-dsa-sha2-192s")
1320
+ return EVP_PKEY_SLH_DSA_SHA2_192S;
1321
+ if (asymmetricKeyType == "slh-dsa-sha2-192f")
1322
+ return EVP_PKEY_SLH_DSA_SHA2_192F;
1323
+ if (asymmetricKeyType == "slh-dsa-sha2-256s")
1324
+ return EVP_PKEY_SLH_DSA_SHA2_256S;
1325
+ if (asymmetricKeyType == "slh-dsa-sha2-256f")
1326
+ return EVP_PKEY_SLH_DSA_SHA2_256F;
1327
+ if (asymmetricKeyType == "slh-dsa-shake-128s")
1328
+ return EVP_PKEY_SLH_DSA_SHAKE_128S;
1329
+ if (asymmetricKeyType == "slh-dsa-shake-128f")
1330
+ return EVP_PKEY_SLH_DSA_SHAKE_128F;
1331
+ if (asymmetricKeyType == "slh-dsa-shake-192s")
1332
+ return EVP_PKEY_SLH_DSA_SHAKE_192S;
1333
+ if (asymmetricKeyType == "slh-dsa-shake-192f")
1334
+ return EVP_PKEY_SLH_DSA_SHAKE_192F;
1335
+ if (asymmetricKeyType == "slh-dsa-shake-256s")
1336
+ return EVP_PKEY_SLH_DSA_SHAKE_256S;
1337
+ if (asymmetricKeyType == "slh-dsa-shake-256f")
1338
+ return EVP_PKEY_SLH_DSA_SHAKE_256F;
1339
+ #endif
1340
+ return 0;
1341
+ }
1342
+
1343
+ bool HybridKeyObjectHandle::initRawPublic(const std::string& asymmetricKeyType, const std::shared_ptr<ArrayBuffer>& keyData,
1344
+ const std::optional<std::string>& namedCurve) {
1345
+ data_ = KeyObjectData();
1346
+
1347
+ if (asymmetricKeyType == "ec") {
1348
+ if (!namedCurve.has_value()) {
1349
+ throw std::runtime_error("namedCurve is required for EC raw public key import");
1350
+ }
1351
+ return initECRaw(namedCurve.value(), keyData);
1352
+ }
1353
+
1354
+ int nid = evpNidForAsymmetricKeyType(asymmetricKeyType);
1355
+ if (nid == 0) {
1356
+ throw std::runtime_error("Invalid asymmetricKeyType for raw public key import: " + asymmetricKeyType);
1357
+ }
1358
+
1359
+ ncrypto::Buffer<const unsigned char> buffer{.data = reinterpret_cast<const unsigned char*>(keyData->data()), .len = keyData->size()};
1360
+ auto pkey = ncrypto::EVPKeyPointer::NewRawPublic(nid, buffer);
1361
+ if (!pkey) {
1362
+ throw std::runtime_error("Failed to create raw public key");
1363
+ }
1364
+ this->data_ = KeyObjectData::CreateAsymmetric(KeyType::PUBLIC, std::move(pkey));
1365
+ return true;
1366
+ }
1367
+
1368
+ bool HybridKeyObjectHandle::initRawPrivate(const std::string& asymmetricKeyType, const std::shared_ptr<ArrayBuffer>& keyData,
1369
+ const std::optional<std::string>& namedCurve) {
1370
+ data_ = KeyObjectData();
1371
+
1372
+ if (asymmetricKeyType == "ec") {
1373
+ if (!namedCurve.has_value()) {
1374
+ throw std::runtime_error("namedCurve is required for EC raw private key import");
1375
+ }
1376
+
1377
+ int nid = 0;
1378
+ const std::string& curve = namedCurve.value();
1379
+ if (curve == "prime256v1" || curve == "P-256")
1380
+ nid = NID_X9_62_prime256v1;
1381
+ else if (curve == "secp384r1" || curve == "P-384")
1382
+ nid = NID_secp384r1;
1383
+ else if (curve == "secp521r1" || curve == "P-521")
1384
+ nid = NID_secp521r1;
1385
+ else if (curve == "secp256k1")
1386
+ nid = NID_secp256k1;
1387
+ else
1388
+ nid = OBJ_txt2nid(curve.c_str());
1389
+
1390
+ if (nid == 0) {
1391
+ throw std::runtime_error("Unknown curve: " + curve);
1392
+ }
1393
+
1394
+ auto ec_key = std::unique_ptr<EC_KEY, decltype(&EC_KEY_free)>(EC_KEY_new_by_curve_name(nid), EC_KEY_free);
1395
+ if (!ec_key) {
1396
+ throw std::runtime_error("Failed to create EC_KEY");
1397
+ }
1398
+ const EC_GROUP* group = EC_KEY_get0_group(ec_key.get());
1399
+
1400
+ BIGNUM* order = BN_new();
1401
+ if (!order || EC_GROUP_get_order(group, order, nullptr) != 1) {
1402
+ if (order)
1403
+ BN_free(order);
1404
+ throw std::runtime_error("Failed to get EC group order");
1405
+ }
1406
+ size_t order_size = (BN_num_bits(order) + 7) / 8;
1407
+ BN_free(order);
1408
+
1409
+ if (keyData->size() != order_size) {
1410
+ throw std::runtime_error("Invalid EC private key length");
1411
+ }
1412
+
1413
+ BIGNUM* priv_bn = BN_bin2bn(reinterpret_cast<const unsigned char*>(keyData->data()), static_cast<int>(keyData->size()), nullptr);
1414
+ if (!priv_bn) {
1415
+ throw std::runtime_error("Failed to decode EC private key");
1416
+ }
1417
+
1418
+ if (EC_KEY_set_private_key(ec_key.get(), priv_bn) != 1) {
1419
+ BN_free(priv_bn);
1420
+ throw std::runtime_error("Failed to set EC private key");
1421
+ }
1422
+
1423
+ auto pub_point = std::unique_ptr<EC_POINT, decltype(&EC_POINT_free)>(EC_POINT_new(group), EC_POINT_free);
1424
+ if (!pub_point || EC_POINT_mul(group, pub_point.get(), priv_bn, nullptr, nullptr, nullptr) != 1 ||
1425
+ EC_KEY_set_public_key(ec_key.get(), pub_point.get()) != 1) {
1426
+ BN_free(priv_bn);
1427
+ throw std::runtime_error("Failed to derive EC public key");
1428
+ }
1429
+ BN_free(priv_bn);
1430
+
1431
+ EVP_PKEY* pkey = EVP_PKEY_new();
1432
+ if (!pkey || EVP_PKEY_assign_EC_KEY(pkey, ec_key.get()) != 1) {
1433
+ if (pkey)
1434
+ EVP_PKEY_free(pkey);
1435
+ throw std::runtime_error("Failed to create EVP_PKEY from EC_KEY");
1436
+ }
1437
+ ec_key.release();
1438
+
1439
+ this->data_ = KeyObjectData::CreateAsymmetric(KeyType::PRIVATE, ncrypto::EVPKeyPointer(pkey));
1440
+ return true;
1441
+ }
1442
+
1443
+ int nid = evpNidForAsymmetricKeyType(asymmetricKeyType);
1444
+ if (nid == 0) {
1445
+ throw std::runtime_error("Invalid asymmetricKeyType for raw private key import: " + asymmetricKeyType);
1446
+ }
1447
+
1448
+ ncrypto::Buffer<const unsigned char> buffer{.data = reinterpret_cast<const unsigned char*>(keyData->data()), .len = keyData->size()};
1449
+ auto pkey = ncrypto::EVPKeyPointer::NewRawPrivate(nid, buffer);
1450
+ if (!pkey) {
1451
+ throw std::runtime_error("Failed to create raw private key");
1452
+ }
1453
+ this->data_ = KeyObjectData::CreateAsymmetric(KeyType::PRIVATE, std::move(pkey));
1454
+ return true;
1455
+ }
1456
+
1457
+ bool HybridKeyObjectHandle::initRawSeed(const std::string& asymmetricKeyType, const std::shared_ptr<ArrayBuffer>& keyData) {
1458
+ #if OPENSSL_VERSION_NUMBER >= 0x30500000L
1459
+ data_ = KeyObjectData();
1460
+
1461
+ int nid = evpNidForAsymmetricKeyType(asymmetricKeyType);
1462
+ if (nid == 0) {
1463
+ throw std::runtime_error("Invalid asymmetricKeyType for raw seed import: " + asymmetricKeyType);
1464
+ }
1465
+
1466
+ ncrypto::Buffer<const unsigned char> buffer{.data = reinterpret_cast<const unsigned char*>(keyData->data()), .len = keyData->size()};
1467
+ auto pkey = ncrypto::EVPKeyPointer::NewRawSeed(nid, buffer);
1468
+ if (!pkey) {
1469
+ throw std::runtime_error("Failed to create key from raw seed");
1470
+ }
1471
+ this->data_ = KeyObjectData::CreateAsymmetric(KeyType::PRIVATE, std::move(pkey));
1472
+ return true;
1473
+ #else
1474
+ throw std::runtime_error("Raw seed import requires OpenSSL 3.5+");
1475
+ #endif
1476
+ }
1477
+
862
1478
  bool HybridKeyObjectHandle::keyEquals(const std::shared_ptr<HybridKeyObjectHandleSpec>& other) {
863
1479
  auto otherHandle = std::dynamic_pointer_cast<HybridKeyObjectHandle>(other);
864
1480
  if (!otherHandle)
@@ -887,4 +1503,16 @@ double HybridKeyObjectHandle::getSymmetricKeySize() {
887
1503
  return static_cast<double>(data_.GetSymmetricKeySize());
888
1504
  }
889
1505
 
1506
+ bool HybridKeyObjectHandle::checkEcKeyData() {
1507
+ const auto& pkey = data_.GetAsymmetricKey();
1508
+ if (!pkey || EVP_PKEY_id(pkey.get()) != EVP_PKEY_EC) {
1509
+ return false;
1510
+ }
1511
+ auto ctx = pkey.newCtx();
1512
+ if (!ctx) {
1513
+ return false;
1514
+ }
1515
+ return data_.GetKeyType() == KeyType::PRIVATE ? ctx.privateCheck() : ctx.publicCheck();
1516
+ }
1517
+
890
1518
  } // namespace margelo::nitro::crypto