react-native-quick-crypto 1.0.0-beta.8 → 1.0.0

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 (480) hide show
  1. package/QuickCrypto.podspec +145 -6
  2. package/README.md +14 -27
  3. package/android/CMakeLists.txt +62 -7
  4. package/android/build.gradle +12 -2
  5. package/android/src/main/java/com/margelo/nitro/quickcrypto/QuickCryptoPackage.java +0 -2
  6. package/app.plugin.js +3 -0
  7. package/cpp/blake3/HybridBlake3.cpp +118 -0
  8. package/cpp/blake3/HybridBlake3.hpp +35 -0
  9. package/cpp/cipher/CCMCipher.cpp +199 -0
  10. package/cpp/cipher/CCMCipher.hpp +26 -0
  11. package/cpp/cipher/ChaCha20Cipher.cpp +97 -0
  12. package/cpp/cipher/ChaCha20Cipher.hpp +25 -0
  13. package/cpp/cipher/ChaCha20Poly1305Cipher.cpp +170 -0
  14. package/cpp/cipher/ChaCha20Poly1305Cipher.hpp +30 -0
  15. package/cpp/cipher/GCMCipher.cpp +68 -0
  16. package/cpp/cipher/GCMCipher.hpp +14 -0
  17. package/cpp/cipher/HybridCipher.cpp +322 -0
  18. package/cpp/cipher/HybridCipher.hpp +68 -0
  19. package/cpp/cipher/HybridCipherFactory.hpp +105 -0
  20. package/cpp/cipher/HybridRsaCipher.cpp +348 -0
  21. package/cpp/cipher/HybridRsaCipher.hpp +29 -0
  22. package/cpp/cipher/OCBCipher.cpp +55 -0
  23. package/cpp/cipher/OCBCipher.hpp +19 -0
  24. package/cpp/cipher/XSalsa20Cipher.cpp +61 -0
  25. package/cpp/cipher/XSalsa20Cipher.hpp +33 -0
  26. package/cpp/ec/HybridEcKeyPair.cpp +428 -0
  27. package/cpp/ec/HybridEcKeyPair.hpp +48 -0
  28. package/cpp/ed25519/HybridEdKeyPair.cpp +228 -98
  29. package/cpp/ed25519/HybridEdKeyPair.hpp +42 -56
  30. package/cpp/hash/HybridHash.cpp +185 -0
  31. package/cpp/hash/HybridHash.hpp +43 -0
  32. package/cpp/hmac/HybridHmac.cpp +95 -0
  33. package/cpp/hmac/HybridHmac.hpp +31 -0
  34. package/cpp/keys/HybridKeyObjectHandle.cpp +749 -0
  35. package/cpp/keys/HybridKeyObjectHandle.hpp +51 -0
  36. package/cpp/keys/KeyObjectData.cpp +268 -0
  37. package/cpp/keys/KeyObjectData.hpp +71 -0
  38. package/cpp/keys/node.h +5 -0
  39. package/cpp/pbkdf2/HybridPbkdf2.cpp +34 -55
  40. package/cpp/pbkdf2/HybridPbkdf2.hpp +5 -16
  41. package/cpp/random/HybridRandom.cpp +6 -17
  42. package/cpp/random/HybridRandom.hpp +5 -6
  43. package/cpp/rsa/HybridRsaKeyPair.cpp +154 -0
  44. package/cpp/rsa/HybridRsaKeyPair.hpp +43 -0
  45. package/cpp/sign/HybridSignHandle.cpp +191 -0
  46. package/cpp/sign/HybridSignHandle.hpp +36 -0
  47. package/cpp/sign/HybridVerifyHandle.cpp +158 -0
  48. package/cpp/sign/HybridVerifyHandle.hpp +36 -0
  49. package/cpp/sign/SignUtils.hpp +108 -0
  50. package/cpp/utils/Macros.hpp +68 -0
  51. package/cpp/utils/Utils.hpp +43 -2
  52. package/cpp/utils/base64.h +309 -0
  53. package/deps/blake3/.cargo/config.toml +2 -0
  54. package/deps/blake3/.git-blame-ignore-revs +2 -0
  55. package/deps/blake3/.github/workflows/build_b3sum.py +38 -0
  56. package/deps/blake3/.github/workflows/ci.yml +491 -0
  57. package/deps/blake3/.github/workflows/tag.yml +43 -0
  58. package/deps/blake3/.github/workflows/upload_github_release_asset.py +73 -0
  59. package/deps/blake3/CONTRIBUTING.md +31 -0
  60. package/deps/blake3/Cargo.toml +135 -0
  61. package/deps/blake3/LICENSE_A2 +202 -0
  62. package/deps/blake3/LICENSE_A2LLVM +219 -0
  63. package/deps/blake3/LICENSE_CC0 +121 -0
  64. package/deps/blake3/README.md +229 -0
  65. package/deps/blake3/b3sum/Cargo.lock +513 -0
  66. package/deps/blake3/b3sum/Cargo.toml +26 -0
  67. package/deps/blake3/b3sum/README.md +72 -0
  68. package/deps/blake3/b3sum/src/main.rs +564 -0
  69. package/deps/blake3/b3sum/src/unit_tests.rs +235 -0
  70. package/deps/blake3/b3sum/tests/cli_tests.rs +680 -0
  71. package/deps/blake3/b3sum/what_does_check_do.md +176 -0
  72. package/deps/blake3/benches/bench.rs +623 -0
  73. package/deps/blake3/build.rs +389 -0
  74. package/deps/blake3/c/CMakeLists.txt +383 -0
  75. package/deps/blake3/c/CMakePresets.json +73 -0
  76. package/deps/blake3/c/Makefile.testing +82 -0
  77. package/deps/blake3/c/README.md +403 -0
  78. package/deps/blake3/c/blake3-config.cmake.in +14 -0
  79. package/deps/blake3/c/blake3.c +650 -0
  80. package/deps/blake3/c/blake3.h +86 -0
  81. package/deps/blake3/c/blake3_avx2.c +326 -0
  82. package/deps/blake3/c/blake3_avx2_x86-64_unix.S +1815 -0
  83. package/deps/blake3/c/blake3_avx2_x86-64_windows_gnu.S +1817 -0
  84. package/deps/blake3/c/blake3_avx2_x86-64_windows_msvc.asm +1828 -0
  85. package/deps/blake3/c/blake3_avx512.c +1388 -0
  86. package/deps/blake3/c/blake3_avx512_x86-64_unix.S +4824 -0
  87. package/deps/blake3/c/blake3_avx512_x86-64_windows_gnu.S +2615 -0
  88. package/deps/blake3/c/blake3_avx512_x86-64_windows_msvc.asm +2634 -0
  89. package/deps/blake3/c/blake3_c_rust_bindings/Cargo.toml +32 -0
  90. package/deps/blake3/c/blake3_c_rust_bindings/README.md +4 -0
  91. package/deps/blake3/c/blake3_c_rust_bindings/benches/bench.rs +477 -0
  92. package/deps/blake3/c/blake3_c_rust_bindings/build.rs +253 -0
  93. package/deps/blake3/c/blake3_c_rust_bindings/cross_test.sh +31 -0
  94. package/deps/blake3/c/blake3_c_rust_bindings/src/lib.rs +333 -0
  95. package/deps/blake3/c/blake3_c_rust_bindings/src/test.rs +696 -0
  96. package/deps/blake3/c/blake3_dispatch.c +332 -0
  97. package/deps/blake3/c/blake3_impl.h +333 -0
  98. package/deps/blake3/c/blake3_neon.c +366 -0
  99. package/deps/blake3/c/blake3_portable.c +160 -0
  100. package/deps/blake3/c/blake3_sse2.c +566 -0
  101. package/deps/blake3/c/blake3_sse2_x86-64_unix.S +2291 -0
  102. package/deps/blake3/c/blake3_sse2_x86-64_windows_gnu.S +2332 -0
  103. package/deps/blake3/c/blake3_sse2_x86-64_windows_msvc.asm +2350 -0
  104. package/deps/blake3/c/blake3_sse41.c +560 -0
  105. package/deps/blake3/c/blake3_sse41_x86-64_unix.S +2028 -0
  106. package/deps/blake3/c/blake3_sse41_x86-64_windows_gnu.S +2069 -0
  107. package/deps/blake3/c/blake3_sse41_x86-64_windows_msvc.asm +2089 -0
  108. package/deps/blake3/c/blake3_tbb.cpp +37 -0
  109. package/deps/blake3/c/dependencies/CMakeLists.txt +3 -0
  110. package/deps/blake3/c/dependencies/tbb/CMakeLists.txt +28 -0
  111. package/deps/blake3/c/example.c +36 -0
  112. package/deps/blake3/c/example_tbb.c +57 -0
  113. package/deps/blake3/c/libblake3.pc.in +12 -0
  114. package/deps/blake3/c/main.c +166 -0
  115. package/deps/blake3/c/test.py +97 -0
  116. package/deps/blake3/media/B3.svg +70 -0
  117. package/deps/blake3/media/BLAKE3.svg +85 -0
  118. package/deps/blake3/media/speed.svg +1474 -0
  119. package/deps/blake3/reference_impl/Cargo.toml +8 -0
  120. package/deps/blake3/reference_impl/README.md +14 -0
  121. package/deps/blake3/reference_impl/reference_impl.rs +374 -0
  122. package/deps/blake3/src/ffi_avx2.rs +65 -0
  123. package/deps/blake3/src/ffi_avx512.rs +169 -0
  124. package/deps/blake3/src/ffi_neon.rs +82 -0
  125. package/deps/blake3/src/ffi_sse2.rs +126 -0
  126. package/deps/blake3/src/ffi_sse41.rs +126 -0
  127. package/deps/blake3/src/guts.rs +60 -0
  128. package/deps/blake3/src/hazmat.rs +704 -0
  129. package/deps/blake3/src/io.rs +64 -0
  130. package/deps/blake3/src/join.rs +92 -0
  131. package/deps/blake3/src/lib.rs +1835 -0
  132. package/deps/blake3/src/platform.rs +587 -0
  133. package/deps/blake3/src/portable.rs +198 -0
  134. package/deps/blake3/src/rust_avx2.rs +474 -0
  135. package/deps/blake3/src/rust_sse2.rs +775 -0
  136. package/deps/blake3/src/rust_sse41.rs +766 -0
  137. package/deps/blake3/src/test.rs +1049 -0
  138. package/deps/blake3/src/traits.rs +227 -0
  139. package/deps/blake3/src/wasm32_simd.rs +794 -0
  140. package/deps/blake3/test_vectors/Cargo.toml +19 -0
  141. package/deps/blake3/test_vectors/cross_test.sh +25 -0
  142. package/deps/blake3/test_vectors/src/bin/generate.rs +4 -0
  143. package/deps/blake3/test_vectors/src/lib.rs +350 -0
  144. package/deps/blake3/test_vectors/test_vectors.json +217 -0
  145. package/deps/blake3/tools/compiler_version/Cargo.toml +7 -0
  146. package/deps/blake3/tools/compiler_version/build.rs +6 -0
  147. package/deps/blake3/tools/compiler_version/src/main.rs +27 -0
  148. package/deps/blake3/tools/instruction_set_support/Cargo.toml +6 -0
  149. package/deps/blake3/tools/instruction_set_support/src/main.rs +10 -0
  150. package/deps/blake3/tools/release.md +16 -0
  151. package/deps/fastpbkdf2/fastpbkdf2.c +5 -1
  152. package/deps/ncrypto/ncrypto.cc +4679 -0
  153. package/deps/ncrypto/ncrypto.h +1625 -0
  154. package/lib/commonjs/blake3.js +98 -0
  155. package/lib/commonjs/blake3.js.map +1 -0
  156. package/lib/commonjs/cipher.js +180 -0
  157. package/lib/commonjs/cipher.js.map +1 -0
  158. package/lib/commonjs/constants.js +32 -0
  159. package/lib/commonjs/constants.js.map +1 -0
  160. package/lib/commonjs/ec.js +480 -0
  161. package/lib/commonjs/ec.js.map +1 -0
  162. package/lib/commonjs/ed.js +214 -2
  163. package/lib/commonjs/ed.js.map +1 -1
  164. package/lib/commonjs/expo-plugin/@types.js +2 -0
  165. package/lib/commonjs/expo-plugin/@types.js.map +1 -0
  166. package/lib/commonjs/expo-plugin/withRNQC.js +25 -0
  167. package/lib/commonjs/expo-plugin/withRNQC.js.map +1 -0
  168. package/lib/commonjs/expo-plugin/withSodiumAndroid.js +25 -0
  169. package/lib/commonjs/expo-plugin/withSodiumAndroid.js.map +1 -0
  170. package/lib/commonjs/expo-plugin/withSodiumIos.js +26 -0
  171. package/lib/commonjs/expo-plugin/withSodiumIos.js.map +1 -0
  172. package/lib/commonjs/expo-plugin/withXCode.js +51 -0
  173. package/lib/commonjs/expo-plugin/withXCode.js.map +1 -0
  174. package/lib/commonjs/hash.js +215 -0
  175. package/lib/commonjs/hash.js.map +1 -0
  176. package/lib/commonjs/hmac.js +109 -0
  177. package/lib/commonjs/hmac.js.map +1 -0
  178. package/lib/commonjs/index.js +102 -24
  179. package/lib/commonjs/index.js.map +1 -1
  180. package/lib/commonjs/keys/classes.js +109 -52
  181. package/lib/commonjs/keys/classes.js.map +1 -1
  182. package/lib/commonjs/keys/generateKeyPair.js +141 -144
  183. package/lib/commonjs/keys/generateKeyPair.js.map +1 -1
  184. package/lib/commonjs/keys/index.js +229 -0
  185. package/lib/commonjs/keys/index.js.map +1 -1
  186. package/lib/commonjs/keys/publicCipher.js +152 -0
  187. package/lib/commonjs/keys/publicCipher.js.map +1 -0
  188. package/lib/commonjs/keys/signVerify.js +178 -39
  189. package/lib/commonjs/keys/signVerify.js.map +1 -1
  190. package/lib/commonjs/keys/utils.js +18 -13
  191. package/lib/commonjs/keys/utils.js.map +1 -1
  192. package/lib/commonjs/pbkdf2.js.map +1 -1
  193. package/lib/commonjs/random.js +6 -0
  194. package/lib/commonjs/random.js.map +1 -1
  195. package/lib/commonjs/rsa.js +202 -0
  196. package/lib/commonjs/rsa.js.map +1 -0
  197. package/lib/commonjs/specs/blake3.nitro.js +6 -0
  198. package/lib/commonjs/specs/blake3.nitro.js.map +1 -0
  199. package/lib/commonjs/specs/cipher.nitro.js +6 -0
  200. package/lib/commonjs/specs/cipher.nitro.js.map +1 -0
  201. package/lib/commonjs/specs/ecKeyPair.nitro.js +6 -0
  202. package/lib/commonjs/specs/ecKeyPair.nitro.js.map +1 -0
  203. package/lib/commonjs/specs/hash.nitro.js +6 -0
  204. package/lib/commonjs/specs/hash.nitro.js.map +1 -0
  205. package/lib/commonjs/specs/hmac.nitro.js +6 -0
  206. package/lib/commonjs/specs/hmac.nitro.js.map +1 -0
  207. package/lib/commonjs/specs/rsaCipher.nitro.js +6 -0
  208. package/lib/commonjs/specs/rsaCipher.nitro.js.map +1 -0
  209. package/lib/commonjs/specs/rsaKeyPair.nitro.js +6 -0
  210. package/lib/commonjs/specs/rsaKeyPair.nitro.js.map +1 -0
  211. package/lib/commonjs/specs/sign.nitro.js +6 -0
  212. package/lib/commonjs/specs/sign.nitro.js.map +1 -0
  213. package/lib/commonjs/subtle.js +987 -0
  214. package/lib/commonjs/subtle.js.map +1 -0
  215. package/lib/commonjs/utils/cipher.js +64 -0
  216. package/lib/commonjs/utils/cipher.js.map +1 -0
  217. package/lib/commonjs/utils/conversion.js +44 -5
  218. package/lib/commonjs/utils/conversion.js.map +1 -1
  219. package/lib/commonjs/utils/hashnames.js +2 -1
  220. package/lib/commonjs/utils/hashnames.js.map +1 -1
  221. package/lib/commonjs/utils/index.js +11 -0
  222. package/lib/commonjs/utils/index.js.map +1 -1
  223. package/lib/commonjs/utils/noble.js +82 -0
  224. package/lib/commonjs/utils/noble.js.map +1 -0
  225. package/lib/commonjs/utils/types.js +32 -17
  226. package/lib/commonjs/utils/types.js.map +1 -1
  227. package/lib/commonjs/utils/validation.js +74 -1
  228. package/lib/commonjs/utils/validation.js.map +1 -1
  229. package/lib/module/blake3.js +90 -0
  230. package/lib/module/blake3.js.map +1 -0
  231. package/lib/module/cipher.js +173 -0
  232. package/lib/module/cipher.js.map +1 -0
  233. package/lib/module/constants.js +28 -0
  234. package/lib/module/constants.js.map +1 -0
  235. package/lib/module/ec.js +470 -0
  236. package/lib/module/ec.js.map +1 -0
  237. package/lib/module/ed.js +212 -3
  238. package/lib/module/ed.js.map +1 -1
  239. package/lib/module/expo-plugin/@types.js +2 -0
  240. package/lib/module/expo-plugin/@types.js.map +1 -0
  241. package/lib/module/expo-plugin/withRNQC.js +21 -0
  242. package/lib/module/expo-plugin/withRNQC.js.map +1 -0
  243. package/lib/module/expo-plugin/withSodiumAndroid.js +20 -0
  244. package/lib/module/expo-plugin/withSodiumAndroid.js.map +1 -0
  245. package/lib/module/expo-plugin/withSodiumIos.js +20 -0
  246. package/lib/module/expo-plugin/withSodiumIos.js.map +1 -0
  247. package/lib/module/expo-plugin/withXCode.js +46 -0
  248. package/lib/module/expo-plugin/withXCode.js.map +1 -0
  249. package/lib/module/hash.js +207 -0
  250. package/lib/module/hash.js.map +1 -0
  251. package/lib/module/hmac.js +104 -0
  252. package/lib/module/hmac.js.map +1 -0
  253. package/lib/module/index.js +21 -21
  254. package/lib/module/index.js.map +1 -1
  255. package/lib/module/keys/classes.js +106 -49
  256. package/lib/module/keys/classes.js.map +1 -1
  257. package/lib/module/keys/generateKeyPair.js +134 -143
  258. package/lib/module/keys/generateKeyPair.js.map +1 -1
  259. package/lib/module/keys/index.js +161 -22
  260. package/lib/module/keys/index.js.map +1 -1
  261. package/lib/module/keys/publicCipher.js +145 -0
  262. package/lib/module/keys/publicCipher.js.map +1 -0
  263. package/lib/module/keys/signVerify.js +170 -39
  264. package/lib/module/keys/signVerify.js.map +1 -1
  265. package/lib/module/keys/utils.js +16 -12
  266. package/lib/module/keys/utils.js.map +1 -1
  267. package/lib/module/pbkdf2.js.map +1 -1
  268. package/lib/module/random.js +6 -0
  269. package/lib/module/random.js.map +1 -1
  270. package/lib/module/rsa.js +194 -0
  271. package/lib/module/rsa.js.map +1 -0
  272. package/lib/module/specs/blake3.nitro.js +4 -0
  273. package/lib/module/specs/blake3.nitro.js.map +1 -0
  274. package/lib/module/specs/cipher.nitro.js +4 -0
  275. package/lib/module/specs/cipher.nitro.js.map +1 -0
  276. package/lib/module/specs/ecKeyPair.nitro.js +4 -0
  277. package/lib/module/specs/ecKeyPair.nitro.js.map +1 -0
  278. package/lib/module/specs/hash.nitro.js +4 -0
  279. package/lib/module/specs/hash.nitro.js.map +1 -0
  280. package/lib/module/specs/hmac.nitro.js +4 -0
  281. package/lib/module/specs/hmac.nitro.js.map +1 -0
  282. package/lib/module/specs/rsaCipher.nitro.js +4 -0
  283. package/lib/module/specs/rsaCipher.nitro.js.map +1 -0
  284. package/lib/module/specs/rsaKeyPair.nitro.js +4 -0
  285. package/lib/module/specs/rsaKeyPair.nitro.js.map +1 -0
  286. package/lib/module/specs/sign.nitro.js +4 -0
  287. package/lib/module/specs/sign.nitro.js.map +1 -0
  288. package/lib/module/subtle.js +982 -0
  289. package/lib/module/subtle.js.map +1 -0
  290. package/lib/module/utils/cipher.js +56 -0
  291. package/lib/module/utils/cipher.js.map +1 -0
  292. package/lib/module/utils/conversion.js +26 -5
  293. package/lib/module/utils/conversion.js.map +1 -1
  294. package/lib/module/utils/hashnames.js +2 -1
  295. package/lib/module/utils/hashnames.js.map +1 -1
  296. package/lib/module/utils/index.js +1 -0
  297. package/lib/module/utils/index.js.map +1 -1
  298. package/lib/module/utils/noble.js +76 -0
  299. package/lib/module/utils/noble.js.map +1 -0
  300. package/lib/module/utils/types.js +32 -17
  301. package/lib/module/utils/types.js.map +1 -1
  302. package/lib/module/utils/validation.js +69 -1
  303. package/lib/module/utils/validation.js.map +1 -1
  304. package/lib/tsconfig.tsbuildinfo +1 -1
  305. package/lib/typescript/blake3.d.ts +33 -0
  306. package/lib/typescript/blake3.d.ts.map +1 -0
  307. package/lib/typescript/cipher.d.ts +60 -0
  308. package/lib/typescript/cipher.d.ts.map +1 -0
  309. package/lib/typescript/constants.d.ts +21 -0
  310. package/lib/typescript/constants.d.ts.map +1 -0
  311. package/lib/typescript/ec.d.ts +22 -0
  312. package/lib/typescript/ec.d.ts.map +1 -0
  313. package/lib/typescript/ed.d.ts +28 -1
  314. package/lib/typescript/ed.d.ts.map +1 -1
  315. package/lib/typescript/expo-plugin/@types.d.ts +8 -0
  316. package/lib/typescript/expo-plugin/@types.d.ts.map +1 -0
  317. package/lib/typescript/expo-plugin/withRNQC.d.ts +4 -0
  318. package/lib/typescript/expo-plugin/withRNQC.d.ts.map +1 -0
  319. package/lib/typescript/expo-plugin/withSodiumAndroid.d.ts +4 -0
  320. package/lib/typescript/expo-plugin/withSodiumAndroid.d.ts.map +1 -0
  321. package/lib/typescript/expo-plugin/withSodiumIos.d.ts +4 -0
  322. package/lib/typescript/expo-plugin/withSodiumIos.d.ts.map +1 -0
  323. package/lib/typescript/expo-plugin/withXCode.d.ts +9 -0
  324. package/lib/typescript/expo-plugin/withXCode.d.ts.map +1 -0
  325. package/lib/typescript/hash.d.ts +122 -0
  326. package/lib/typescript/hash.d.ts.map +1 -0
  327. package/lib/typescript/hmac.d.ts +66 -0
  328. package/lib/typescript/hmac.d.ts.map +1 -0
  329. package/lib/typescript/index.d.ts +102 -10
  330. package/lib/typescript/index.d.ts.map +1 -1
  331. package/lib/typescript/keys/classes.d.ts +50 -8
  332. package/lib/typescript/keys/classes.d.ts.map +1 -1
  333. package/lib/typescript/keys/generateKeyPair.d.ts +5 -0
  334. package/lib/typescript/keys/generateKeyPair.d.ts.map +1 -1
  335. package/lib/typescript/keys/index.d.ts +22 -2
  336. package/lib/typescript/keys/index.d.ts.map +1 -1
  337. package/lib/typescript/keys/publicCipher.d.ts +20 -0
  338. package/lib/typescript/keys/publicCipher.d.ts.map +1 -0
  339. package/lib/typescript/keys/signVerify.d.ts +28 -0
  340. package/lib/typescript/keys/signVerify.d.ts.map +1 -1
  341. package/lib/typescript/keys/utils.d.ts +3 -1
  342. package/lib/typescript/keys/utils.d.ts.map +1 -1
  343. package/lib/typescript/pbkdf2.d.ts +1 -1
  344. package/lib/typescript/pbkdf2.d.ts.map +1 -1
  345. package/lib/typescript/random.d.ts +6 -0
  346. package/lib/typescript/random.d.ts.map +1 -1
  347. package/lib/typescript/rsa.d.ts +19 -0
  348. package/lib/typescript/rsa.d.ts.map +1 -0
  349. package/lib/typescript/specs/blake3.nitro.d.ts +15 -0
  350. package/lib/typescript/specs/blake3.nitro.d.ts.map +1 -0
  351. package/lib/typescript/specs/cipher.nitro.d.ts +29 -0
  352. package/lib/typescript/specs/cipher.nitro.d.ts.map +1 -0
  353. package/lib/typescript/specs/ecKeyPair.nitro.d.ts +20 -0
  354. package/lib/typescript/specs/ecKeyPair.nitro.d.ts.map +1 -0
  355. package/lib/typescript/specs/edKeyPair.nitro.d.ts +1 -0
  356. package/lib/typescript/specs/edKeyPair.nitro.d.ts.map +1 -1
  357. package/lib/typescript/specs/hash.nitro.d.ts +13 -0
  358. package/lib/typescript/specs/hash.nitro.d.ts.map +1 -0
  359. package/lib/typescript/specs/hmac.nitro.d.ts +10 -0
  360. package/lib/typescript/specs/hmac.nitro.d.ts.map +1 -0
  361. package/lib/typescript/specs/keyObjectHandle.nitro.d.ts +1 -1
  362. package/lib/typescript/specs/keyObjectHandle.nitro.d.ts.map +1 -1
  363. package/lib/typescript/specs/rsaCipher.nitro.d.ts +44 -0
  364. package/lib/typescript/specs/rsaCipher.nitro.d.ts.map +1 -0
  365. package/lib/typescript/specs/rsaKeyPair.nitro.d.ts +20 -0
  366. package/lib/typescript/specs/rsaKeyPair.nitro.d.ts.map +1 -0
  367. package/lib/typescript/specs/sign.nitro.d.ts +19 -0
  368. package/lib/typescript/specs/sign.nitro.d.ts.map +1 -0
  369. package/lib/typescript/subtle.d.ts +17 -0
  370. package/lib/typescript/subtle.d.ts.map +1 -0
  371. package/lib/typescript/utils/cipher.d.ts +7 -0
  372. package/lib/typescript/utils/cipher.d.ts.map +1 -0
  373. package/lib/typescript/utils/conversion.d.ts +1 -0
  374. package/lib/typescript/utils/conversion.d.ts.map +1 -1
  375. package/lib/typescript/utils/hashnames.d.ts +3 -1
  376. package/lib/typescript/utils/hashnames.d.ts.map +1 -1
  377. package/lib/typescript/utils/index.d.ts +1 -0
  378. package/lib/typescript/utils/index.d.ts.map +1 -1
  379. package/lib/typescript/utils/noble.d.ts +19 -0
  380. package/lib/typescript/utils/noble.d.ts.map +1 -0
  381. package/lib/typescript/utils/types.d.ts +125 -23
  382. package/lib/typescript/utils/types.d.ts.map +1 -1
  383. package/lib/typescript/utils/validation.d.ts +5 -0
  384. package/lib/typescript/utils/validation.d.ts.map +1 -1
  385. package/nitrogen/generated/.gitattributes +1 -0
  386. package/nitrogen/generated/android/QuickCrypto+autolinking.cmake +30 -1
  387. package/nitrogen/generated/android/QuickCrypto+autolinking.gradle +1 -1
  388. package/nitrogen/generated/android/QuickCryptoOnLoad.cpp +115 -1
  389. package/nitrogen/generated/android/QuickCryptoOnLoad.hpp +1 -1
  390. package/nitrogen/generated/android/kotlin/com/margelo/nitro/crypto/QuickCryptoOnLoad.kt +35 -0
  391. package/nitrogen/generated/ios/QuickCrypto+autolinking.rb +3 -1
  392. package/nitrogen/generated/ios/QuickCrypto-Swift-Cxx-Bridge.cpp +1 -1
  393. package/nitrogen/generated/ios/QuickCrypto-Swift-Cxx-Bridge.hpp +1 -1
  394. package/nitrogen/generated/ios/QuickCrypto-Swift-Cxx-Umbrella.hpp +3 -3
  395. package/nitrogen/generated/ios/QuickCryptoAutolinking.mm +111 -1
  396. package/nitrogen/generated/ios/QuickCryptoAutolinking.swift +1 -1
  397. package/nitrogen/generated/shared/c++/AsymmetricKeyType.hpp +104 -0
  398. package/nitrogen/generated/shared/c++/CipherArgs.hpp +86 -0
  399. package/nitrogen/generated/shared/c++/HybridBlake3Spec.cpp +28 -0
  400. package/nitrogen/generated/shared/c++/HybridBlake3Spec.hpp +76 -0
  401. package/nitrogen/generated/shared/c++/HybridCipherFactorySpec.cpp +21 -0
  402. package/nitrogen/generated/shared/c++/HybridCipherFactorySpec.hpp +67 -0
  403. package/nitrogen/generated/shared/c++/HybridCipherSpec.cpp +28 -0
  404. package/nitrogen/generated/shared/c++/HybridCipherSpec.hpp +76 -0
  405. package/nitrogen/generated/shared/c++/HybridEcKeyPairSpec.cpp +29 -0
  406. package/nitrogen/generated/shared/c++/HybridEcKeyPairSpec.hpp +77 -0
  407. package/nitrogen/generated/shared/c++/HybridEdKeyPairSpec.cpp +2 -1
  408. package/nitrogen/generated/shared/c++/HybridEdKeyPairSpec.hpp +5 -4
  409. package/nitrogen/generated/shared/c++/HybridHashSpec.cpp +26 -0
  410. package/nitrogen/generated/shared/c++/HybridHashSpec.hpp +75 -0
  411. package/nitrogen/generated/shared/c++/HybridHmacSpec.cpp +23 -0
  412. package/nitrogen/generated/shared/c++/HybridHmacSpec.hpp +66 -0
  413. package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.cpp +1 -1
  414. package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.hpp +8 -8
  415. package/nitrogen/generated/shared/c++/HybridPbkdf2Spec.cpp +1 -1
  416. package/nitrogen/generated/shared/c++/HybridPbkdf2Spec.hpp +3 -3
  417. package/nitrogen/generated/shared/c++/HybridRandomSpec.cpp +1 -1
  418. package/nitrogen/generated/shared/c++/HybridRandomSpec.hpp +3 -3
  419. package/nitrogen/generated/shared/c++/HybridRsaCipherSpec.cpp +24 -0
  420. package/nitrogen/generated/shared/c++/HybridRsaCipherSpec.hpp +72 -0
  421. package/nitrogen/generated/shared/c++/HybridRsaKeyPairSpec.cpp +29 -0
  422. package/nitrogen/generated/shared/c++/HybridRsaKeyPairSpec.hpp +77 -0
  423. package/nitrogen/generated/shared/c++/HybridSignHandleSpec.cpp +23 -0
  424. package/nitrogen/generated/shared/c++/HybridSignHandleSpec.hpp +71 -0
  425. package/nitrogen/generated/shared/c++/HybridVerifyHandleSpec.cpp +23 -0
  426. package/nitrogen/generated/shared/c++/HybridVerifyHandleSpec.hpp +71 -0
  427. package/nitrogen/generated/shared/c++/JWK.hpp +17 -18
  428. package/nitrogen/generated/shared/c++/JWKkty.hpp +12 -14
  429. package/nitrogen/generated/shared/c++/JWKuse.hpp +8 -10
  430. package/nitrogen/generated/shared/c++/KFormatType.hpp +14 -16
  431. package/nitrogen/generated/shared/c++/KeyDetail.hpp +6 -7
  432. package/nitrogen/generated/shared/c++/KeyEncoding.hpp +15 -17
  433. package/nitrogen/generated/shared/c++/KeyObject.hpp +67 -0
  434. package/nitrogen/generated/shared/c++/KeyType.hpp +11 -13
  435. package/nitrogen/generated/shared/c++/KeyUsage.hpp +38 -24
  436. package/nitrogen/generated/shared/c++/NamedCurve.hpp +10 -12
  437. package/package.json +28 -23
  438. package/src/blake3.ts +123 -0
  439. package/src/cipher.ts +335 -0
  440. package/src/constants.ts +32 -0
  441. package/src/ec.ts +657 -0
  442. package/src/ed.ts +297 -13
  443. package/src/expo-plugin/@types.ts +7 -0
  444. package/src/expo-plugin/withRNQC.ts +23 -0
  445. package/src/expo-plugin/withSodiumAndroid.ts +24 -0
  446. package/src/expo-plugin/withSodiumIos.ts +30 -0
  447. package/src/expo-plugin/withXCode.ts +55 -0
  448. package/src/hash.ts +274 -0
  449. package/src/hmac.ts +135 -0
  450. package/src/index.ts +20 -20
  451. package/src/keys/classes.ts +148 -55
  452. package/src/keys/generateKeyPair.ts +177 -134
  453. package/src/keys/index.ts +226 -14
  454. package/src/keys/publicCipher.ts +229 -0
  455. package/src/keys/signVerify.ts +239 -39
  456. package/src/keys/utils.ts +24 -18
  457. package/src/pbkdf2.ts +1 -1
  458. package/src/random.ts +7 -0
  459. package/src/rsa.ts +310 -0
  460. package/src/specs/blake3.nitro.ts +12 -0
  461. package/src/specs/cipher.nitro.ts +25 -0
  462. package/src/specs/ecKeyPair.nitro.ts +38 -0
  463. package/src/specs/edKeyPair.nitro.ts +2 -0
  464. package/src/specs/hash.nitro.ts +10 -0
  465. package/src/specs/hmac.nitro.ts +7 -0
  466. package/src/specs/keyObjectHandle.nitro.ts +1 -1
  467. package/src/specs/rsaCipher.nitro.ts +65 -0
  468. package/src/specs/rsaKeyPair.nitro.ts +33 -0
  469. package/src/specs/sign.nitro.ts +31 -0
  470. package/src/subtle.ts +1436 -0
  471. package/src/utils/cipher.ts +60 -0
  472. package/src/utils/conversion.ts +33 -4
  473. package/src/utils/hashnames.ts +4 -2
  474. package/src/utils/index.ts +1 -0
  475. package/src/utils/noble.ts +85 -0
  476. package/src/utils/types.ts +209 -29
  477. package/src/utils/validation.ts +96 -1
  478. package/lib/module/package.json +0 -1
  479. package/nitrogen/generated/android/QuickCryptoOnLoad.kt +0 -1
  480. package/nitrogen/generated/shared/c++/CFRGKeyPairType.hpp +0 -86
