react-native-quick-crypto 1.0.0-beta.2 → 1.0.0-beta.21

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 (462) hide show
  1. package/QuickCrypto.podspec +143 -7
  2. package/README.md +12 -6
  3. package/android/CMakeLists.txt +82 -21
  4. package/android/build.gradle +47 -4
  5. package/android/src/main/cpp/cpp-adapter.cpp +3 -10
  6. package/android/src/main/java/com/margelo/nitro/quickcrypto/QuickCryptoPackage.java +13 -10
  7. package/app.plugin.js +3 -0
  8. package/cpp/blake3/HybridBlake3.cpp +118 -0
  9. package/cpp/blake3/HybridBlake3.hpp +35 -0
  10. package/cpp/cipher/CCMCipher.cpp +199 -0
  11. package/cpp/cipher/CCMCipher.hpp +26 -0
  12. package/cpp/cipher/ChaCha20Cipher.cpp +97 -0
  13. package/cpp/cipher/ChaCha20Cipher.hpp +25 -0
  14. package/cpp/cipher/ChaCha20Poly1305Cipher.cpp +170 -0
  15. package/cpp/cipher/ChaCha20Poly1305Cipher.hpp +30 -0
  16. package/cpp/cipher/HybridCipher.cpp +322 -0
  17. package/cpp/cipher/HybridCipher.hpp +68 -0
  18. package/cpp/cipher/HybridCipherFactory.hpp +97 -0
  19. package/cpp/cipher/OCBCipher.cpp +55 -0
  20. package/cpp/cipher/OCBCipher.hpp +19 -0
  21. package/cpp/cipher/XSalsa20Cipher.cpp +61 -0
  22. package/cpp/cipher/XSalsa20Cipher.hpp +33 -0
  23. package/cpp/ec/HybridEcKeyPair.cpp +428 -0
  24. package/cpp/ec/HybridEcKeyPair.hpp +48 -0
  25. package/cpp/ed25519/HybridEdKeyPair.cpp +300 -0
  26. package/cpp/ed25519/HybridEdKeyPair.hpp +63 -0
  27. package/cpp/hash/HybridHash.cpp +185 -0
  28. package/cpp/hash/HybridHash.hpp +43 -0
  29. package/cpp/hmac/HybridHmac.cpp +95 -0
  30. package/cpp/hmac/HybridHmac.hpp +31 -0
  31. package/cpp/keys/HybridKeyObjectHandle.cpp +243 -0
  32. package/cpp/keys/HybridKeyObjectHandle.hpp +42 -0
  33. package/cpp/keys/KeyObjectData.cpp +226 -0
  34. package/cpp/keys/KeyObjectData.hpp +71 -0
  35. package/cpp/keys/node.h +5 -0
  36. package/cpp/pbkdf2/HybridPbkdf2.cpp +51 -0
  37. package/cpp/pbkdf2/HybridPbkdf2.hpp +24 -0
  38. package/cpp/random/HybridRandom.cpp +32 -18
  39. package/cpp/random/HybridRandom.hpp +18 -30
  40. package/cpp/rsa/HybridRsaKeyPair.cpp +154 -0
  41. package/cpp/rsa/HybridRsaKeyPair.hpp +43 -0
  42. package/cpp/utils/Macros.hpp +68 -0
  43. package/cpp/utils/Utils.hpp +53 -1
  44. package/deps/blake3/.cargo/config.toml +2 -0
  45. package/deps/blake3/.git-blame-ignore-revs +2 -0
  46. package/deps/blake3/.github/workflows/build_b3sum.py +38 -0
  47. package/deps/blake3/.github/workflows/ci.yml +491 -0
  48. package/deps/blake3/.github/workflows/tag.yml +43 -0
  49. package/deps/blake3/.github/workflows/upload_github_release_asset.py +73 -0
  50. package/deps/blake3/CONTRIBUTING.md +31 -0
  51. package/deps/blake3/Cargo.toml +135 -0
  52. package/deps/blake3/LICENSE_A2 +202 -0
  53. package/deps/blake3/LICENSE_A2LLVM +219 -0
  54. package/deps/blake3/LICENSE_CC0 +121 -0
  55. package/deps/blake3/README.md +229 -0
  56. package/deps/blake3/b3sum/Cargo.lock +513 -0
  57. package/deps/blake3/b3sum/Cargo.toml +26 -0
  58. package/deps/blake3/b3sum/README.md +72 -0
  59. package/deps/blake3/b3sum/src/main.rs +564 -0
  60. package/deps/blake3/b3sum/src/unit_tests.rs +235 -0
  61. package/deps/blake3/b3sum/tests/cli_tests.rs +680 -0
  62. package/deps/blake3/b3sum/what_does_check_do.md +176 -0
  63. package/deps/blake3/benches/bench.rs +623 -0
  64. package/deps/blake3/build.rs +389 -0
  65. package/deps/blake3/c/CMakeLists.txt +383 -0
  66. package/deps/blake3/c/CMakePresets.json +73 -0
  67. package/deps/blake3/c/Makefile.testing +82 -0
  68. package/deps/blake3/c/README.md +403 -0
  69. package/deps/blake3/c/blake3-config.cmake.in +14 -0
  70. package/deps/blake3/c/blake3.c +650 -0
  71. package/deps/blake3/c/blake3.h +86 -0
  72. package/deps/blake3/c/blake3_avx2.c +326 -0
  73. package/deps/blake3/c/blake3_avx2_x86-64_unix.S +1815 -0
  74. package/deps/blake3/c/blake3_avx2_x86-64_windows_gnu.S +1817 -0
  75. package/deps/blake3/c/blake3_avx2_x86-64_windows_msvc.asm +1828 -0
  76. package/deps/blake3/c/blake3_avx512.c +1388 -0
  77. package/deps/blake3/c/blake3_avx512_x86-64_unix.S +4824 -0
  78. package/deps/blake3/c/blake3_avx512_x86-64_windows_gnu.S +2615 -0
  79. package/deps/blake3/c/blake3_avx512_x86-64_windows_msvc.asm +2634 -0
  80. package/deps/blake3/c/blake3_c_rust_bindings/Cargo.toml +32 -0
  81. package/deps/blake3/c/blake3_c_rust_bindings/README.md +4 -0
  82. package/deps/blake3/c/blake3_c_rust_bindings/benches/bench.rs +477 -0
  83. package/deps/blake3/c/blake3_c_rust_bindings/build.rs +253 -0
  84. package/deps/blake3/c/blake3_c_rust_bindings/cross_test.sh +31 -0
  85. package/deps/blake3/c/blake3_c_rust_bindings/src/lib.rs +333 -0
  86. package/deps/blake3/c/blake3_c_rust_bindings/src/test.rs +696 -0
  87. package/deps/blake3/c/blake3_dispatch.c +332 -0
  88. package/deps/blake3/c/blake3_impl.h +333 -0
  89. package/deps/blake3/c/blake3_neon.c +366 -0
  90. package/deps/blake3/c/blake3_portable.c +160 -0
  91. package/deps/blake3/c/blake3_sse2.c +566 -0
  92. package/deps/blake3/c/blake3_sse2_x86-64_unix.S +2291 -0
  93. package/deps/blake3/c/blake3_sse2_x86-64_windows_gnu.S +2332 -0
  94. package/deps/blake3/c/blake3_sse2_x86-64_windows_msvc.asm +2350 -0
  95. package/deps/blake3/c/blake3_sse41.c +560 -0
  96. package/deps/blake3/c/blake3_sse41_x86-64_unix.S +2028 -0
  97. package/deps/blake3/c/blake3_sse41_x86-64_windows_gnu.S +2069 -0
  98. package/deps/blake3/c/blake3_sse41_x86-64_windows_msvc.asm +2089 -0
  99. package/deps/blake3/c/blake3_tbb.cpp +37 -0
  100. package/deps/blake3/c/dependencies/CMakeLists.txt +3 -0
  101. package/deps/blake3/c/dependencies/tbb/CMakeLists.txt +28 -0
  102. package/deps/blake3/c/example.c +36 -0
  103. package/deps/blake3/c/example_tbb.c +57 -0
  104. package/deps/blake3/c/libblake3.pc.in +12 -0
  105. package/deps/blake3/c/main.c +166 -0
  106. package/deps/blake3/c/test.py +97 -0
  107. package/deps/blake3/media/B3.svg +70 -0
  108. package/deps/blake3/media/BLAKE3.svg +85 -0
  109. package/deps/blake3/media/speed.svg +1474 -0
  110. package/deps/blake3/reference_impl/Cargo.toml +8 -0
  111. package/deps/blake3/reference_impl/README.md +14 -0
  112. package/deps/blake3/reference_impl/reference_impl.rs +374 -0
  113. package/deps/blake3/src/ffi_avx2.rs +65 -0
  114. package/deps/blake3/src/ffi_avx512.rs +169 -0
  115. package/deps/blake3/src/ffi_neon.rs +82 -0
  116. package/deps/blake3/src/ffi_sse2.rs +126 -0
  117. package/deps/blake3/src/ffi_sse41.rs +126 -0
  118. package/deps/blake3/src/guts.rs +60 -0
  119. package/deps/blake3/src/hazmat.rs +704 -0
  120. package/deps/blake3/src/io.rs +64 -0
  121. package/deps/blake3/src/join.rs +92 -0
  122. package/deps/blake3/src/lib.rs +1835 -0
  123. package/deps/blake3/src/platform.rs +587 -0
  124. package/deps/blake3/src/portable.rs +198 -0
  125. package/deps/blake3/src/rust_avx2.rs +474 -0
  126. package/deps/blake3/src/rust_sse2.rs +775 -0
  127. package/deps/blake3/src/rust_sse41.rs +766 -0
  128. package/deps/blake3/src/test.rs +1049 -0
  129. package/deps/blake3/src/traits.rs +227 -0
  130. package/deps/blake3/src/wasm32_simd.rs +794 -0
  131. package/deps/blake3/test_vectors/Cargo.toml +19 -0
  132. package/deps/blake3/test_vectors/cross_test.sh +25 -0
  133. package/deps/blake3/test_vectors/src/bin/generate.rs +4 -0
  134. package/deps/blake3/test_vectors/src/lib.rs +350 -0
  135. package/deps/blake3/test_vectors/test_vectors.json +217 -0
  136. package/deps/blake3/tools/compiler_version/Cargo.toml +7 -0
  137. package/deps/blake3/tools/compiler_version/build.rs +6 -0
  138. package/deps/blake3/tools/compiler_version/src/main.rs +27 -0
  139. package/deps/blake3/tools/instruction_set_support/Cargo.toml +6 -0
  140. package/deps/blake3/tools/instruction_set_support/src/main.rs +10 -0
  141. package/deps/blake3/tools/release.md +16 -0
  142. package/deps/fastpbkdf2/fastpbkdf2.c +356 -0
  143. package/deps/fastpbkdf2/fastpbkdf2.h +68 -0
  144. package/deps/ncrypto/ncrypto.cc +4679 -0
  145. package/deps/ncrypto/ncrypto.h +1625 -0
  146. package/lib/commonjs/blake3.js +98 -0
  147. package/lib/commonjs/blake3.js.map +1 -0
  148. package/lib/commonjs/cipher.js +180 -0
  149. package/lib/commonjs/cipher.js.map +1 -0
  150. package/lib/commonjs/ec.js +344 -0
  151. package/lib/commonjs/ec.js.map +1 -0
  152. package/lib/commonjs/ed.js +185 -0
  153. package/lib/commonjs/ed.js.map +1 -0
  154. package/lib/commonjs/expo-plugin/@types.js +2 -0
  155. package/lib/commonjs/expo-plugin/@types.js.map +1 -0
  156. package/lib/commonjs/expo-plugin/withRNQC.js +25 -0
  157. package/lib/commonjs/expo-plugin/withRNQC.js.map +1 -0
  158. package/lib/commonjs/expo-plugin/withSodiumAndroid.js +25 -0
  159. package/lib/commonjs/expo-plugin/withSodiumAndroid.js.map +1 -0
  160. package/lib/commonjs/expo-plugin/withSodiumIos.js +26 -0
  161. package/lib/commonjs/expo-plugin/withSodiumIos.js.map +1 -0
  162. package/lib/commonjs/expo-plugin/withXCode.js +51 -0
  163. package/lib/commonjs/expo-plugin/withXCode.js.map +1 -0
  164. package/lib/commonjs/hash.js +215 -0
  165. package/lib/commonjs/hash.js.map +1 -0
  166. package/lib/commonjs/hmac.js +109 -0
  167. package/lib/commonjs/hmac.js.map +1 -0
  168. package/lib/commonjs/index.js +152 -32
  169. package/lib/commonjs/index.js.map +1 -1
  170. package/lib/commonjs/keys/classes.js +250 -0
  171. package/lib/commonjs/keys/classes.js.map +1 -0
  172. package/lib/commonjs/keys/generateKeyPair.js +102 -0
  173. package/lib/commonjs/keys/generateKeyPair.js.map +1 -0
  174. package/lib/commonjs/keys/index.js +89 -0
  175. package/lib/commonjs/keys/index.js.map +1 -0
  176. package/lib/commonjs/keys/signVerify.js +41 -0
  177. package/lib/commonjs/keys/signVerify.js.map +1 -0
  178. package/lib/commonjs/keys/utils.js +123 -0
  179. package/lib/commonjs/keys/utils.js.map +1 -0
  180. package/lib/commonjs/pbkdf2.js +89 -0
  181. package/lib/commonjs/pbkdf2.js.map +1 -0
  182. package/lib/commonjs/random.js +9 -3
  183. package/lib/commonjs/random.js.map +1 -1
  184. package/lib/commonjs/rsa.js +129 -0
  185. package/lib/commonjs/rsa.js.map +1 -0
  186. package/lib/commonjs/specs/blake3.nitro.js +6 -0
  187. package/lib/commonjs/specs/blake3.nitro.js.map +1 -0
  188. package/lib/commonjs/specs/cipher.nitro.js +6 -0
  189. package/lib/commonjs/specs/cipher.nitro.js.map +1 -0
  190. package/lib/commonjs/specs/ecKeyPair.nitro.js +6 -0
  191. package/lib/commonjs/specs/ecKeyPair.nitro.js.map +1 -0
  192. package/lib/commonjs/specs/edKeyPair.nitro.js +6 -0
  193. package/lib/commonjs/specs/edKeyPair.nitro.js.map +1 -0
  194. package/lib/commonjs/specs/hash.nitro.js +6 -0
  195. package/lib/commonjs/specs/hash.nitro.js.map +1 -0
  196. package/lib/commonjs/specs/hmac.nitro.js +6 -0
  197. package/lib/commonjs/specs/hmac.nitro.js.map +1 -0
  198. package/lib/commonjs/specs/keyObjectHandle.nitro.js +6 -0
  199. package/lib/commonjs/specs/keyObjectHandle.nitro.js.map +1 -0
  200. package/lib/commonjs/specs/pbkdf2.nitro.js +6 -0
  201. package/lib/commonjs/specs/pbkdf2.nitro.js.map +1 -0
  202. package/lib/commonjs/specs/rsaKeyPair.nitro.js +6 -0
  203. package/lib/commonjs/specs/rsaKeyPair.nitro.js.map +1 -0
  204. package/lib/commonjs/subtle.js +365 -0
  205. package/lib/commonjs/subtle.js.map +1 -0
  206. package/lib/commonjs/utils/cipher.js +64 -0
  207. package/lib/commonjs/utils/cipher.js.map +1 -0
  208. package/lib/commonjs/utils/conversion.js +140 -6
  209. package/lib/commonjs/utils/conversion.js.map +1 -1
  210. package/lib/commonjs/utils/errors.js +14 -0
  211. package/lib/commonjs/utils/errors.js.map +1 -0
  212. package/lib/commonjs/utils/hashnames.js +91 -0
  213. package/lib/commonjs/utils/hashnames.js.map +1 -0
  214. package/lib/commonjs/utils/index.js +65 -5
  215. package/lib/commonjs/utils/index.js.map +1 -1
  216. package/lib/commonjs/utils/noble.js +82 -0
  217. package/lib/commonjs/utils/noble.js.map +1 -0
  218. package/lib/commonjs/utils/types.js +52 -0
  219. package/lib/commonjs/utils/types.js.map +1 -1
  220. package/lib/commonjs/utils/validation.js +98 -0
  221. package/lib/commonjs/utils/validation.js.map +1 -0
  222. package/lib/module/blake3.js +90 -0
  223. package/lib/module/blake3.js.map +1 -0
  224. package/lib/module/cipher.js +173 -0
  225. package/lib/module/cipher.js.map +1 -0
  226. package/lib/module/ec.js +336 -0
  227. package/lib/module/ec.js.map +1 -0
  228. package/lib/module/ed.js +178 -0
  229. package/lib/module/ed.js.map +1 -0
  230. package/lib/module/expo-plugin/@types.js +2 -0
  231. package/lib/module/expo-plugin/@types.js.map +1 -0
  232. package/lib/module/expo-plugin/withRNQC.js +21 -0
  233. package/lib/module/expo-plugin/withRNQC.js.map +1 -0
  234. package/lib/module/expo-plugin/withSodiumAndroid.js +20 -0
  235. package/lib/module/expo-plugin/withSodiumAndroid.js.map +1 -0
  236. package/lib/module/expo-plugin/withSodiumIos.js +20 -0
  237. package/lib/module/expo-plugin/withSodiumIos.js.map +1 -0
  238. package/lib/module/expo-plugin/withXCode.js +46 -0
  239. package/lib/module/expo-plugin/withXCode.js.map +1 -0
  240. package/lib/module/hash.js +207 -0
  241. package/lib/module/hash.js.map +1 -0
  242. package/lib/module/hmac.js +104 -0
  243. package/lib/module/hmac.js.map +1 -0
  244. package/lib/module/index.js +33 -29
  245. package/lib/module/index.js.map +1 -1
  246. package/lib/module/keys/classes.js +241 -0
  247. package/lib/module/keys/classes.js.map +1 -0
  248. package/lib/module/keys/generateKeyPair.js +96 -0
  249. package/lib/module/keys/generateKeyPair.js.map +1 -0
  250. package/lib/module/keys/index.js +32 -0
  251. package/lib/module/keys/index.js.map +1 -0
  252. package/lib/module/keys/signVerify.js +41 -0
  253. package/lib/module/keys/signVerify.js.map +1 -0
  254. package/lib/module/keys/utils.js +114 -0
  255. package/lib/module/keys/utils.js.map +1 -0
  256. package/lib/module/pbkdf2.js +83 -0
  257. package/lib/module/pbkdf2.js.map +1 -0
  258. package/lib/module/random.js +7 -1
  259. package/lib/module/random.js.map +1 -1
  260. package/lib/module/rsa.js +123 -0
  261. package/lib/module/rsa.js.map +1 -0
  262. package/lib/module/specs/blake3.nitro.js +4 -0
  263. package/lib/module/specs/blake3.nitro.js.map +1 -0
  264. package/lib/module/specs/cipher.nitro.js +4 -0
  265. package/lib/module/specs/cipher.nitro.js.map +1 -0
  266. package/lib/module/specs/ecKeyPair.nitro.js +4 -0
  267. package/lib/module/specs/ecKeyPair.nitro.js.map +1 -0
  268. package/lib/module/specs/edKeyPair.nitro.js +4 -0
  269. package/lib/module/specs/edKeyPair.nitro.js.map +1 -0
  270. package/lib/module/specs/hash.nitro.js +4 -0
  271. package/lib/module/specs/hash.nitro.js.map +1 -0
  272. package/lib/module/specs/hmac.nitro.js +4 -0
  273. package/lib/module/specs/hmac.nitro.js.map +1 -0
  274. package/lib/module/specs/keyObjectHandle.nitro.js +4 -0
  275. package/lib/module/specs/keyObjectHandle.nitro.js.map +1 -0
  276. package/lib/module/specs/pbkdf2.nitro.js +4 -0
  277. package/lib/module/specs/pbkdf2.nitro.js.map +1 -0
  278. package/lib/module/specs/rsaKeyPair.nitro.js +4 -0
  279. package/lib/module/specs/rsaKeyPair.nitro.js.map +1 -0
  280. package/lib/module/subtle.js +360 -0
  281. package/lib/module/subtle.js.map +1 -0
  282. package/lib/module/utils/cipher.js +56 -0
  283. package/lib/module/utils/cipher.js.map +1 -0
  284. package/lib/module/utils/conversion.js +120 -8
  285. package/lib/module/utils/conversion.js.map +1 -1
  286. package/lib/module/utils/errors.js +10 -0
  287. package/lib/module/utils/errors.js.map +1 -0
  288. package/lib/module/utils/hashnames.js +89 -0
  289. package/lib/module/utils/hashnames.js.map +1 -0
  290. package/lib/module/utils/index.js +6 -5
  291. package/lib/module/utils/index.js.map +1 -1
  292. package/lib/module/utils/noble.js +76 -0
  293. package/lib/module/utils/noble.js.map +1 -0
  294. package/lib/module/utils/types.js +53 -0
  295. package/lib/module/utils/types.js.map +1 -1
  296. package/lib/module/utils/validation.js +87 -0
  297. package/lib/module/utils/validation.js.map +1 -0
  298. package/lib/tsconfig.tsbuildinfo +1 -1
  299. package/lib/typescript/blake3.d.ts +33 -0
  300. package/lib/typescript/blake3.d.ts.map +1 -0
  301. package/lib/typescript/cipher.d.ts +60 -0
  302. package/lib/typescript/cipher.d.ts.map +1 -0
  303. package/lib/typescript/ec.d.ts +13 -0
  304. package/lib/typescript/ec.d.ts.map +1 -0
  305. package/lib/typescript/ed.d.ts +43 -0
  306. package/lib/typescript/ed.d.ts.map +1 -0
  307. package/lib/typescript/expo-plugin/@types.d.ts +8 -0
  308. package/lib/typescript/expo-plugin/@types.d.ts.map +1 -0
  309. package/lib/typescript/expo-plugin/withRNQC.d.ts +4 -0
  310. package/lib/typescript/expo-plugin/withRNQC.d.ts.map +1 -0
  311. package/lib/typescript/expo-plugin/withSodiumAndroid.d.ts +4 -0
  312. package/lib/typescript/expo-plugin/withSodiumAndroid.d.ts.map +1 -0
  313. package/lib/typescript/expo-plugin/withSodiumIos.d.ts +4 -0
  314. package/lib/typescript/expo-plugin/withSodiumIos.d.ts.map +1 -0
  315. package/lib/typescript/expo-plugin/withXCode.d.ts +9 -0
  316. package/lib/typescript/expo-plugin/withXCode.d.ts.map +1 -0
  317. package/lib/typescript/hash.d.ts +122 -0
  318. package/lib/typescript/hash.d.ts.map +1 -0
  319. package/lib/typescript/hmac.d.ts +66 -0
  320. package/lib/typescript/hmac.d.ts.map +1 -0
  321. package/lib/typescript/index.d.ts +110 -9
  322. package/lib/typescript/index.d.ts.map +1 -1
  323. package/lib/typescript/keys/classes.d.ts +79 -0
  324. package/lib/typescript/keys/classes.d.ts.map +1 -0
  325. package/lib/typescript/keys/generateKeyPair.d.ts +6 -0
  326. package/lib/typescript/keys/generateKeyPair.d.ts.map +1 -0
  327. package/lib/typescript/keys/index.d.ts +7 -0
  328. package/lib/typescript/keys/index.d.ts.map +1 -0
  329. package/lib/typescript/keys/signVerify.d.ts +1 -0
  330. package/lib/typescript/keys/signVerify.d.ts.map +1 -0
  331. package/lib/typescript/keys/utils.d.ts +34 -0
  332. package/lib/typescript/keys/utils.d.ts.map +1 -0
  333. package/lib/typescript/pbkdf2.d.ts +12 -0
  334. package/lib/typescript/pbkdf2.d.ts.map +1 -0
  335. package/lib/typescript/random.d.ts +11 -5
  336. package/lib/typescript/random.d.ts.map +1 -1
  337. package/lib/typescript/rsa.d.ts +10 -0
  338. package/lib/typescript/rsa.d.ts.map +1 -0
  339. package/lib/typescript/specs/blake3.nitro.d.ts +15 -0
  340. package/lib/typescript/specs/blake3.nitro.d.ts.map +1 -0
  341. package/lib/typescript/specs/cipher.nitro.d.ts +29 -0
  342. package/lib/typescript/specs/cipher.nitro.d.ts.map +1 -0
  343. package/lib/typescript/specs/ecKeyPair.nitro.d.ts +20 -0
  344. package/lib/typescript/specs/ecKeyPair.nitro.d.ts.map +1 -0
  345. package/lib/typescript/specs/edKeyPair.nitro.d.ts +17 -0
  346. package/lib/typescript/specs/edKeyPair.nitro.d.ts.map +1 -0
  347. package/lib/typescript/specs/hash.nitro.d.ts +13 -0
  348. package/lib/typescript/specs/hash.nitro.d.ts.map +1 -0
  349. package/lib/typescript/specs/hmac.nitro.d.ts +10 -0
  350. package/lib/typescript/specs/hmac.nitro.d.ts.map +1 -0
  351. package/lib/typescript/specs/keyObjectHandle.nitro.d.ts +14 -0
  352. package/lib/typescript/specs/keyObjectHandle.nitro.d.ts.map +1 -0
  353. package/lib/typescript/specs/pbkdf2.nitro.d.ts +9 -0
  354. package/lib/typescript/specs/pbkdf2.nitro.d.ts.map +1 -0
  355. package/lib/typescript/specs/rsaKeyPair.nitro.d.ts +20 -0
  356. package/lib/typescript/specs/rsaKeyPair.nitro.d.ts.map +1 -0
  357. package/lib/typescript/subtle.d.ts +17 -0
  358. package/lib/typescript/subtle.d.ts.map +1 -0
  359. package/lib/typescript/utils/cipher.d.ts +7 -0
  360. package/lib/typescript/utils/cipher.d.ts.map +1 -0
  361. package/lib/typescript/utils/conversion.d.ts +24 -2
  362. package/lib/typescript/utils/conversion.d.ts.map +1 -1
  363. package/lib/typescript/utils/errors.d.ts +7 -0
  364. package/lib/typescript/utils/errors.d.ts.map +1 -0
  365. package/lib/typescript/utils/hashnames.d.ts +13 -0
  366. package/lib/typescript/utils/hashnames.d.ts.map +1 -0
  367. package/lib/typescript/utils/index.d.ts +6 -5
  368. package/lib/typescript/utils/index.d.ts.map +1 -1
  369. package/lib/typescript/utils/noble.d.ts +19 -0
  370. package/lib/typescript/utils/noble.d.ts.map +1 -0
  371. package/lib/typescript/utils/types.d.ts +252 -2
  372. package/lib/typescript/utils/types.d.ts.map +1 -1
  373. package/lib/typescript/utils/validation.d.ts +13 -0
  374. package/lib/typescript/utils/validation.d.ts.map +1 -0
  375. package/nitrogen/generated/.gitattributes +1 -0
  376. package/nitrogen/generated/android/QuickCrypto+autolinking.cmake +47 -4
  377. package/nitrogen/generated/android/QuickCrypto+autolinking.gradle +4 -3
  378. package/nitrogen/generated/android/QuickCryptoOnLoad.cpp +144 -0
  379. package/nitrogen/generated/android/QuickCryptoOnLoad.hpp +25 -0
  380. package/nitrogen/generated/android/kotlin/com/margelo/nitro/crypto/QuickCryptoOnLoad.kt +35 -0
  381. package/nitrogen/generated/ios/QuickCrypto+autolinking.rb +11 -8
  382. package/nitrogen/generated/ios/QuickCrypto-Swift-Cxx-Bridge.cpp +11 -3
  383. package/nitrogen/generated/ios/QuickCrypto-Swift-Cxx-Bridge.hpp +5 -3
  384. package/nitrogen/generated/ios/QuickCrypto-Swift-Cxx-Umbrella.hpp +16 -7
  385. package/nitrogen/generated/ios/QuickCryptoAutolinking.mm +135 -0
  386. package/nitrogen/generated/ios/QuickCryptoAutolinking.swift +12 -0
  387. package/nitrogen/generated/shared/c++/CFRGKeyPairType.hpp +84 -0
  388. package/nitrogen/generated/shared/c++/CipherArgs.hpp +86 -0
  389. package/nitrogen/generated/shared/c++/HybridBlake3Spec.cpp +28 -0
  390. package/nitrogen/generated/shared/c++/HybridBlake3Spec.hpp +76 -0
  391. package/nitrogen/generated/shared/c++/HybridCipherFactorySpec.cpp +21 -0
  392. package/nitrogen/generated/shared/c++/HybridCipherFactorySpec.hpp +67 -0
  393. package/nitrogen/generated/shared/c++/HybridCipherSpec.cpp +28 -0
  394. package/nitrogen/generated/shared/c++/HybridCipherSpec.hpp +76 -0
  395. package/nitrogen/generated/shared/c++/HybridEcKeyPairSpec.cpp +29 -0
  396. package/nitrogen/generated/shared/c++/HybridEcKeyPairSpec.hpp +77 -0
  397. package/nitrogen/generated/shared/c++/HybridEdKeyPairSpec.cpp +30 -0
  398. package/nitrogen/generated/shared/c++/HybridEdKeyPairSpec.hpp +75 -0
  399. package/nitrogen/generated/shared/c++/HybridHashSpec.cpp +26 -0
  400. package/nitrogen/generated/shared/c++/HybridHashSpec.hpp +75 -0
  401. package/nitrogen/generated/shared/c++/HybridHmacSpec.cpp +23 -0
  402. package/nitrogen/generated/shared/c++/HybridHmacSpec.hpp +66 -0
  403. package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.cpp +26 -0
  404. package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.hpp +92 -0
  405. package/nitrogen/generated/shared/c++/HybridPbkdf2Spec.cpp +22 -0
  406. package/nitrogen/generated/shared/c++/HybridPbkdf2Spec.hpp +66 -0
  407. package/nitrogen/generated/shared/c++/HybridRandomSpec.cpp +2 -3
  408. package/nitrogen/generated/shared/c++/HybridRandomSpec.hpp +9 -6
  409. package/nitrogen/generated/shared/c++/HybridRsaKeyPairSpec.cpp +29 -0
  410. package/nitrogen/generated/shared/c++/HybridRsaKeyPairSpec.hpp +77 -0
  411. package/nitrogen/generated/shared/c++/JWK.hpp +161 -0
  412. package/nitrogen/generated/shared/c++/JWKkty.hpp +84 -0
  413. package/nitrogen/generated/shared/c++/JWKuse.hpp +76 -0
  414. package/nitrogen/generated/shared/c++/KFormatType.hpp +63 -0
  415. package/nitrogen/generated/shared/c++/KeyDetail.hpp +92 -0
  416. package/nitrogen/generated/shared/c++/KeyEncoding.hpp +64 -0
  417. package/nitrogen/generated/shared/c++/KeyObject.hpp +67 -0
  418. package/nitrogen/generated/shared/c++/KeyType.hpp +63 -0
  419. package/nitrogen/generated/shared/c++/KeyUsage.hpp +116 -0
  420. package/nitrogen/generated/shared/c++/NamedCurve.hpp +80 -0
  421. package/package.json +66 -39
  422. package/src/blake3.ts +123 -0
  423. package/src/cipher.ts +335 -0
  424. package/src/ec.ts +432 -0
  425. package/src/ed.ts +256 -0
  426. package/src/expo-plugin/@types.ts +7 -0
  427. package/src/expo-plugin/withRNQC.ts +23 -0
  428. package/src/expo-plugin/withSodiumAndroid.ts +24 -0
  429. package/src/expo-plugin/withSodiumIos.ts +30 -0
  430. package/src/expo-plugin/withXCode.ts +55 -0
  431. package/src/hash.ts +274 -0
  432. package/src/hmac.ts +135 -0
  433. package/src/index.ts +32 -29
  434. package/src/keys/classes.ts +317 -0
  435. package/src/keys/generateKeyPair.ts +145 -0
  436. package/src/keys/index.ts +52 -0
  437. package/src/keys/signVerify.ts +39 -0
  438. package/src/keys/utils.ts +190 -0
  439. package/src/pbkdf2.ts +154 -0
  440. package/src/random.ts +26 -23
  441. package/src/rsa.ts +176 -0
  442. package/src/specs/blake3.nitro.ts +12 -0
  443. package/src/specs/cipher.nitro.ts +25 -0
  444. package/src/specs/ecKeyPair.nitro.ts +38 -0
  445. package/src/specs/edKeyPair.nitro.ts +43 -0
  446. package/src/specs/hash.nitro.ts +10 -0
  447. package/src/specs/hmac.nitro.ts +7 -0
  448. package/src/specs/keyObjectHandle.nitro.ts +31 -0
  449. package/src/specs/pbkdf2.nitro.ts +18 -0
  450. package/src/specs/random.nitro.ts +2 -2
  451. package/src/specs/rsaKeyPair.nitro.ts +33 -0
  452. package/src/subtle.ts +614 -0
  453. package/src/utils/cipher.ts +60 -0
  454. package/src/utils/conversion.ts +143 -9
  455. package/src/utils/errors.ts +15 -0
  456. package/src/utils/hashnames.ts +98 -0
  457. package/src/utils/index.ts +6 -6
  458. package/src/utils/noble.ts +85 -0
  459. package/src/utils/types.ts +423 -3
  460. package/src/utils/validation.ts +130 -0
  461. package/ios/QuickCryptoOnLoad.mm +0 -19
  462. package/lib/module/package.json +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"names":["Buffer","SBuffer","CryptoKey","bufferLikeToArrayBuffer","lazyDOMException","normalizeHashName","HashContext","validateMaxBufferLength","asyncDigest","createSecretKey","pbkdf2DeriveBits","ecImportKey","ecdsaSignVerify","ec_generateKeyPair","rsa_generateKeyPair","KWebCryptoKeyFormat","CipherOrWrapMode","hasAnyNotIn","usages","allowed","some","usage","includes","normalizeAlgorithm","algorithm","_operation","name","getAlgorithmName","length","ecExportKey","_key","_format","Error","rsaExportKey","rsaCipher","_mode","_data","_algorithm","aesCipher","aesGenerateKey","_extractable","_keyUsages","rsaImportKey","hmacImportKey","aesImportKey","exportKeySpki","key","type","kWebCryptoKeyFormatSPKI","exportKeyPkcs8","kWebCryptoKeyFormatPKCS8","exportKeyRaw","kWebCryptoKeyFormatRaw","keyObject","export","exportKeyJWK","jwk","handle","exportJwk","key_ops","ext","extractable","alg","hash","JwkRsa","JwkRsaPss","JwkRsaOaep","JwkHmac","crv","namedCurve","undefined","importGenericSecretKey","format","keyData","keyUsages","checkLength","isBuffer","byteLength","checkCryptoKeyPairUsages","pair","privateKey","isCryptoKeyPair","result","signVerify","data","signature","cipherOrWrap","mode","op","Subtle","decrypt","normalizedAlgorithm","kWebCryptoCipherDecrypt","digest","deriveBits","baseKey","encrypt","kWebCryptoCipherEncrypt","exportKey","generateKey","importKey","sign","verify","subtle"],"sourceRoot":"../../src","sources":["subtle.ts"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+
3
+ // Mimics node behavior for default global encoding
4
+ let defaultEncoding = 'buffer';
5
+ export function setDefaultEncoding(encoding) {
6
+ defaultEncoding = encoding;
7
+ }
8
+ export function getDefaultEncoding() {
9
+ return defaultEncoding;
10
+ }
11
+ export function normalizeEncoding(enc) {
12
+ if (!enc) return 'utf8';
13
+ let retried;
14
+ while (true) {
15
+ switch (enc) {
16
+ case 'utf8':
17
+ case 'utf-8':
18
+ return 'utf8';
19
+ case 'ucs2':
20
+ case 'ucs-2':
21
+ case 'utf16le':
22
+ case 'utf-16le':
23
+ return 'utf16le';
24
+ case 'latin1':
25
+ case 'binary':
26
+ return 'latin1';
27
+ case 'base64':
28
+ case 'ascii':
29
+ case 'hex':
30
+ return enc;
31
+ default:
32
+ if (retried) return; // undefined
33
+ enc = ('' + enc).toLowerCase();
34
+ retried = true;
35
+ }
36
+ }
37
+ }
38
+ export function validateEncoding(data, encoding) {
39
+ const normalizedEncoding = normalizeEncoding(encoding);
40
+ const length = data.length;
41
+ if (normalizedEncoding === 'hex' && length % 2 !== 0) {
42
+ throw new Error(`Encoding ${encoding} not valid for data length ${length}`);
43
+ }
44
+ }
45
+
46
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
47
+ export function getUIntOption(options, key) {
48
+ let value;
49
+ if (options && (value = options[key]) != null) {
50
+ // >>> Turns any type into a positive integer (also sets the sign bit to 0)
51
+ if (value >>> 0 !== value) throw new Error(`options.${key}: ${value}`);
52
+ return value;
53
+ }
54
+ return -1;
55
+ }
56
+ //# sourceMappingURL=cipher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["defaultEncoding","setDefaultEncoding","encoding","getDefaultEncoding","normalizeEncoding","enc","retried","toLowerCase","validateEncoding","data","normalizedEncoding","length","Error","getUIntOption","options","key","value"],"sourceRoot":"../../../src","sources":["utils/cipher.ts"],"mappings":";;AAEA;AACA,IAAIA,eAAyB,GAAG,QAAQ;AAExC,OAAO,SAASC,kBAAkBA,CAACC,QAAkB,EAAE;EACrDF,eAAe,GAAGE,QAAQ;AAC5B;AAEA,OAAO,SAASC,kBAAkBA,CAAA,EAAa;EAC7C,OAAOH,eAAe;AACxB;AAEA,OAAO,SAASI,iBAAiBA,CAACC,GAAW,EAAE;EAC7C,IAAI,CAACA,GAAG,EAAE,OAAO,MAAM;EACvB,IAAIC,OAAO;EACX,OAAO,IAAI,EAAE;IACX,QAAQD,GAAG;MACT,KAAK,MAAM;MACX,KAAK,OAAO;QACV,OAAO,MAAM;MACf,KAAK,MAAM;MACX,KAAK,OAAO;MACZ,KAAK,SAAS;MACd,KAAK,UAAU;QACb,OAAO,SAAS;MAClB,KAAK,QAAQ;MACb,KAAK,QAAQ;QACX,OAAO,QAAQ;MACjB,KAAK,QAAQ;MACb,KAAK,OAAO;MACZ,KAAK,KAAK;QACR,OAAOA,GAAG;MACZ;QACE,IAAIC,OAAO,EAAE,OAAO,CAAC;QACrBD,GAAG,GAAG,CAAC,EAAE,GAAGA,GAAG,EAAEE,WAAW,CAAC,CAAC;QAC9BD,OAAO,GAAG,IAAI;IAClB;EACF;AACF;AAEA,OAAO,SAASE,gBAAgBA,CAACC,IAAY,EAAEP,QAAgB,EAAE;EAC/D,MAAMQ,kBAAkB,GAAGN,iBAAiB,CAACF,QAAQ,CAAC;EACtD,MAAMS,MAAM,GAAGF,IAAI,CAACE,MAAM;EAE1B,IAAID,kBAAkB,KAAK,KAAK,IAAIC,MAAM,GAAG,CAAC,KAAK,CAAC,EAAE;IACpD,MAAM,IAAIC,KAAK,CAAC,YAAYV,QAAQ,8BAA8BS,MAAM,EAAE,CAAC;EAC7E;AACF;;AAEA;AACA,OAAO,SAASE,aAAaA,CAACC,OAA4B,EAAEC,GAAW,EAAE;EACvE,IAAIC,KAAK;EACT,IAAIF,OAAO,IAAI,CAACE,KAAK,GAAGF,OAAO,CAACC,GAAG,CAAC,KAAK,IAAI,EAAE;IAC7C;IACA,IAAIC,KAAK,KAAK,CAAC,KAAKA,KAAK,EAAE,MAAM,IAAIJ,KAAK,CAAC,WAAWG,GAAG,KAAKC,KAAK,EAAE,CAAC;IACtE,OAAOA,KAAK;EACd;EACA,OAAO,CAAC,CAAC;AACX","ignoreList":[]}
@@ -1,16 +1,128 @@
1
1
  "use strict";
2
2
 
3
- import { Buffer } from '@craftzdog/react-native-buffer';
4
- export const abvToArrayBuffer = buffer => {
5
- if (Buffer.isBuffer(buffer)) {
6
- return buffer.buffer;
3
+ import { Buffer as CraftzdogBuffer } from '@craftzdog/react-native-buffer';
4
+ import { Buffer as SafeBuffer } from 'safe-buffer';
5
+ import { KeyObject } from '../keys/classes';
6
+
7
+ /**
8
+ * Converts supplied argument to an ArrayBuffer. Note this does not copy the
9
+ * data so it is faster than toArrayBuffer. Not copying is important for
10
+ * functions like randomFill which need to be able to write to the underlying
11
+ * buffer.
12
+ * @param buf
13
+ * @returns ArrayBuffer
14
+ */
15
+ export const abvToArrayBuffer = buf => {
16
+ if (CraftzdogBuffer.isBuffer(buf)) {
17
+ return buf.buffer;
7
18
  }
8
- if (ArrayBuffer.isView(buffer)) {
9
- return buffer.buffer;
19
+ if (ArrayBuffer.isView(buf)) {
20
+ return buf.buffer;
10
21
  }
11
- return buffer;
22
+ return buf;
12
23
  };
24
+
25
+ /**
26
+ * Converts supplied argument to an ArrayBuffer. Note this copies data if the
27
+ * supplied buffer has the .slice() method, so can be a bit slow.
28
+ * @param buf
29
+ * @returns ArrayBuffer
30
+ */
31
+ export function toArrayBuffer(buf) {
32
+ if (CraftzdogBuffer.isBuffer(buf) || ArrayBuffer.isView(buf)) {
33
+ if (buf?.buffer?.slice) {
34
+ return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength);
35
+ } else {
36
+ return buf.buffer;
37
+ }
38
+ }
39
+ const ab = new ArrayBuffer(buf.length);
40
+ const view = new Uint8Array(ab);
41
+ for (let i = 0; i < buf.length; ++i) {
42
+ view[i] = SafeBuffer.isBuffer(buf) ? buf.readUInt8(i) : buf[i];
43
+ }
44
+ return ab;
45
+ }
46
+ export function bufferLikeToArrayBuffer(buf) {
47
+ // Buffer
48
+ if (CraftzdogBuffer.isBuffer(buf) || SafeBuffer.isBuffer(buf)) {
49
+ return toArrayBuffer(buf);
50
+ }
51
+ // ArrayBufferView
52
+ if (ArrayBuffer.isView(buf)) {
53
+ return toArrayBuffer(buf);
54
+ }
55
+
56
+ // If buf is already an ArrayBuffer, return it.
57
+ if (buf instanceof ArrayBuffer) {
58
+ return buf;
59
+ }
60
+
61
+ // If buf is a SharedArrayBuffer, convert it to ArrayBuffer.
62
+ // This typically involves a copy of the data.
63
+ if (typeof SharedArrayBuffer !== 'undefined' && buf instanceof SharedArrayBuffer) {
64
+ const arrayBuffer = new ArrayBuffer(buf.byteLength);
65
+ new Uint8Array(arrayBuffer).set(new Uint8Array(buf));
66
+ return arrayBuffer;
67
+ }
68
+
69
+ // If we reach here, 'buf' is of a type within BufferLike that has not been handled by the above checks.
70
+ // This indicates either an incomplete BufferLike definition or an unexpected input type.
71
+ // Throw an error to signal this, ensuring the function's contract (return ArrayBuffer or throw) is met.
72
+ throw new TypeError('Input must be a Buffer, ArrayBufferView, ArrayBuffer, or SharedArrayBuffer.');
73
+ }
74
+ export function binaryLikeToArrayBuffer(input,
75
+ // CipherKey adds compat with node types
76
+ encoding = 'utf-8') {
77
+ // string
78
+ if (typeof input === 'string') {
79
+ if (encoding === 'buffer') {
80
+ throw new Error('Cannot create a buffer from a string with a buffer encoding');
81
+ }
82
+ const buffer = CraftzdogBuffer.from(input, encoding);
83
+ return buffer.buffer.slice(buffer.byteOffset, buffer.byteOffset + buffer.byteLength);
84
+ }
85
+
86
+ // Buffer
87
+ if (CraftzdogBuffer.isBuffer(input) || SafeBuffer.isBuffer(input)) {
88
+ return toArrayBuffer(input);
89
+ }
90
+
91
+ // ArrayBufferView
92
+ // TODO add further binary types to BinaryLike, UInt8Array and so for have this array as property
93
+ if (ArrayBuffer.isView(input)) {
94
+ return toArrayBuffer(input);
95
+ }
96
+
97
+ // ArrayBuffer
98
+ if (input instanceof ArrayBuffer) {
99
+ return input;
100
+ }
101
+
102
+ // if (!(input instanceof ArrayBuffer)) {
103
+ // try {
104
+ // // this is a strange fallback case and input is unknown at this point
105
+ // const buffer = Buffer.from(input as unknown as string);
106
+ // return buffer.buffer.slice(
107
+ // buffer.byteOffset,
108
+ // buffer.byteOffset + buffer.byteLength
109
+ // );
110
+ // } catch(e: unknown) {
111
+ // console.log('throwing 1');
112
+ // const err = e as Error;
113
+ // throw new Error(err.message);
114
+ // }
115
+ // }
116
+
117
+ // KeyObject
118
+ if (input instanceof KeyObject) {
119
+ return input.handle.exportKey();
120
+ }
121
+ throw new Error('input could not be converted to ArrayBuffer');
122
+ }
13
123
  export function ab2str(buf, encoding = 'hex') {
14
- return Buffer.from(buf).toString(encoding);
124
+ return CraftzdogBuffer.from(buf).toString(encoding);
15
125
  }
126
+ export const kEmptyObject = Object.freeze(Object.create(null));
127
+ export * from './noble';
16
128
  //# sourceMappingURL=conversion.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["Buffer","abvToArrayBuffer","buffer","isBuffer","ArrayBuffer","isView","ab2str","buf","encoding","from","toString"],"sourceRoot":"../../../src","sources":["utils/conversion.ts"],"mappings":";;AAAA,SAASA,MAAM,QAAQ,gCAAgC;AAGvD,OAAO,MAAMC,gBAAgB,GAAIC,MAAuB,IAAK;EAC3D,IAAIF,MAAM,CAACG,QAAQ,CAACD,MAAM,CAAC,EAAE;IAC3B,OAAOA,MAAM,CAACA,MAAM;EACtB;EACA,IAAIE,WAAW,CAACC,MAAM,CAACH,MAAM,CAAC,EAAE;IAC9B,OAAOA,MAAM,CAACA,MAAM;EACtB;EACA,OAAOA,MAAM;AACf,CAAC;AAED,OAAO,SAASI,MAAMA,CAACC,GAAgB,EAAEC,QAAgB,GAAG,KAAK,EAAE;EACjE,OAAOR,MAAM,CAACS,IAAI,CAACF,GAAG,CAAC,CAACG,QAAQ,CAACF,QAAQ,CAAC;AAC5C","ignoreList":[]}
1
+ {"version":3,"names":["Buffer","CraftzdogBuffer","SafeBuffer","KeyObject","abvToArrayBuffer","buf","isBuffer","buffer","ArrayBuffer","isView","toArrayBuffer","slice","byteOffset","byteLength","ab","length","view","Uint8Array","i","readUInt8","bufferLikeToArrayBuffer","SharedArrayBuffer","arrayBuffer","set","TypeError","binaryLikeToArrayBuffer","input","encoding","Error","from","handle","exportKey","ab2str","toString","kEmptyObject","Object","freeze","create"],"sourceRoot":"../../../src","sources":["utils/conversion.ts"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ export function lazyDOMException(message, domName) {
4
+ let cause = '';
5
+ if (typeof domName !== 'string') {
6
+ cause = `\nCaused by: ${domName.cause}`;
7
+ }
8
+ return new Error(`[${domName}]: ${message}${cause}`);
9
+ }
10
+ //# sourceMappingURL=errors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["lazyDOMException","message","domName","cause","Error"],"sourceRoot":"../../../src","sources":["utils/errors.ts"],"mappings":";;AAOA,OAAO,SAASA,gBAAgBA,CAACC,OAAe,EAAEC,OAAgB,EAAS;EACzE,IAAIC,KAAK,GAAG,EAAE;EACd,IAAI,OAAOD,OAAO,KAAK,QAAQ,EAAE;IAC/BC,KAAK,GAAG,gBAAgBD,OAAO,CAACC,KAAK,EAAE;EACzC;EAEA,OAAO,IAAIC,KAAK,CAAC,IAAIF,OAAO,MAAMD,OAAO,GAAGE,KAAK,EAAE,CAAC;AACtD","ignoreList":[]}
@@ -0,0 +1,89 @@
1
+ "use strict";
2
+
3
+ export let HashContext = /*#__PURE__*/function (HashContext) {
4
+ HashContext[HashContext["Node"] = 0] = "Node";
5
+ HashContext[HashContext["WebCrypto"] = 1] = "WebCrypto";
6
+ HashContext[HashContext["JwkRsa"] = 2] = "JwkRsa";
7
+ HashContext[HashContext["JwkRsaPss"] = 3] = "JwkRsaPss";
8
+ HashContext[HashContext["JwkRsaOaep"] = 4] = "JwkRsaOaep";
9
+ HashContext[HashContext["JwkHmac"] = 5] = "JwkHmac";
10
+ return HashContext;
11
+ }({});
12
+
13
+ // WebCrypto and JWK use a bunch of different names for the
14
+ // standard set of SHA-* digest algorithms... which is ... fun.
15
+ // Here we provide a utility for mapping between them in order
16
+ // make it easier in the code.
17
+
18
+ const kHashNames = {
19
+ sha1: {
20
+ [HashContext.Node]: 'sha1',
21
+ [HashContext.WebCrypto]: 'SHA-1',
22
+ [HashContext.JwkRsa]: 'RS1',
23
+ [HashContext.JwkRsaPss]: 'PS1',
24
+ [HashContext.JwkRsaOaep]: 'RSA-OAEP',
25
+ [HashContext.JwkHmac]: 'HS1'
26
+ },
27
+ sha224: {
28
+ [HashContext.Node]: 'sha224',
29
+ [HashContext.WebCrypto]: 'SHA-224',
30
+ [HashContext.JwkRsa]: 'RS224',
31
+ [HashContext.JwkRsaPss]: 'PS224',
32
+ [HashContext.JwkRsaOaep]: 'RSA-OAEP-224',
33
+ [HashContext.JwkHmac]: 'HS224'
34
+ },
35
+ sha256: {
36
+ [HashContext.Node]: 'sha256',
37
+ [HashContext.WebCrypto]: 'SHA-256',
38
+ [HashContext.JwkRsa]: 'RS256',
39
+ [HashContext.JwkRsaPss]: 'PS256',
40
+ [HashContext.JwkRsaOaep]: 'RSA-OAEP-256',
41
+ [HashContext.JwkHmac]: 'HS256'
42
+ },
43
+ sha384: {
44
+ [HashContext.Node]: 'sha384',
45
+ [HashContext.WebCrypto]: 'SHA-384',
46
+ [HashContext.JwkRsa]: 'RS384',
47
+ [HashContext.JwkRsaPss]: 'PS384',
48
+ [HashContext.JwkRsaOaep]: 'RSA-OAEP-384',
49
+ [HashContext.JwkHmac]: 'HS384'
50
+ },
51
+ sha512: {
52
+ [HashContext.Node]: 'sha512',
53
+ [HashContext.WebCrypto]: 'SHA-512',
54
+ [HashContext.JwkRsa]: 'RS512',
55
+ [HashContext.JwkRsaPss]: 'PS512',
56
+ [HashContext.JwkRsaOaep]: 'RSA-OAEP-512',
57
+ [HashContext.JwkHmac]: 'HS512'
58
+ },
59
+ ripemd160: {
60
+ [HashContext.Node]: 'ripemd160',
61
+ [HashContext.WebCrypto]: 'RIPEMD-160'
62
+ }
63
+ };
64
+ {
65
+ // Index the aliases
66
+ const keys = Object.keys(kHashNames);
67
+ for (let n = 0; n < keys.length; n++) {
68
+ const contexts = Object.keys(kHashNames[keys[n]]);
69
+ for (let i = 0; i < contexts.length; i++) {
70
+ const alias = kHashNames[keys[n]][contexts[i]].toLowerCase();
71
+ if (kHashNames[alias] === undefined) kHashNames[alias] = kHashNames[keys[n]];
72
+ }
73
+ }
74
+ }
75
+ export function normalizeHashName(algo, context = HashContext.Node) {
76
+ if (typeof algo !== 'undefined') {
77
+ const hashName = typeof algo === 'string' ? algo : algo.name || algo.toString();
78
+ const normAlgo = hashName.toLowerCase();
79
+ try {
80
+ const alias = kHashNames[normAlgo][context];
81
+ if (alias) return alias;
82
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
83
+ } catch (_e) {
84
+ // ignore
85
+ }
86
+ }
87
+ throw new Error(`Invalid Hash Algorithm: ${algo}`);
88
+ }
89
+ //# sourceMappingURL=hashnames.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["HashContext","kHashNames","sha1","Node","WebCrypto","JwkRsa","JwkRsaPss","JwkRsaOaep","JwkHmac","sha224","sha256","sha384","sha512","ripemd160","keys","Object","n","length","contexts","i","alias","toLowerCase","undefined","normalizeHashName","algo","context","hashName","name","toString","normAlgo","_e","Error"],"sourceRoot":"../../../src","sources":["utils/hashnames.ts"],"mappings":"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","ignoreList":[]}
@@ -1,8 +1,9 @@
1
1
  "use strict";
2
2
 
3
- import { ab2str, abvToArrayBuffer } from "./conversion";
4
- export const utils = {
5
- ab2str,
6
- abvToArrayBuffer
7
- };
3
+ export * from './conversion';
4
+ export * from './errors';
5
+ export * from './hashnames';
6
+ export * from './types';
7
+ export * from './validation';
8
+ export * from './cipher';
8
9
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["ab2str","abvToArrayBuffer","utils"],"sourceRoot":"../../../src","sources":["utils/index.ts"],"mappings":";;AAAA,SAASA,MAAM,EAAEC,gBAAgB,QAAQ,cAAc;AAEvD,OAAO,MAAMC,KAAK,GAAG;EACnBF,MAAM;EACNC;AACF,CAAC","ignoreList":[]}
1
+ {"version":3,"names":[],"sourceRoot":"../../../src","sources":["utils/index.ts"],"mappings":";;AAAA,cAAc,cAAc;AAC5B,cAAc,UAAU;AACxB,cAAc,aAAa;AAC3B,cAAc,SAAS;AACvB,cAAc,cAAc;AAC5B,cAAc,UAAU","ignoreList":[]}
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+
3
+ /**
4
+ * Takes hex string or Uint8Array, converts to Uint8Array.
5
+ * Validates output length.
6
+ * Will throw error for other types.
7
+ * @param title descriptive title for an error e.g. 'private key'
8
+ * @param hex hex string or Uint8Array
9
+ * @param expectedLength optional, will compare to result array's length
10
+ * @returns
11
+ */
12
+ export function ensureBytes(title, hex, expectedLength) {
13
+ let res;
14
+ if (typeof hex === 'string') {
15
+ try {
16
+ res = hexToBytes(hex);
17
+ } catch (e) {
18
+ throw new Error(title + ' must be hex string or Uint8Array, cause: ' + e);
19
+ }
20
+ } else if (isBytes(hex)) {
21
+ // Uint8Array.from() instead of hash.slice() because node.js Buffer
22
+ // is instance of Uint8Array, and its slice() creates **mutable** copy
23
+ res = Uint8Array.from(hex);
24
+ } else {
25
+ throw new Error(title + ' must be hex string or Uint8Array');
26
+ }
27
+ const len = res.length;
28
+ if (typeof expectedLength === 'number' && len !== expectedLength) throw new Error(title + ' of length ' + expectedLength + ' expected, got ' + len);
29
+ return res;
30
+ }
31
+
32
+ /** Checks if something is Uint8Array. Be careful: nodejs Buffer will return true. */
33
+ export function isBytes(a) {
34
+ return a instanceof Uint8Array || ArrayBuffer.isView(a) && a.constructor.name === 'Uint8Array';
35
+ }
36
+
37
+ // We use optimized technique to convert hex string to byte array
38
+ const asciis = {
39
+ _0: 48,
40
+ _9: 57,
41
+ A: 65,
42
+ F: 70,
43
+ a: 97,
44
+ f: 102
45
+ };
46
+ function asciiToBase16(ch) {
47
+ if (ch >= asciis._0 && ch <= asciis._9) return ch - asciis._0; // '2' => 50-48
48
+ if (ch >= asciis.A && ch <= asciis.F) return ch - (asciis.A - 10); // 'B' => 66-(65-10)
49
+ if (ch >= asciis.a && ch <= asciis.f) return ch - (asciis.a - 10); // 'b' => 98-(97-10)
50
+ return;
51
+ }
52
+
53
+ /**
54
+ * Convert hex string to byte array. Uses built-in function, when available.
55
+ * @example hexToBytes('cafe0123') // Uint8Array.from([0xca, 0xfe, 0x01, 0x23])
56
+ */
57
+ export function hexToBytes(hex) {
58
+ if (typeof hex !== 'string') throw new Error('hex string expected, got ' + typeof hex);
59
+ // @ts-expect-error Uint8Array.fromHex
60
+ if (hasHexBuiltin) return Uint8Array.fromHex(hex);
61
+ const hl = hex.length;
62
+ const al = hl / 2;
63
+ if (hl % 2) throw new Error('hex string expected, got unpadded hex of length ' + hl);
64
+ const array = new Uint8Array(al);
65
+ for (let ai = 0, hi = 0; ai < al; ai++, hi += 2) {
66
+ const n1 = asciiToBase16(hex.charCodeAt(hi));
67
+ const n2 = asciiToBase16(hex.charCodeAt(hi + 1));
68
+ if (n1 === undefined || n2 === undefined) {
69
+ const char = hex.substring(hi, hi + 2);
70
+ throw new Error('hex string expected, got non-hex character "' + char + '" at index ' + hi);
71
+ }
72
+ array[ai] = n1 * 16 + n2; // multiply first octet, e.g. 'a3' => 10*16+3 => 160 + 3 => 163
73
+ }
74
+ return array;
75
+ }
76
+ //# sourceMappingURL=noble.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["ensureBytes","title","hex","expectedLength","res","hexToBytes","e","Error","isBytes","Uint8Array","from","len","length","a","ArrayBuffer","isView","constructor","name","asciis","_0","_9","A","F","f","asciiToBase16","ch","hasHexBuiltin","fromHex","hl","al","array","ai","hi","n1","charCodeAt","n2","undefined","char","substring"],"sourceRoot":"../../../src","sources":["utils/noble.ts"],"mappings":"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","ignoreList":[]}
@@ -1,2 +1,55 @@
1
1
  "use strict";
2
+
3
+ // @types/node
4
+
5
+ // TODO: These enums need to be defined on the native side
6
+ export let KFormatType = /*#__PURE__*/function (KFormatType) {
7
+ KFormatType[KFormatType["DER"] = 0] = "DER";
8
+ KFormatType[KFormatType["PEM"] = 1] = "PEM";
9
+ KFormatType[KFormatType["JWK"] = 2] = "JWK";
10
+ return KFormatType;
11
+ }({});
12
+ export let KeyType = /*#__PURE__*/function (KeyType) {
13
+ KeyType[KeyType["SECRET"] = 0] = "SECRET";
14
+ KeyType[KeyType["PUBLIC"] = 1] = "PUBLIC";
15
+ KeyType[KeyType["PRIVATE"] = 2] = "PRIVATE";
16
+ return KeyType;
17
+ }({});
18
+ export let KeyEncoding = /*#__PURE__*/function (KeyEncoding) {
19
+ KeyEncoding[KeyEncoding["PKCS1"] = 0] = "PKCS1";
20
+ KeyEncoding[KeyEncoding["PKCS8"] = 1] = "PKCS8";
21
+ KeyEncoding[KeyEncoding["SPKI"] = 2] = "SPKI";
22
+ KeyEncoding[KeyEncoding["SEC1"] = 3] = "SEC1";
23
+ return KeyEncoding;
24
+ }({});
25
+ export let KeyFormat = /*#__PURE__*/function (KeyFormat) {
26
+ KeyFormat[KeyFormat["RAW"] = 0] = "RAW";
27
+ KeyFormat[KeyFormat["PKCS8"] = 1] = "PKCS8";
28
+ KeyFormat[KeyFormat["SPKI"] = 2] = "SPKI";
29
+ KeyFormat[KeyFormat["JWK"] = 3] = "JWK";
30
+ return KeyFormat;
31
+ }({});
32
+ export const kNamedCurveAliases = {
33
+ 'P-256': 'prime256v1',
34
+ 'P-384': 'secp384r1',
35
+ 'P-521': 'secp521r1'
36
+ };
37
+ // end TODO
38
+
39
+ export let KeyVariant = /*#__PURE__*/function (KeyVariant) {
40
+ KeyVariant[KeyVariant["RSA_SSA_PKCS1_v1_5"] = 0] = "RSA_SSA_PKCS1_v1_5";
41
+ KeyVariant[KeyVariant["RSA_PSS"] = 1] = "RSA_PSS";
42
+ KeyVariant[KeyVariant["RSA_OAEP"] = 2] = "RSA_OAEP";
43
+ KeyVariant[KeyVariant["DSA"] = 3] = "DSA";
44
+ KeyVariant[KeyVariant["EC"] = 4] = "EC";
45
+ KeyVariant[KeyVariant["NID"] = 5] = "NID";
46
+ KeyVariant[KeyVariant["DH"] = 6] = "DH";
47
+ return KeyVariant;
48
+ }({});
49
+
50
+ // These are for shortcomings in @types/node
51
+ // Here we use "*Type" instead of "*Types" like node does.
52
+ // export type CipherCBCType = 'aes-128-cbc' | 'aes-192-cbc' | 'aes-256-cbc';
53
+
54
+ // from @paulmillr/noble-curves
2
55
  //# sourceMappingURL=types.js.map
@@ -1 +1 @@
1
- {"version":3,"names":[],"sourceRoot":"../../../src","sources":["utils/types.ts"],"mappings":"","ignoreList":[]}
1
+ {"version":3,"names":["KFormatType","KeyType","KeyEncoding","KeyFormat","kNamedCurveAliases","KeyVariant"],"sourceRoot":"../../../src","sources":["utils/types.ts"],"mappings":";;AAE8C;;AAmL9C;AACA,WAAYA,WAAW,0BAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAA,OAAXA,WAAW;AAAA;AAMvB,WAAYC,OAAO,0BAAPA,OAAO;EAAPA,OAAO,CAAPA,OAAO;EAAPA,OAAO,CAAPA,OAAO;EAAPA,OAAO,CAAPA,OAAO;EAAA,OAAPA,OAAO;AAAA;AAMnB,WAAYC,WAAW,0BAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAA,OAAXA,WAAW;AAAA;AAOvB,WAAYC,SAAS,0BAATA,SAAS;EAATA,SAAS,CAATA,SAAS;EAATA,SAAS,CAATA,SAAS;EAATA,SAAS,CAATA,SAAS;EAATA,SAAS,CAATA,SAAS;EAAA,OAATA,SAAS;AAAA;AASrB,OAAO,MAAMC,kBAAkB,GAAG;EAChC,OAAO,EAAE,YAAY;EACrB,OAAO,EAAE,WAAW;EACpB,OAAO,EAAE;AACX,CAAU;AACV;;AAkIA,WAAYC,UAAU,0BAAVA,UAAU;EAAVA,UAAU,CAAVA,UAAU;EAAVA,UAAU,CAAVA,UAAU;EAAVA,UAAU,CAAVA,UAAU;EAAVA,UAAU,CAAVA,UAAU;EAAVA,UAAU,CAAVA,UAAU;EAAVA,UAAU,CAAVA,UAAU;EAAVA,UAAU,CAAVA,UAAU;EAAA,OAAVA,UAAU;AAAA;;AAuBtB;AACA;AACA;;AAqCA","ignoreList":[]}
@@ -0,0 +1,87 @@
1
+ "use strict";
2
+
3
+ import { Buffer as SBuffer } from 'safe-buffer';
4
+ import { lazyDOMException } from './errors';
5
+
6
+ // The maximum buffer size that we'll support in the WebCrypto impl
7
+ const kMaxBufferLength = 2 ** 31 - 1;
8
+ export function validateFunction(f) {
9
+ return f !== null && typeof f === 'function';
10
+ }
11
+ export function isStringOrBuffer(val) {
12
+ return typeof val === 'string' || ArrayBuffer.isView(val) || val instanceof ArrayBuffer;
13
+ }
14
+ export function validateObject(value, name, options) {
15
+ const useDefaultOptions = options == null;
16
+ const allowArray = useDefaultOptions ? false : options.allowArray;
17
+ const allowFunction = useDefaultOptions ? false : options.allowFunction;
18
+ const nullable = useDefaultOptions ? false : options.nullable;
19
+ if (!nullable && value === null || !allowArray && Array.isArray(value) || typeof value !== 'object' && (!allowFunction || typeof value !== 'function')) {
20
+ throw new Error(`${name} is not a valid object ${value}`);
21
+ }
22
+ return true;
23
+ }
24
+ export const validateMaxBufferLength = (data, name) => {
25
+ const length = typeof data === 'string' || data instanceof SBuffer ? data.length : data.byteLength;
26
+ if (length > kMaxBufferLength) {
27
+ throw lazyDOMException(`${name} must be less than ${kMaxBufferLength + 1} bits`, 'OperationError');
28
+ }
29
+ };
30
+ export const getUsagesUnion = (usageSet, ...usages) => {
31
+ const newset = [];
32
+ for (let n = 0; n < usages.length; n++) {
33
+ if (!usages[n] || usages[n] === undefined) continue;
34
+ if (usageSet.includes(usages[n])) newset.push(usages[n]);
35
+ }
36
+ return newset;
37
+ };
38
+ const kKeyOps = {
39
+ sign: 1,
40
+ verify: 2,
41
+ encrypt: 3,
42
+ decrypt: 4,
43
+ wrapKey: 5,
44
+ unwrapKey: 6,
45
+ deriveKey: 7,
46
+ deriveBits: 8,
47
+ encapsulateBits: 9,
48
+ decapsulateBits: 10,
49
+ encapsulateKey: 11,
50
+ decapsulateKey: 12
51
+ };
52
+ export const validateKeyOps = (keyOps, usagesSet) => {
53
+ if (keyOps === undefined) return;
54
+ if (!Array.isArray(keyOps)) {
55
+ throw lazyDOMException('keyData.key_ops', 'InvalidArgument');
56
+ }
57
+ let flags = 0;
58
+ for (let n = 0; n < keyOps.length; n++) {
59
+ const op = keyOps[n];
60
+ const op_flag = kKeyOps[op];
61
+ // Skipping unknown key ops
62
+ if (op_flag === undefined) continue;
63
+ // Have we seen it already? if so, error
64
+ if (flags & 1 << op_flag) throw lazyDOMException('Duplicate key operation', 'DataError');
65
+ flags |= 1 << op_flag;
66
+
67
+ // TODO(@jasnell): RFC7517 section 4.3 strong recommends validating
68
+ // key usage combinations. Specifically, it says that unrelated key
69
+ // ops SHOULD NOT be used together. We're not yet validating that here.
70
+ }
71
+ if (usagesSet !== undefined) {
72
+ for (const use of usagesSet) {
73
+ if (!keyOps.includes(use)) {
74
+ throw lazyDOMException('Key operations and usage mismatch', 'DataError');
75
+ }
76
+ }
77
+ }
78
+ };
79
+ export function hasAnyNotIn(set, checks) {
80
+ for (const s of set) {
81
+ if (!checks.includes(s)) {
82
+ return true;
83
+ }
84
+ }
85
+ return false;
86
+ }
87
+ //# sourceMappingURL=validation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["Buffer","SBuffer","lazyDOMException","kMaxBufferLength","validateFunction","f","isStringOrBuffer","val","ArrayBuffer","isView","validateObject","value","name","options","useDefaultOptions","allowArray","allowFunction","nullable","Array","isArray","Error","validateMaxBufferLength","data","length","byteLength","getUsagesUnion","usageSet","usages","newset","n","undefined","includes","push","kKeyOps","sign","verify","encrypt","decrypt","wrapKey","unwrapKey","deriveKey","deriveBits","encapsulateBits","decapsulateBits","encapsulateKey","decapsulateKey","validateKeyOps","keyOps","usagesSet","flags","op","op_flag","use","hasAnyNotIn","set","checks","s"],"sourceRoot":"../../../src","sources":["utils/validation.ts"],"mappings":"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","ignoreList":[]}