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.
- package/QuickCrypto.podspec +143 -7
- package/README.md +12 -6
- package/android/CMakeLists.txt +82 -21
- package/android/build.gradle +47 -4
- package/android/src/main/cpp/cpp-adapter.cpp +3 -10
- package/android/src/main/java/com/margelo/nitro/quickcrypto/QuickCryptoPackage.java +13 -10
- package/app.plugin.js +3 -0
- package/cpp/blake3/HybridBlake3.cpp +118 -0
- package/cpp/blake3/HybridBlake3.hpp +35 -0
- package/cpp/cipher/CCMCipher.cpp +199 -0
- package/cpp/cipher/CCMCipher.hpp +26 -0
- package/cpp/cipher/ChaCha20Cipher.cpp +97 -0
- package/cpp/cipher/ChaCha20Cipher.hpp +25 -0
- package/cpp/cipher/ChaCha20Poly1305Cipher.cpp +170 -0
- package/cpp/cipher/ChaCha20Poly1305Cipher.hpp +30 -0
- package/cpp/cipher/HybridCipher.cpp +322 -0
- package/cpp/cipher/HybridCipher.hpp +68 -0
- package/cpp/cipher/HybridCipherFactory.hpp +97 -0
- package/cpp/cipher/OCBCipher.cpp +55 -0
- package/cpp/cipher/OCBCipher.hpp +19 -0
- package/cpp/cipher/XSalsa20Cipher.cpp +61 -0
- package/cpp/cipher/XSalsa20Cipher.hpp +33 -0
- package/cpp/ec/HybridEcKeyPair.cpp +428 -0
- package/cpp/ec/HybridEcKeyPair.hpp +48 -0
- package/cpp/ed25519/HybridEdKeyPair.cpp +300 -0
- package/cpp/ed25519/HybridEdKeyPair.hpp +63 -0
- package/cpp/hash/HybridHash.cpp +185 -0
- package/cpp/hash/HybridHash.hpp +43 -0
- package/cpp/hmac/HybridHmac.cpp +95 -0
- package/cpp/hmac/HybridHmac.hpp +31 -0
- package/cpp/keys/HybridKeyObjectHandle.cpp +243 -0
- package/cpp/keys/HybridKeyObjectHandle.hpp +42 -0
- package/cpp/keys/KeyObjectData.cpp +226 -0
- package/cpp/keys/KeyObjectData.hpp +71 -0
- package/cpp/keys/node.h +5 -0
- package/cpp/pbkdf2/HybridPbkdf2.cpp +51 -0
- package/cpp/pbkdf2/HybridPbkdf2.hpp +24 -0
- package/cpp/random/HybridRandom.cpp +32 -18
- package/cpp/random/HybridRandom.hpp +18 -30
- package/cpp/rsa/HybridRsaKeyPair.cpp +154 -0
- package/cpp/rsa/HybridRsaKeyPair.hpp +43 -0
- package/cpp/utils/Macros.hpp +68 -0
- package/cpp/utils/Utils.hpp +53 -1
- package/deps/blake3/.cargo/config.toml +2 -0
- package/deps/blake3/.git-blame-ignore-revs +2 -0
- package/deps/blake3/.github/workflows/build_b3sum.py +38 -0
- package/deps/blake3/.github/workflows/ci.yml +491 -0
- package/deps/blake3/.github/workflows/tag.yml +43 -0
- package/deps/blake3/.github/workflows/upload_github_release_asset.py +73 -0
- package/deps/blake3/CONTRIBUTING.md +31 -0
- package/deps/blake3/Cargo.toml +135 -0
- package/deps/blake3/LICENSE_A2 +202 -0
- package/deps/blake3/LICENSE_A2LLVM +219 -0
- package/deps/blake3/LICENSE_CC0 +121 -0
- package/deps/blake3/README.md +229 -0
- package/deps/blake3/b3sum/Cargo.lock +513 -0
- package/deps/blake3/b3sum/Cargo.toml +26 -0
- package/deps/blake3/b3sum/README.md +72 -0
- package/deps/blake3/b3sum/src/main.rs +564 -0
- package/deps/blake3/b3sum/src/unit_tests.rs +235 -0
- package/deps/blake3/b3sum/tests/cli_tests.rs +680 -0
- package/deps/blake3/b3sum/what_does_check_do.md +176 -0
- package/deps/blake3/benches/bench.rs +623 -0
- package/deps/blake3/build.rs +389 -0
- package/deps/blake3/c/CMakeLists.txt +383 -0
- package/deps/blake3/c/CMakePresets.json +73 -0
- package/deps/blake3/c/Makefile.testing +82 -0
- package/deps/blake3/c/README.md +403 -0
- package/deps/blake3/c/blake3-config.cmake.in +14 -0
- package/deps/blake3/c/blake3.c +650 -0
- package/deps/blake3/c/blake3.h +86 -0
- package/deps/blake3/c/blake3_avx2.c +326 -0
- package/deps/blake3/c/blake3_avx2_x86-64_unix.S +1815 -0
- package/deps/blake3/c/blake3_avx2_x86-64_windows_gnu.S +1817 -0
- package/deps/blake3/c/blake3_avx2_x86-64_windows_msvc.asm +1828 -0
- package/deps/blake3/c/blake3_avx512.c +1388 -0
- package/deps/blake3/c/blake3_avx512_x86-64_unix.S +4824 -0
- package/deps/blake3/c/blake3_avx512_x86-64_windows_gnu.S +2615 -0
- package/deps/blake3/c/blake3_avx512_x86-64_windows_msvc.asm +2634 -0
- package/deps/blake3/c/blake3_c_rust_bindings/Cargo.toml +32 -0
- package/deps/blake3/c/blake3_c_rust_bindings/README.md +4 -0
- package/deps/blake3/c/blake3_c_rust_bindings/benches/bench.rs +477 -0
- package/deps/blake3/c/blake3_c_rust_bindings/build.rs +253 -0
- package/deps/blake3/c/blake3_c_rust_bindings/cross_test.sh +31 -0
- package/deps/blake3/c/blake3_c_rust_bindings/src/lib.rs +333 -0
- package/deps/blake3/c/blake3_c_rust_bindings/src/test.rs +696 -0
- package/deps/blake3/c/blake3_dispatch.c +332 -0
- package/deps/blake3/c/blake3_impl.h +333 -0
- package/deps/blake3/c/blake3_neon.c +366 -0
- package/deps/blake3/c/blake3_portable.c +160 -0
- package/deps/blake3/c/blake3_sse2.c +566 -0
- package/deps/blake3/c/blake3_sse2_x86-64_unix.S +2291 -0
- package/deps/blake3/c/blake3_sse2_x86-64_windows_gnu.S +2332 -0
- package/deps/blake3/c/blake3_sse2_x86-64_windows_msvc.asm +2350 -0
- package/deps/blake3/c/blake3_sse41.c +560 -0
- package/deps/blake3/c/blake3_sse41_x86-64_unix.S +2028 -0
- package/deps/blake3/c/blake3_sse41_x86-64_windows_gnu.S +2069 -0
- package/deps/blake3/c/blake3_sse41_x86-64_windows_msvc.asm +2089 -0
- package/deps/blake3/c/blake3_tbb.cpp +37 -0
- package/deps/blake3/c/dependencies/CMakeLists.txt +3 -0
- package/deps/blake3/c/dependencies/tbb/CMakeLists.txt +28 -0
- package/deps/blake3/c/example.c +36 -0
- package/deps/blake3/c/example_tbb.c +57 -0
- package/deps/blake3/c/libblake3.pc.in +12 -0
- package/deps/blake3/c/main.c +166 -0
- package/deps/blake3/c/test.py +97 -0
- package/deps/blake3/media/B3.svg +70 -0
- package/deps/blake3/media/BLAKE3.svg +85 -0
- package/deps/blake3/media/speed.svg +1474 -0
- package/deps/blake3/reference_impl/Cargo.toml +8 -0
- package/deps/blake3/reference_impl/README.md +14 -0
- package/deps/blake3/reference_impl/reference_impl.rs +374 -0
- package/deps/blake3/src/ffi_avx2.rs +65 -0
- package/deps/blake3/src/ffi_avx512.rs +169 -0
- package/deps/blake3/src/ffi_neon.rs +82 -0
- package/deps/blake3/src/ffi_sse2.rs +126 -0
- package/deps/blake3/src/ffi_sse41.rs +126 -0
- package/deps/blake3/src/guts.rs +60 -0
- package/deps/blake3/src/hazmat.rs +704 -0
- package/deps/blake3/src/io.rs +64 -0
- package/deps/blake3/src/join.rs +92 -0
- package/deps/blake3/src/lib.rs +1835 -0
- package/deps/blake3/src/platform.rs +587 -0
- package/deps/blake3/src/portable.rs +198 -0
- package/deps/blake3/src/rust_avx2.rs +474 -0
- package/deps/blake3/src/rust_sse2.rs +775 -0
- package/deps/blake3/src/rust_sse41.rs +766 -0
- package/deps/blake3/src/test.rs +1049 -0
- package/deps/blake3/src/traits.rs +227 -0
- package/deps/blake3/src/wasm32_simd.rs +794 -0
- package/deps/blake3/test_vectors/Cargo.toml +19 -0
- package/deps/blake3/test_vectors/cross_test.sh +25 -0
- package/deps/blake3/test_vectors/src/bin/generate.rs +4 -0
- package/deps/blake3/test_vectors/src/lib.rs +350 -0
- package/deps/blake3/test_vectors/test_vectors.json +217 -0
- package/deps/blake3/tools/compiler_version/Cargo.toml +7 -0
- package/deps/blake3/tools/compiler_version/build.rs +6 -0
- package/deps/blake3/tools/compiler_version/src/main.rs +27 -0
- package/deps/blake3/tools/instruction_set_support/Cargo.toml +6 -0
- package/deps/blake3/tools/instruction_set_support/src/main.rs +10 -0
- package/deps/blake3/tools/release.md +16 -0
- package/deps/fastpbkdf2/fastpbkdf2.c +356 -0
- package/deps/fastpbkdf2/fastpbkdf2.h +68 -0
- package/deps/ncrypto/ncrypto.cc +4679 -0
- package/deps/ncrypto/ncrypto.h +1625 -0
- package/lib/commonjs/blake3.js +98 -0
- package/lib/commonjs/blake3.js.map +1 -0
- package/lib/commonjs/cipher.js +180 -0
- package/lib/commonjs/cipher.js.map +1 -0
- package/lib/commonjs/ec.js +344 -0
- package/lib/commonjs/ec.js.map +1 -0
- package/lib/commonjs/ed.js +185 -0
- package/lib/commonjs/ed.js.map +1 -0
- package/lib/commonjs/expo-plugin/@types.js +2 -0
- package/lib/commonjs/expo-plugin/@types.js.map +1 -0
- package/lib/commonjs/expo-plugin/withRNQC.js +25 -0
- package/lib/commonjs/expo-plugin/withRNQC.js.map +1 -0
- package/lib/commonjs/expo-plugin/withSodiumAndroid.js +25 -0
- package/lib/commonjs/expo-plugin/withSodiumAndroid.js.map +1 -0
- package/lib/commonjs/expo-plugin/withSodiumIos.js +26 -0
- package/lib/commonjs/expo-plugin/withSodiumIos.js.map +1 -0
- package/lib/commonjs/expo-plugin/withXCode.js +51 -0
- package/lib/commonjs/expo-plugin/withXCode.js.map +1 -0
- package/lib/commonjs/hash.js +215 -0
- package/lib/commonjs/hash.js.map +1 -0
- package/lib/commonjs/hmac.js +109 -0
- package/lib/commonjs/hmac.js.map +1 -0
- package/lib/commonjs/index.js +152 -32
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/keys/classes.js +250 -0
- package/lib/commonjs/keys/classes.js.map +1 -0
- package/lib/commonjs/keys/generateKeyPair.js +102 -0
- package/lib/commonjs/keys/generateKeyPair.js.map +1 -0
- package/lib/commonjs/keys/index.js +89 -0
- package/lib/commonjs/keys/index.js.map +1 -0
- package/lib/commonjs/keys/signVerify.js +41 -0
- package/lib/commonjs/keys/signVerify.js.map +1 -0
- package/lib/commonjs/keys/utils.js +123 -0
- package/lib/commonjs/keys/utils.js.map +1 -0
- package/lib/commonjs/pbkdf2.js +89 -0
- package/lib/commonjs/pbkdf2.js.map +1 -0
- package/lib/commonjs/random.js +9 -3
- package/lib/commonjs/random.js.map +1 -1
- package/lib/commonjs/rsa.js +129 -0
- package/lib/commonjs/rsa.js.map +1 -0
- package/lib/commonjs/specs/blake3.nitro.js +6 -0
- package/lib/commonjs/specs/blake3.nitro.js.map +1 -0
- package/lib/commonjs/specs/cipher.nitro.js +6 -0
- package/lib/commonjs/specs/cipher.nitro.js.map +1 -0
- package/lib/commonjs/specs/ecKeyPair.nitro.js +6 -0
- package/lib/commonjs/specs/ecKeyPair.nitro.js.map +1 -0
- package/lib/commonjs/specs/edKeyPair.nitro.js +6 -0
- package/lib/commonjs/specs/edKeyPair.nitro.js.map +1 -0
- package/lib/commonjs/specs/hash.nitro.js +6 -0
- package/lib/commonjs/specs/hash.nitro.js.map +1 -0
- package/lib/commonjs/specs/hmac.nitro.js +6 -0
- package/lib/commonjs/specs/hmac.nitro.js.map +1 -0
- package/lib/commonjs/specs/keyObjectHandle.nitro.js +6 -0
- package/lib/commonjs/specs/keyObjectHandle.nitro.js.map +1 -0
- package/lib/commonjs/specs/pbkdf2.nitro.js +6 -0
- package/lib/commonjs/specs/pbkdf2.nitro.js.map +1 -0
- package/lib/commonjs/specs/rsaKeyPair.nitro.js +6 -0
- package/lib/commonjs/specs/rsaKeyPair.nitro.js.map +1 -0
- package/lib/commonjs/subtle.js +365 -0
- package/lib/commonjs/subtle.js.map +1 -0
- package/lib/commonjs/utils/cipher.js +64 -0
- package/lib/commonjs/utils/cipher.js.map +1 -0
- package/lib/commonjs/utils/conversion.js +140 -6
- package/lib/commonjs/utils/conversion.js.map +1 -1
- package/lib/commonjs/utils/errors.js +14 -0
- package/lib/commonjs/utils/errors.js.map +1 -0
- package/lib/commonjs/utils/hashnames.js +91 -0
- package/lib/commonjs/utils/hashnames.js.map +1 -0
- package/lib/commonjs/utils/index.js +65 -5
- package/lib/commonjs/utils/index.js.map +1 -1
- package/lib/commonjs/utils/noble.js +82 -0
- package/lib/commonjs/utils/noble.js.map +1 -0
- package/lib/commonjs/utils/types.js +52 -0
- package/lib/commonjs/utils/types.js.map +1 -1
- package/lib/commonjs/utils/validation.js +98 -0
- package/lib/commonjs/utils/validation.js.map +1 -0
- package/lib/module/blake3.js +90 -0
- package/lib/module/blake3.js.map +1 -0
- package/lib/module/cipher.js +173 -0
- package/lib/module/cipher.js.map +1 -0
- package/lib/module/ec.js +336 -0
- package/lib/module/ec.js.map +1 -0
- package/lib/module/ed.js +178 -0
- package/lib/module/ed.js.map +1 -0
- package/lib/module/expo-plugin/@types.js +2 -0
- package/lib/module/expo-plugin/@types.js.map +1 -0
- package/lib/module/expo-plugin/withRNQC.js +21 -0
- package/lib/module/expo-plugin/withRNQC.js.map +1 -0
- package/lib/module/expo-plugin/withSodiumAndroid.js +20 -0
- package/lib/module/expo-plugin/withSodiumAndroid.js.map +1 -0
- package/lib/module/expo-plugin/withSodiumIos.js +20 -0
- package/lib/module/expo-plugin/withSodiumIos.js.map +1 -0
- package/lib/module/expo-plugin/withXCode.js +46 -0
- package/lib/module/expo-plugin/withXCode.js.map +1 -0
- package/lib/module/hash.js +207 -0
- package/lib/module/hash.js.map +1 -0
- package/lib/module/hmac.js +104 -0
- package/lib/module/hmac.js.map +1 -0
- package/lib/module/index.js +33 -29
- package/lib/module/index.js.map +1 -1
- package/lib/module/keys/classes.js +241 -0
- package/lib/module/keys/classes.js.map +1 -0
- package/lib/module/keys/generateKeyPair.js +96 -0
- package/lib/module/keys/generateKeyPair.js.map +1 -0
- package/lib/module/keys/index.js +32 -0
- package/lib/module/keys/index.js.map +1 -0
- package/lib/module/keys/signVerify.js +41 -0
- package/lib/module/keys/signVerify.js.map +1 -0
- package/lib/module/keys/utils.js +114 -0
- package/lib/module/keys/utils.js.map +1 -0
- package/lib/module/pbkdf2.js +83 -0
- package/lib/module/pbkdf2.js.map +1 -0
- package/lib/module/random.js +7 -1
- package/lib/module/random.js.map +1 -1
- package/lib/module/rsa.js +123 -0
- package/lib/module/rsa.js.map +1 -0
- package/lib/module/specs/blake3.nitro.js +4 -0
- package/lib/module/specs/blake3.nitro.js.map +1 -0
- package/lib/module/specs/cipher.nitro.js +4 -0
- package/lib/module/specs/cipher.nitro.js.map +1 -0
- package/lib/module/specs/ecKeyPair.nitro.js +4 -0
- package/lib/module/specs/ecKeyPair.nitro.js.map +1 -0
- package/lib/module/specs/edKeyPair.nitro.js +4 -0
- package/lib/module/specs/edKeyPair.nitro.js.map +1 -0
- package/lib/module/specs/hash.nitro.js +4 -0
- package/lib/module/specs/hash.nitro.js.map +1 -0
- package/lib/module/specs/hmac.nitro.js +4 -0
- package/lib/module/specs/hmac.nitro.js.map +1 -0
- package/lib/module/specs/keyObjectHandle.nitro.js +4 -0
- package/lib/module/specs/keyObjectHandle.nitro.js.map +1 -0
- package/lib/module/specs/pbkdf2.nitro.js +4 -0
- package/lib/module/specs/pbkdf2.nitro.js.map +1 -0
- package/lib/module/specs/rsaKeyPair.nitro.js +4 -0
- package/lib/module/specs/rsaKeyPair.nitro.js.map +1 -0
- package/lib/module/subtle.js +360 -0
- package/lib/module/subtle.js.map +1 -0
- package/lib/module/utils/cipher.js +56 -0
- package/lib/module/utils/cipher.js.map +1 -0
- package/lib/module/utils/conversion.js +120 -8
- package/lib/module/utils/conversion.js.map +1 -1
- package/lib/module/utils/errors.js +10 -0
- package/lib/module/utils/errors.js.map +1 -0
- package/lib/module/utils/hashnames.js +89 -0
- package/lib/module/utils/hashnames.js.map +1 -0
- package/lib/module/utils/index.js +6 -5
- package/lib/module/utils/index.js.map +1 -1
- package/lib/module/utils/noble.js +76 -0
- package/lib/module/utils/noble.js.map +1 -0
- package/lib/module/utils/types.js +53 -0
- package/lib/module/utils/types.js.map +1 -1
- package/lib/module/utils/validation.js +87 -0
- package/lib/module/utils/validation.js.map +1 -0
- package/lib/tsconfig.tsbuildinfo +1 -1
- package/lib/typescript/blake3.d.ts +33 -0
- package/lib/typescript/blake3.d.ts.map +1 -0
- package/lib/typescript/cipher.d.ts +60 -0
- package/lib/typescript/cipher.d.ts.map +1 -0
- package/lib/typescript/ec.d.ts +13 -0
- package/lib/typescript/ec.d.ts.map +1 -0
- package/lib/typescript/ed.d.ts +43 -0
- package/lib/typescript/ed.d.ts.map +1 -0
- package/lib/typescript/expo-plugin/@types.d.ts +8 -0
- package/lib/typescript/expo-plugin/@types.d.ts.map +1 -0
- package/lib/typescript/expo-plugin/withRNQC.d.ts +4 -0
- package/lib/typescript/expo-plugin/withRNQC.d.ts.map +1 -0
- package/lib/typescript/expo-plugin/withSodiumAndroid.d.ts +4 -0
- package/lib/typescript/expo-plugin/withSodiumAndroid.d.ts.map +1 -0
- package/lib/typescript/expo-plugin/withSodiumIos.d.ts +4 -0
- package/lib/typescript/expo-plugin/withSodiumIos.d.ts.map +1 -0
- package/lib/typescript/expo-plugin/withXCode.d.ts +9 -0
- package/lib/typescript/expo-plugin/withXCode.d.ts.map +1 -0
- package/lib/typescript/hash.d.ts +122 -0
- package/lib/typescript/hash.d.ts.map +1 -0
- package/lib/typescript/hmac.d.ts +66 -0
- package/lib/typescript/hmac.d.ts.map +1 -0
- package/lib/typescript/index.d.ts +110 -9
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/keys/classes.d.ts +79 -0
- package/lib/typescript/keys/classes.d.ts.map +1 -0
- package/lib/typescript/keys/generateKeyPair.d.ts +6 -0
- package/lib/typescript/keys/generateKeyPair.d.ts.map +1 -0
- package/lib/typescript/keys/index.d.ts +7 -0
- package/lib/typescript/keys/index.d.ts.map +1 -0
- package/lib/typescript/keys/signVerify.d.ts +1 -0
- package/lib/typescript/keys/signVerify.d.ts.map +1 -0
- package/lib/typescript/keys/utils.d.ts +34 -0
- package/lib/typescript/keys/utils.d.ts.map +1 -0
- package/lib/typescript/pbkdf2.d.ts +12 -0
- package/lib/typescript/pbkdf2.d.ts.map +1 -0
- package/lib/typescript/random.d.ts +11 -5
- package/lib/typescript/random.d.ts.map +1 -1
- package/lib/typescript/rsa.d.ts +10 -0
- package/lib/typescript/rsa.d.ts.map +1 -0
- package/lib/typescript/specs/blake3.nitro.d.ts +15 -0
- package/lib/typescript/specs/blake3.nitro.d.ts.map +1 -0
- package/lib/typescript/specs/cipher.nitro.d.ts +29 -0
- package/lib/typescript/specs/cipher.nitro.d.ts.map +1 -0
- package/lib/typescript/specs/ecKeyPair.nitro.d.ts +20 -0
- package/lib/typescript/specs/ecKeyPair.nitro.d.ts.map +1 -0
- package/lib/typescript/specs/edKeyPair.nitro.d.ts +17 -0
- package/lib/typescript/specs/edKeyPair.nitro.d.ts.map +1 -0
- package/lib/typescript/specs/hash.nitro.d.ts +13 -0
- package/lib/typescript/specs/hash.nitro.d.ts.map +1 -0
- package/lib/typescript/specs/hmac.nitro.d.ts +10 -0
- package/lib/typescript/specs/hmac.nitro.d.ts.map +1 -0
- package/lib/typescript/specs/keyObjectHandle.nitro.d.ts +14 -0
- package/lib/typescript/specs/keyObjectHandle.nitro.d.ts.map +1 -0
- package/lib/typescript/specs/pbkdf2.nitro.d.ts +9 -0
- package/lib/typescript/specs/pbkdf2.nitro.d.ts.map +1 -0
- package/lib/typescript/specs/rsaKeyPair.nitro.d.ts +20 -0
- package/lib/typescript/specs/rsaKeyPair.nitro.d.ts.map +1 -0
- package/lib/typescript/subtle.d.ts +17 -0
- package/lib/typescript/subtle.d.ts.map +1 -0
- package/lib/typescript/utils/cipher.d.ts +7 -0
- package/lib/typescript/utils/cipher.d.ts.map +1 -0
- package/lib/typescript/utils/conversion.d.ts +24 -2
- package/lib/typescript/utils/conversion.d.ts.map +1 -1
- package/lib/typescript/utils/errors.d.ts +7 -0
- package/lib/typescript/utils/errors.d.ts.map +1 -0
- package/lib/typescript/utils/hashnames.d.ts +13 -0
- package/lib/typescript/utils/hashnames.d.ts.map +1 -0
- package/lib/typescript/utils/index.d.ts +6 -5
- package/lib/typescript/utils/index.d.ts.map +1 -1
- package/lib/typescript/utils/noble.d.ts +19 -0
- package/lib/typescript/utils/noble.d.ts.map +1 -0
- package/lib/typescript/utils/types.d.ts +252 -2
- package/lib/typescript/utils/types.d.ts.map +1 -1
- package/lib/typescript/utils/validation.d.ts +13 -0
- package/lib/typescript/utils/validation.d.ts.map +1 -0
- package/nitrogen/generated/.gitattributes +1 -0
- package/nitrogen/generated/android/QuickCrypto+autolinking.cmake +47 -4
- package/nitrogen/generated/android/QuickCrypto+autolinking.gradle +4 -3
- package/nitrogen/generated/android/QuickCryptoOnLoad.cpp +144 -0
- package/nitrogen/generated/android/QuickCryptoOnLoad.hpp +25 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/crypto/QuickCryptoOnLoad.kt +35 -0
- package/nitrogen/generated/ios/QuickCrypto+autolinking.rb +11 -8
- package/nitrogen/generated/ios/QuickCrypto-Swift-Cxx-Bridge.cpp +11 -3
- package/nitrogen/generated/ios/QuickCrypto-Swift-Cxx-Bridge.hpp +5 -3
- package/nitrogen/generated/ios/QuickCrypto-Swift-Cxx-Umbrella.hpp +16 -7
- package/nitrogen/generated/ios/QuickCryptoAutolinking.mm +135 -0
- package/nitrogen/generated/ios/QuickCryptoAutolinking.swift +12 -0
- package/nitrogen/generated/shared/c++/CFRGKeyPairType.hpp +84 -0
- package/nitrogen/generated/shared/c++/CipherArgs.hpp +86 -0
- package/nitrogen/generated/shared/c++/HybridBlake3Spec.cpp +28 -0
- package/nitrogen/generated/shared/c++/HybridBlake3Spec.hpp +76 -0
- package/nitrogen/generated/shared/c++/HybridCipherFactorySpec.cpp +21 -0
- package/nitrogen/generated/shared/c++/HybridCipherFactorySpec.hpp +67 -0
- package/nitrogen/generated/shared/c++/HybridCipherSpec.cpp +28 -0
- package/nitrogen/generated/shared/c++/HybridCipherSpec.hpp +76 -0
- package/nitrogen/generated/shared/c++/HybridEcKeyPairSpec.cpp +29 -0
- package/nitrogen/generated/shared/c++/HybridEcKeyPairSpec.hpp +77 -0
- package/nitrogen/generated/shared/c++/HybridEdKeyPairSpec.cpp +30 -0
- package/nitrogen/generated/shared/c++/HybridEdKeyPairSpec.hpp +75 -0
- package/nitrogen/generated/shared/c++/HybridHashSpec.cpp +26 -0
- package/nitrogen/generated/shared/c++/HybridHashSpec.hpp +75 -0
- package/nitrogen/generated/shared/c++/HybridHmacSpec.cpp +23 -0
- package/nitrogen/generated/shared/c++/HybridHmacSpec.hpp +66 -0
- package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.cpp +26 -0
- package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.hpp +92 -0
- package/nitrogen/generated/shared/c++/HybridPbkdf2Spec.cpp +22 -0
- package/nitrogen/generated/shared/c++/HybridPbkdf2Spec.hpp +66 -0
- package/nitrogen/generated/shared/c++/HybridRandomSpec.cpp +2 -3
- package/nitrogen/generated/shared/c++/HybridRandomSpec.hpp +9 -6
- package/nitrogen/generated/shared/c++/HybridRsaKeyPairSpec.cpp +29 -0
- package/nitrogen/generated/shared/c++/HybridRsaKeyPairSpec.hpp +77 -0
- package/nitrogen/generated/shared/c++/JWK.hpp +161 -0
- package/nitrogen/generated/shared/c++/JWKkty.hpp +84 -0
- package/nitrogen/generated/shared/c++/JWKuse.hpp +76 -0
- package/nitrogen/generated/shared/c++/KFormatType.hpp +63 -0
- package/nitrogen/generated/shared/c++/KeyDetail.hpp +92 -0
- package/nitrogen/generated/shared/c++/KeyEncoding.hpp +64 -0
- package/nitrogen/generated/shared/c++/KeyObject.hpp +67 -0
- package/nitrogen/generated/shared/c++/KeyType.hpp +63 -0
- package/nitrogen/generated/shared/c++/KeyUsage.hpp +116 -0
- package/nitrogen/generated/shared/c++/NamedCurve.hpp +80 -0
- package/package.json +66 -39
- package/src/blake3.ts +123 -0
- package/src/cipher.ts +335 -0
- package/src/ec.ts +432 -0
- package/src/ed.ts +256 -0
- package/src/expo-plugin/@types.ts +7 -0
- package/src/expo-plugin/withRNQC.ts +23 -0
- package/src/expo-plugin/withSodiumAndroid.ts +24 -0
- package/src/expo-plugin/withSodiumIos.ts +30 -0
- package/src/expo-plugin/withXCode.ts +55 -0
- package/src/hash.ts +274 -0
- package/src/hmac.ts +135 -0
- package/src/index.ts +32 -29
- package/src/keys/classes.ts +317 -0
- package/src/keys/generateKeyPair.ts +145 -0
- package/src/keys/index.ts +52 -0
- package/src/keys/signVerify.ts +39 -0
- package/src/keys/utils.ts +190 -0
- package/src/pbkdf2.ts +154 -0
- package/src/random.ts +26 -23
- package/src/rsa.ts +176 -0
- package/src/specs/blake3.nitro.ts +12 -0
- package/src/specs/cipher.nitro.ts +25 -0
- package/src/specs/ecKeyPair.nitro.ts +38 -0
- package/src/specs/edKeyPair.nitro.ts +43 -0
- package/src/specs/hash.nitro.ts +10 -0
- package/src/specs/hmac.nitro.ts +7 -0
- package/src/specs/keyObjectHandle.nitro.ts +31 -0
- package/src/specs/pbkdf2.nitro.ts +18 -0
- package/src/specs/random.nitro.ts +2 -2
- package/src/specs/rsaKeyPair.nitro.ts +33 -0
- package/src/subtle.ts +614 -0
- package/src/utils/cipher.ts +60 -0
- package/src/utils/conversion.ts +143 -9
- package/src/utils/errors.ts +15 -0
- package/src/utils/hashnames.ts +98 -0
- package/src/utils/index.ts +6 -6
- package/src/utils/noble.ts +85 -0
- package/src/utils/types.ts +423 -3
- package/src/utils/validation.ts +130 -0
- package/ios/QuickCryptoOnLoad.mm +0 -19
- 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
|
-
|
|
5
|
-
|
|
6
|
-
|
|
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(
|
|
9
|
-
return
|
|
19
|
+
if (ArrayBuffer.isView(buf)) {
|
|
20
|
+
return buf.buffer;
|
|
10
21
|
}
|
|
11
|
-
return
|
|
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
|
|
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","
|
|
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":";;AAEA,WAAYA,WAAW,0BAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAA,OAAXA,WAAW;AAAA;;AASvB;AACA;AACA;AACA;;AAMA,MAAMC,UAAqB,GAAG;EAC5BC,IAAI,EAAE;IACJ,CAACF,WAAW,CAACG,IAAI,GAAG,MAAM;IAC1B,CAACH,WAAW,CAACI,SAAS,GAAG,OAAO;IAChC,CAACJ,WAAW,CAACK,MAAM,GAAG,KAAK;IAC3B,CAACL,WAAW,CAACM,SAAS,GAAG,KAAK;IAC9B,CAACN,WAAW,CAACO,UAAU,GAAG,UAAU;IACpC,CAACP,WAAW,CAACQ,OAAO,GAAG;EACzB,CAAC;EACDC,MAAM,EAAE;IACN,CAACT,WAAW,CAACG,IAAI,GAAG,QAAQ;IAC5B,CAACH,WAAW,CAACI,SAAS,GAAG,SAAS;IAClC,CAACJ,WAAW,CAACK,MAAM,GAAG,OAAO;IAC7B,CAACL,WAAW,CAACM,SAAS,GAAG,OAAO;IAChC,CAACN,WAAW,CAACO,UAAU,GAAG,cAAc;IACxC,CAACP,WAAW,CAACQ,OAAO,GAAG;EACzB,CAAC;EACDE,MAAM,EAAE;IACN,CAACV,WAAW,CAACG,IAAI,GAAG,QAAQ;IAC5B,CAACH,WAAW,CAACI,SAAS,GAAG,SAAS;IAClC,CAACJ,WAAW,CAACK,MAAM,GAAG,OAAO;IAC7B,CAACL,WAAW,CAACM,SAAS,GAAG,OAAO;IAChC,CAACN,WAAW,CAACO,UAAU,GAAG,cAAc;IACxC,CAACP,WAAW,CAACQ,OAAO,GAAG;EACzB,CAAC;EACDG,MAAM,EAAE;IACN,CAACX,WAAW,CAACG,IAAI,GAAG,QAAQ;IAC5B,CAACH,WAAW,CAACI,SAAS,GAAG,SAAS;IAClC,CAACJ,WAAW,CAACK,MAAM,GAAG,OAAO;IAC7B,CAACL,WAAW,CAACM,SAAS,GAAG,OAAO;IAChC,CAACN,WAAW,CAACO,UAAU,GAAG,cAAc;IACxC,CAACP,WAAW,CAACQ,OAAO,GAAG;EACzB,CAAC;EACDI,MAAM,EAAE;IACN,CAACZ,WAAW,CAACG,IAAI,GAAG,QAAQ;IAC5B,CAACH,WAAW,CAACI,SAAS,GAAG,SAAS;IAClC,CAACJ,WAAW,CAACK,MAAM,GAAG,OAAO;IAC7B,CAACL,WAAW,CAACM,SAAS,GAAG,OAAO;IAChC,CAACN,WAAW,CAACO,UAAU,GAAG,cAAc;IACxC,CAACP,WAAW,CAACQ,OAAO,GAAG;EACzB,CAAC;EACDK,SAAS,EAAE;IACT,CAACb,WAAW,CAACG,IAAI,GAAG,WAAW;IAC/B,CAACH,WAAW,CAACI,SAAS,GAAG;EAC3B;AACF,CAAC;AAED;EACE;EACA,MAAMU,IAAc,GAAGC,MAAM,CAACD,IAAI,CAACb,UAAU,CAAC;EAC9C,KAAK,IAAIe,CAAS,GAAG,CAAC,EAAEA,CAAC,GAAGF,IAAI,CAACG,MAAM,EAAED,CAAC,EAAE,EAAE;IAC5C,MAAME,QAAkB,GAAGH,MAAM,CAACD,IAAI,CAACb,UAAU,CAACa,IAAI,CAACE,CAAC,CAAC,CAAG,CAAC;IAC7D,KAAK,IAAIG,CAAS,GAAG,CAAC,EAAEA,CAAC,GAAGD,QAAQ,CAACD,MAAM,EAAEE,CAAC,EAAE,EAAE;MAChD,MAAMC,KAAa,GAAGnB,UAAU,CAACa,IAAI,CAACE,CAAC,CAAC,CAAE,CAAEE,QAAQ,CAACC,CAAC,CAAC,CAAE,CAAEE,WAAW,CAAC,CAAC;MACxE,IAAIpB,UAAU,CAACmB,KAAK,CAAC,KAAKE,SAAS,EACjCrB,UAAU,CAACmB,KAAK,CAAC,GAAGnB,UAAU,CAACa,IAAI,CAACE,CAAC,CAAC,CAAG;IAC7C;EACF;AACF;AAEA,OAAO,SAASO,iBAAiBA,CAC/BC,IAA2D,EAC3DC,OAAoB,GAAGzB,WAAW,CAACG,IAAI,EACxB;EACf,IAAI,OAAOqB,IAAI,KAAK,WAAW,EAAE;IAC/B,MAAME,QAAQ,GACZ,OAAOF,IAAI,KAAK,QAAQ,GAAGA,IAAI,GAAGA,IAAI,CAACG,IAAI,IAAIH,IAAI,CAACI,QAAQ,CAAC,CAAC;IAChE,MAAMC,QAAQ,GAAGH,QAAQ,CAACL,WAAW,CAAC,CAAC;IACvC,IAAI;MACF,MAAMD,KAAK,GAAGnB,UAAU,CAAC4B,QAAQ,CAAC,CAAEJ,OAAO,CAAkB;MAC7D,IAAIL,KAAK,EAAE,OAAOA,KAAK;MACvB;IACF,CAAC,CAAC,OAAOU,EAAE,EAAE;MACX;IAAA;EAEJ;EACA,MAAM,IAAIC,KAAK,CAAC,2BAA2BP,IAAI,EAAE,CAAC;AACpD","ignoreList":[]}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
export
|
|
5
|
-
|
|
6
|
-
|
|
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":[
|
|
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":[]}
|