@@ -0,0 +1 @@
1
+ {"version":3,"names":["Buffer","SBuffer","KFormatType","KeyEncoding","CryptoKey","KeyObject","PublicKeyObject","PrivateKeyObject","SecretKeyObject","bufferLikeToArrayBuffer","lazyDOMException","normalizeHashName","HashContext","validateMaxBufferLength","asyncDigest","createSecretKey","NitroModules","pbkdf2DeriveBits","ecImportKey","ecdsaSignVerify","ec_generateKeyPair","rsa_generateKeyPair","getRandomValues","createHmac","createSign","createVerify","ed_generateKeyPairWebCrypto","Ed","KWebCryptoKeyFormat","CipherOrWrapMode","hasAnyNotIn","usages","allowed","some","usage","includes","normalizeAlgorithm","algorithm","_operation","name","getAlgorithmName","length","ecExportKey","key","format","keyObject","kWebCryptoKeyFormatSPKI","exported","export","type","kWebCryptoKeyFormatPKCS8","Error","rsaExportKey","rsaCipher","mode","data","rsaParams","expectedType","kWebCryptoCipherEncrypt","hashAlgorithm","hash","label","undefined","rsaCipherModule","createHybridObject","RSA_PKCS1_OAEP_PADDING","encrypt","handle","decrypt","aesCipher","aesCtrCipher","aesCbcCipher","aesGcmCipher","counter","byteLength","keyLength","cipherType","factory","cipher","createCipher","isCipher","cipherKey","iv","updated","update","final","result","Uint8Array","set","buffer","tagLength","validTagLengths","tagByteLength","authTagLen","processData","authTag","kWebCryptoCipherDecrypt","dataView","ciphertextLength","slice","setAuthTag","additionalData","setAAD","tag","getAuthTag","aesGenerateKey","extractable","keyUsages","validUsages","keyBytes","keyAlgorithm","hmacGenerateKey","hashName","Math","ceil","rsaImportKey","checkSet","jwk","kty","keyType","initJwk","keyData","createKeyObject","DER","SPKI","PKCS8","keyDetails","asymmetricKeyDetails","publicExponentBytes","publicExponent","exp","bytes","value","unshift","floor","algorithmWithDetails","modulusLength","hmacImportKey","k","decoded","from","keyBitLength","aesImportKey","actualLength","edImportKey","init","exportKeySpki","exportKey","exportKeyPkcs8","exportKeyRaw","kWebCryptoKeyFormatRaw","byteOffset","exportKeyJWK","exportJwk","key_ops","ext","alg","JwkRsa","JwkRsaPss","JwkRsaOaep","JwkHmac","crv","namedCurve","importGenericSecretKey","checkLength","isBuffer","checkCryptoKeyPairUsages","pair","privateKey","isCryptoKeyPair","hmacSignVerify","signature","hmac","computed","digest","sigBytes","computedBytes","i","rsaSignVerify","padding","saltLength","RSA_PKCS1_PADDING","RSA_PKCS1_PSS_PADDING","paddingValue","signer","sig","sign","verifier","verify","edSignVerify","isSign","expectedKeyType","algorithmName","curveType","toLowerCase","ed","rawKey","dataBuffer","signSync","signatureBuffer","verifySync","signVerify","cipherOrWrap","op","Subtle","normalizedAlgorithm","deriveBits","baseKey","generateKey","importKey","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":[]}
@@ -2,6 +2,8 @@
2
2
 
3
3
  import { Buffer as CraftzdogBuffer } from '@craftzdog/react-native-buffer';
4
4
  import { Buffer as SafeBuffer } from 'safe-buffer';
5
+ import { KeyObject } from '../keys/classes';
6
+
5
7
  /**
6
8
  * Converts supplied argument to an ArrayBuffer. Note this does not copy the
7
9
  * data so it is faster than toArrayBuffer. Not copying is important for
@@ -50,8 +52,24 @@ export function bufferLikeToArrayBuffer(buf) {
50
52
  if (ArrayBuffer.isView(buf)) {
51
53
  return toArrayBuffer(buf);
52
54
  }
53
- // ArrayBuffer
54
- return buf;
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.');
55
73
  }
56
74
  export function binaryLikeToArrayBuffer(input,
57
75
  // CipherKey adds compat with node types
@@ -96,12 +114,15 @@ encoding = 'utf-8') {
96
114
  // }
97
115
  // }
98
116
 
99
- // TODO: handle if input is KeyObject?
100
-
101
- throw new Error('input could not be converted to ArrayBuffer');
117
+ // KeyObject
118
+ if (input instanceof KeyObject) {
119
+ return input.handle.exportKey();
120
+ }
121
+ throw new Error('Invalid argument type for "key". Need ArrayBuffer, TypedArray, KeyObject, CryptoKey, string');
102
122
  }
103
123
  export function ab2str(buf, encoding = 'hex') {
104
124
  return CraftzdogBuffer.from(buf).toString(encoding);
105
125
  }
106
126
  export const kEmptyObject = Object.freeze(Object.create(null));
127
+ export * from './noble';
107
128
  //# sourceMappingURL=conversion.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["Buffer","CraftzdogBuffer","SafeBuffer","abvToArrayBuffer","buf","isBuffer","buffer","ArrayBuffer","isView","toArrayBuffer","slice","byteOffset","byteLength","ab","length","view","Uint8Array","i","readUInt8","bufferLikeToArrayBuffer","binaryLikeToArrayBuffer","input","encoding","Error","from","ab2str","toString","kEmptyObject","Object","freeze","create"],"sourceRoot":"../../../src","sources":["utils/conversion.ts"],"mappings":"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","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":[]}
@@ -74,7 +74,8 @@ const kHashNames = {
74
74
  }
75
75
  export function normalizeHashName(algo, context = HashContext.Node) {
76
76
  if (typeof algo !== 'undefined') {
77
- const normAlgo = algo.toString().toLowerCase();
77
+ const hashName = typeof algo === 'string' ? algo : algo.name || algo.toString();
78
+ const normAlgo = hashName.toLowerCase();
78
79
  try {
79
80
  const alias = kHashNames[normAlgo][context];
80
81
  if (alias) return alias;
@@ -1 +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","normAlgo","toString","_e","Error"],"sourceRoot":"../../../src","sources":["utils/hashnames.ts"],"mappings":"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","ignoreList":[]}
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":[]}
@@ -5,4 +5,5 @@ export * from './errors';
5
5
  export * from './hashnames';
6
6
  export * from './types';
7
7
  export * from './validation';
8
+ export * from './cipher';
8
9
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
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","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":[]}
@@ -2,32 +2,41 @@
2
2
 
3
3
  // @types/node
4
4
 
5
- // On node this value is defined on the native side, for now I'm just creating it here in JS
6
- // TODO(osp) move this into native side to make sure they always match
5
+ // Node.js style key pair types (lowercase)
6
+
7
+ // TODO: These enums need to be defined on the native side
7
8
  export let KFormatType = /*#__PURE__*/function (KFormatType) {
8
- KFormatType[KFormatType["kKeyFormatDER"] = 0] = "kKeyFormatDER";
9
- KFormatType[KFormatType["kKeyFormatPEM"] = 1] = "kKeyFormatPEM";
10
- KFormatType[KFormatType["kKeyFormatJWK"] = 2] = "kKeyFormatJWK";
9
+ KFormatType[KFormatType["DER"] = 0] = "DER";
10
+ KFormatType[KFormatType["PEM"] = 1] = "PEM";
11
+ KFormatType[KFormatType["JWK"] = 2] = "JWK";
11
12
  return KFormatType;
12
13
  }({});
13
-
14
- // Same as KFormatType, this enum needs to be defined on the native side
15
14
  export let KeyType = /*#__PURE__*/function (KeyType) {
16
- KeyType[KeyType["Secret"] = 0] = "Secret";
17
- KeyType[KeyType["Public"] = 1] = "Public";
18
- KeyType[KeyType["Private"] = 2] = "Private";
15
+ KeyType[KeyType["SECRET"] = 0] = "SECRET";
16
+ KeyType[KeyType["PUBLIC"] = 1] = "PUBLIC";
17
+ KeyType[KeyType["PRIVATE"] = 2] = "PRIVATE";
19
18
  return KeyType;
20
19
  }({});
21
20
  export let KeyEncoding = /*#__PURE__*/function (KeyEncoding) {
22
- KeyEncoding[KeyEncoding["kKeyEncodingPKCS1"] = 0] = "kKeyEncodingPKCS1";
23
- KeyEncoding[KeyEncoding["kKeyEncodingPKCS8"] = 1] = "kKeyEncodingPKCS8";
24
- KeyEncoding[KeyEncoding["kKeyEncodingSPKI"] = 2] = "kKeyEncodingSPKI";
25
- KeyEncoding[KeyEncoding["kKeyEncodingSEC1"] = 3] = "kKeyEncodingSEC1";
21
+ KeyEncoding[KeyEncoding["PKCS1"] = 0] = "PKCS1";
22
+ KeyEncoding[KeyEncoding["PKCS8"] = 1] = "PKCS8";
23
+ KeyEncoding[KeyEncoding["SPKI"] = 2] = "SPKI";
24
+ KeyEncoding[KeyEncoding["SEC1"] = 3] = "SEC1";
26
25
  return KeyEncoding;
27
26
  }({});
28
-
29
- // Note: removed CryptoKey class from this type (from 0.x) because Nitro doesn't
30
- // handle custom JS objects. We might need to make it a JS object.
27
+ export let KeyFormat = /*#__PURE__*/function (KeyFormat) {
28
+ KeyFormat[KeyFormat["RAW"] = 0] = "RAW";
29
+ KeyFormat[KeyFormat["PKCS8"] = 1] = "PKCS8";
30
+ KeyFormat[KeyFormat["SPKI"] = 2] = "SPKI";
31
+ KeyFormat[KeyFormat["JWK"] = 3] = "JWK";
32
+ return KeyFormat;
33
+ }({});
34
+ export const kNamedCurveAliases = {
35
+ 'P-256': 'prime256v1',
36
+ 'P-384': 'secp384r1',
37
+ 'P-521': 'secp521r1'
38
+ };
39
+ // end TODO
31
40
 
32
41
  export let KeyVariant = /*#__PURE__*/function (KeyVariant) {
33
42
  KeyVariant[KeyVariant["RSA_SSA_PKCS1_v1_5"] = 0] = "RSA_SSA_PKCS1_v1_5";
@@ -39,4 +48,10 @@ export let KeyVariant = /*#__PURE__*/function (KeyVariant) {
39
48
  KeyVariant[KeyVariant["DH"] = 6] = "DH";
40
49
  return KeyVariant;
41
50
  }({});
51
+
52
+ // These are for shortcomings in @types/node
53
+ // Here we use "*Type" instead of "*Types" like node does.
54
+ // export type CipherCBCType = 'aes-128-cbc' | 'aes-192-cbc' | 'aes-256-cbc';
55
+
56
+ // from @paulmillr/noble-curves
42
57
  //# sourceMappingURL=types.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["KFormatType","KeyType","KeyEncoding","KeyVariant"],"sourceRoot":"../../../src","sources":["utils/types.ts"],"mappings":";;AAEyC;;AAiHzC;AACA;AACA,WAAYA,WAAW,0BAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAA,OAAXA,WAAW;AAAA;;AAMvB;AACA,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;;AAwGvB;AACA;;AA2BA,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","ignoreList":[]}
1
+ {"version":3,"names":["KFormatType","KeyType","KeyEncoding","KeyFormat","kNamedCurveAliases","KeyVariant"],"sourceRoot":"../../../src","sources":["utils/types.ts"],"mappings":";;AAE8C;;AAiE9C;;AA+HA;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;;AAyIA,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":[]}
@@ -1,5 +1,10 @@
1
1
  "use strict";
2
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;
3
8
  export function validateFunction(f) {
4
9
  return f !== null && typeof f === 'function';
5
10
  }
@@ -12,8 +17,71 @@ export function validateObject(value, name, options) {
12
17
  const allowFunction = useDefaultOptions ? false : options.allowFunction;
13
18
  const nullable = useDefaultOptions ? false : options.nullable;
14
19
  if (!nullable && value === null || !allowArray && Array.isArray(value) || typeof value !== 'object' && (!allowFunction || typeof value !== 'function')) {
15
- throw new Error(`${name} is not a valid object $${value}`);
20
+ throw new Error(`${name} is not a valid object ${value}`);
16
21
  }
17
22
  return true;
18
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
+ }
19
87
  //# sourceMappingURL=validation.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["validateFunction","f","isStringOrBuffer","val","ArrayBuffer","isView","validateObject","value","name","options","useDefaultOptions","allowArray","allowFunction","nullable","Array","isArray","Error"],"sourceRoot":"../../../src","sources":["utils/validation.ts"],"mappings":";;AAAA,OAAO,SAASA,gBAAgBA,CAACC,CAAU,EAAW;EACpD,OAAOA,CAAC,KAAK,IAAI,IAAI,OAAOA,CAAC,KAAK,UAAU;AAC9C;AAEA,OAAO,SAASC,gBAAgBA,CAACC,GAAY,EAA+B;EAC1E,OACE,OAAOA,GAAG,KAAK,QAAQ,IACvBC,WAAW,CAACC,MAAM,CAACF,GAAG,CAAC,IACvBA,GAAG,YAAYC,WAAW;AAE9B;AAEA,OAAO,SAASE,cAAcA,CAC5BC,KAAc,EACdC,IAAY,EACZC,OAIQ,EACI;EACZ,MAAMC,iBAAiB,GAAGD,OAAO,IAAI,IAAI;EACzC,MAAME,UAAU,GAAGD,iBAAiB,GAAG,KAAK,GAAGD,OAAO,CAACE,UAAU;EACjE,MAAMC,aAAa,GAAGF,iBAAiB,GAAG,KAAK,GAAGD,OAAO,CAACG,aAAa;EACvE,MAAMC,QAAQ,GAAGH,iBAAiB,GAAG,KAAK,GAAGD,OAAO,CAACI,QAAQ;EAC7D,IACG,CAACA,QAAQ,IAAIN,KAAK,KAAK,IAAI,IAC3B,CAACI,UAAU,IAAIG,KAAK,CAACC,OAAO,CAACR,KAAK,CAAE,IACpC,OAAOA,KAAK,KAAK,QAAQ,KACvB,CAACK,aAAa,IAAI,OAAOL,KAAK,KAAK,UAAU,CAAE,EAClD;IACA,MAAM,IAAIS,KAAK,CAAC,GAAGR,IAAI,2BAA2BD,KAAK,EAAE,CAAC;EAC5D;EACA,OAAO,IAAI;AACb","ignoreList":[]}
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":[]}