@pezkuwi/util-crypto 14.0.4 → 14.0.6
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/README.md +4 -4
- package/build/README.md +17 -0
- package/build/address/addressToEvm.js +8 -0
- package/build/address/check.js +26 -0
- package/build/address/checksum.js +16 -0
- package/build/address/decode.js +29 -0
- package/build/address/defaults.js +8 -0
- package/build/address/derive.js +24 -0
- package/build/address/encode.js +23 -0
- package/build/address/encodeDerived.d.ts +9 -0
- package/build/address/encodeDerived.js +12 -0
- package/build/address/encodeMulti.d.ts +9 -0
- package/build/address/encodeMulti.js +11 -0
- package/build/address/eq.d.ts +15 -0
- package/build/address/eq.js +19 -0
- package/build/address/evmToAddress.js +14 -0
- package/build/address/index.js +16 -0
- package/build/address/is.js +9 -0
- package/build/address/keyDerived.d.ts +2 -0
- package/build/address/keyDerived.js +8 -0
- package/build/address/keyMulti.d.ts +2 -0
- package/build/address/keyMulti.js +8 -0
- package/build/address/setSS58Format.js +11 -0
- package/build/address/sort.js +7 -0
- package/build/address/sshash.js +6 -0
- package/build/address/util.js +4 -0
- package/build/address/validate.js +4 -0
- package/build/base32/bs32.d.ts +26 -0
- package/build/base32/bs32.js +40 -0
- package/build/base32/helpers.d.ts +25 -0
- package/build/base32/helpers.js +61 -0
- package/build/base32/index.js +4 -0
- package/build/base58/bs58.d.ts +26 -0
- package/build/base58/bs58.js +34 -0
- package/build/base58/index.js +4 -0
- package/build/base64/bs64.d.ts +26 -0
- package/build/base64/bs64.js +34 -0
- package/build/base64/index.js +6 -0
- package/build/base64/pad.js +7 -0
- package/build/base64/trim.js +10 -0
- package/build/blake2/asU8a.d.ts +20 -0
- package/build/blake2/asU8a.js +32 -0
- package/build/blake2/index.js +4 -0
- package/build/bn.js +8 -0
- package/build/bundle-pezkuwi-util-crypto.js +11813 -0
- package/build/bundle.js +26 -0
- package/build/bundleInit.d.ts +1 -0
- package/build/bundleInit.js +5 -0
- package/build/cjs/address/addressToEvm.d.ts +5 -0
- package/build/cjs/address/addressToEvm.js +11 -0
- package/build/cjs/address/check.d.ts +8 -0
- package/build/cjs/address/check.js +29 -0
- package/build/cjs/address/checksum.d.ts +1 -0
- package/build/cjs/address/checksum.js +19 -0
- package/build/cjs/address/decode.d.ts +2 -0
- package/build/cjs/address/decode.js +32 -0
- package/build/cjs/address/defaults.d.ts +6 -0
- package/build/cjs/address/defaults.js +11 -0
- package/build/cjs/address/derive.d.ts +8 -0
- package/build/cjs/address/derive.js +27 -0
- package/build/cjs/address/encode.d.ts +2 -0
- package/build/cjs/address/encode.js +26 -0
- package/build/cjs/address/encodeDerived.d.ts +9 -0
- package/build/cjs/address/encodeDerived.js +15 -0
- package/build/cjs/address/encodeMulti.d.ts +9 -0
- package/build/cjs/address/encodeMulti.js +14 -0
- package/build/cjs/address/eq.d.ts +15 -0
- package/build/cjs/address/eq.js +22 -0
- package/build/cjs/address/evmToAddress.d.ts +7 -0
- package/build/cjs/address/evmToAddress.js +17 -0
- package/build/cjs/address/index.d.ts +16 -0
- package/build/cjs/address/index.js +35 -0
- package/build/cjs/address/is.d.ts +2 -0
- package/build/cjs/address/is.js +12 -0
- package/build/cjs/address/keyDerived.d.ts +2 -0
- package/build/cjs/address/keyDerived.js +11 -0
- package/build/cjs/address/keyMulti.d.ts +2 -0
- package/build/cjs/address/keyMulti.js +11 -0
- package/build/cjs/address/setSS58Format.d.ts +6 -0
- package/build/cjs/address/setSS58Format.js +14 -0
- package/build/cjs/address/sort.d.ts +2 -0
- package/build/cjs/address/sort.js +10 -0
- package/build/cjs/address/sshash.d.ts +1 -0
- package/build/cjs/address/sshash.js +9 -0
- package/build/cjs/address/types.d.ts +1 -0
- package/build/cjs/address/types.js +2 -0
- package/build/cjs/address/util.d.ts +1 -0
- package/build/cjs/address/util.js +7 -0
- package/build/cjs/address/validate.d.ts +2 -0
- package/build/cjs/address/validate.js +7 -0
- package/build/cjs/base32/bs32.d.ts +26 -0
- package/build/cjs/base32/bs32.js +43 -0
- package/build/cjs/base32/helpers.d.ts +25 -0
- package/build/cjs/base32/helpers.js +67 -0
- package/build/cjs/base32/index.d.ts +4 -0
- package/build/cjs/base32/index.js +11 -0
- package/build/cjs/base58/bs58.d.ts +26 -0
- package/build/cjs/base58/bs58.js +37 -0
- package/build/cjs/base58/index.d.ts +4 -0
- package/build/cjs/base58/index.js +11 -0
- package/build/cjs/base64/bs64.d.ts +26 -0
- package/build/cjs/base64/bs64.js +37 -0
- package/build/cjs/base64/index.d.ts +6 -0
- package/build/cjs/base64/index.js +15 -0
- package/build/cjs/base64/pad.d.ts +5 -0
- package/build/cjs/base64/pad.js +10 -0
- package/build/cjs/base64/trim.d.ts +5 -0
- package/build/cjs/base64/trim.js +13 -0
- package/build/cjs/blake2/asU8a.d.ts +20 -0
- package/build/cjs/blake2/asU8a.js +36 -0
- package/build/cjs/blake2/index.d.ts +4 -0
- package/build/cjs/blake2/index.js +9 -0
- package/build/cjs/bn.d.ts +30 -0
- package/build/cjs/bn.js +11 -0
- package/build/cjs/bundle.d.ts +26 -0
- package/build/cjs/bundle.js +31 -0
- package/build/cjs/bundleInit.d.ts +1 -0
- package/build/cjs/bundleInit.js +7 -0
- package/build/cjs/crypto.d.ts +3 -0
- package/build/cjs/crypto.js +16 -0
- package/build/cjs/ed25519/deriveHard.js +12 -0
- package/build/cjs/ed25519/index.js +20 -0
- package/build/cjs/ed25519/pair/fromRandom.d.ts +16 -0
- package/build/cjs/ed25519/pair/fromRandom.js +22 -0
- package/build/cjs/ed25519/pair/fromSecret.d.ts +16 -0
- package/build/cjs/ed25519/pair/fromSecret.js +26 -0
- package/build/cjs/ed25519/pair/fromSeed.d.ts +16 -0
- package/build/cjs/ed25519/pair/fromSeed.js +34 -0
- package/build/cjs/ed25519/pair/fromString.d.ts +16 -0
- package/build/cjs/ed25519/pair/fromString.js +23 -0
- package/build/cjs/ed25519/sign.d.ts +16 -0
- package/build/cjs/ed25519/sign.js +33 -0
- package/build/cjs/ed25519/verify.d.ts +15 -0
- package/build/cjs/ed25519/verify.js +39 -0
- package/build/cjs/ethereum/encode.d.ts +2 -0
- package/build/cjs/ethereum/encode.js +28 -0
- package/build/cjs/ethereum/index.js +9 -0
- package/build/cjs/ethereum/isAddress.js +14 -0
- package/build/cjs/ethereum/isChecksum.js +20 -0
- package/build/cjs/hd/ethereum/index.js +47 -0
- package/build/cjs/hd/index.js +9 -0
- package/build/cjs/hd/ledger/derivePrivate.js +15 -0
- package/build/cjs/hd/ledger/index.js +33 -0
- package/build/cjs/hd/ledger/master.js +19 -0
- package/build/cjs/hd/validatePath.js +20 -0
- package/build/cjs/helpers.d.ts +12 -0
- package/build/cjs/helpers.js +24 -0
- package/build/cjs/hmac/index.js +7 -0
- package/build/cjs/hmac/shaAsU8a.js +40 -0
- package/build/cjs/index.js +5 -0
- package/build/cjs/json/constants.js +8 -0
- package/build/cjs/json/decrypt.js +16 -0
- package/build/cjs/json/decryptData.js +32 -0
- package/build/cjs/json/encrypt.js +18 -0
- package/build/cjs/json/encryptFormat.js +17 -0
- package/build/cjs/json/index.js +11 -0
- package/build/cjs/json/types.js +2 -0
- package/build/cjs/keccak/asU8a.d.ts +30 -0
- package/build/cjs/keccak/asU8a.js +36 -0
- package/build/cjs/keccak/index.js +11 -0
- package/build/cjs/key/DeriveJunction.d.ts +12 -0
- package/build/cjs/key/DeriveJunction.js +62 -0
- package/build/cjs/key/extractPath.js +26 -0
- package/build/cjs/key/extractSuri.js +25 -0
- package/build/cjs/key/fromPath.js +21 -0
- package/build/cjs/key/hdkdDerive.js +11 -0
- package/build/cjs/key/hdkdEcdsa.js +7 -0
- package/build/cjs/key/hdkdEd25519.js +6 -0
- package/build/cjs/key/hdkdSr25519.js +10 -0
- package/build/cjs/key/index.js +18 -0
- package/build/cjs/mnemonic/bip39.js +90 -0
- package/build/cjs/mnemonic/generate.d.ts +13 -0
- package/build/cjs/mnemonic/generate.js +23 -0
- package/build/cjs/mnemonic/index.js +16 -0
- package/build/cjs/mnemonic/toEntropy.js +11 -0
- package/build/cjs/mnemonic/toLegacySeed.d.ts +18 -0
- package/build/cjs/mnemonic/toLegacySeed.js +37 -0
- package/build/cjs/mnemonic/toMiniSecret.js +20 -0
- package/build/cjs/mnemonic/validate.d.ts +14 -0
- package/build/cjs/mnemonic/validate.js +24 -0
- package/build/cjs/mnemonic/wordlists/en.js +3 -0
- package/build/cjs/mnemonic/wordlists/es.js +3 -0
- package/build/cjs/mnemonic/wordlists/fr.js +3 -0
- package/build/cjs/mnemonic/wordlists/index.js +20 -0
- package/build/cjs/mnemonic/wordlists/it.js +3 -0
- package/build/cjs/mnemonic/wordlists/jp.js +3 -0
- package/build/cjs/mnemonic/wordlists/ko.js +3 -0
- package/build/cjs/mnemonic/wordlists/zh-s.js +3 -0
- package/build/cjs/mnemonic/wordlists/zh-t.js +3 -0
- package/build/cjs/nacl/decrypt.d.ts +15 -0
- package/build/cjs/nacl/decrypt.js +21 -0
- package/build/cjs/nacl/encrypt.d.ts +20 -0
- package/build/cjs/nacl/encrypt.js +25 -0
- package/build/cjs/nacl/index.js +10 -0
- package/build/cjs/nacl/tweetnacl.js +238 -0
- package/build/cjs/networks.d.ts +1 -0
- package/build/cjs/networks.js +7 -0
- package/build/cjs/packageDetect.d.ts +1 -0
- package/build/cjs/packageInfo.js +4 -0
- package/build/cjs/pbkdf2/encode.js +19 -0
- package/build/cjs/pbkdf2/index.js +5 -0
- package/build/cjs/random/asNumber.d.ts +15 -0
- package/build/cjs/random/asNumber.js +23 -0
- package/build/cjs/random/asU8a.d.ts +20 -0
- package/build/cjs/random/asU8a.js +28 -0
- package/build/cjs/random/index.js +11 -0
- package/build/cjs/scrypt/defaults.js +16 -0
- package/build/cjs/scrypt/encode.js +18 -0
- package/build/cjs/scrypt/fromU8a.js +27 -0
- package/build/cjs/scrypt/index.js +9 -0
- package/build/cjs/scrypt/toU8a.js +8 -0
- package/build/cjs/scrypt/types.js +2 -0
- package/build/cjs/secp256k1/compress.js +17 -0
- package/build/cjs/secp256k1/deriveHard.js +13 -0
- package/build/cjs/secp256k1/expand.js +20 -0
- package/build/cjs/secp256k1/hasher.js +10 -0
- package/build/cjs/secp256k1/index.js +17 -0
- package/build/cjs/secp256k1/pair/fromSeed.js +34 -0
- package/build/cjs/secp256k1/recover.js +29 -0
- package/build/cjs/secp256k1/sign.js +23 -0
- package/build/cjs/secp256k1/tweakAdd.js +48 -0
- package/build/cjs/secp256k1/types.js +2 -0
- package/build/cjs/secp256k1/verify.js +23 -0
- package/build/cjs/sha/asU8a.js +22 -0
- package/build/cjs/sha/index.js +10 -0
- package/build/cjs/signature/index.js +8 -0
- package/build/cjs/signature/verify.js +81 -0
- package/build/cjs/sr25519/agreement.js +20 -0
- package/build/cjs/sr25519/derive.js +16 -0
- package/build/cjs/sr25519/deriveHard.js +7 -0
- package/build/cjs/sr25519/derivePublic.js +16 -0
- package/build/cjs/sr25519/deriveSoft.js +7 -0
- package/build/cjs/sr25519/index.js +21 -0
- package/build/cjs/sr25519/pair/fromSeed.js +22 -0
- package/build/cjs/sr25519/pair/fromU8a.js +17 -0
- package/build/cjs/sr25519/pair/toU8a.js +7 -0
- package/build/cjs/sr25519/sign.js +19 -0
- package/build/cjs/sr25519/verify.js +21 -0
- package/build/cjs/sr25519/vrfSign.js +19 -0
- package/build/cjs/sr25519/vrfVerify.js +22 -0
- package/build/cjs/types.js +5 -0
- package/build/cjs/xxhash/asU8a.d.ts +20 -0
- package/build/cjs/xxhash/asU8a.js +39 -0
- package/build/cjs/xxhash/index.js +9 -0
- package/build/cjs/xxhash/xxhash64.js +103 -0
- package/build/crypto.d.ts +3 -0
- package/build/crypto.js +12 -0
- package/build/ed25519/deriveHard.d.ts +1 -0
- package/build/ed25519/deriveHard.js +9 -0
- package/build/ed25519/index.d.ts +10 -0
- package/build/ed25519/index.js +10 -0
- package/build/ed25519/pair/fromRandom.d.ts +16 -0
- package/build/ed25519/pair/fromRandom.js +19 -0
- package/build/ed25519/pair/fromSecret.d.ts +16 -0
- package/build/ed25519/pair/fromSecret.js +23 -0
- package/build/ed25519/pair/fromSeed.d.ts +16 -0
- package/build/ed25519/pair/fromSeed.js +31 -0
- package/build/ed25519/pair/fromString.d.ts +16 -0
- package/build/ed25519/pair/fromString.js +20 -0
- package/build/ed25519/sign.d.ts +16 -0
- package/build/ed25519/sign.js +30 -0
- package/build/ed25519/verify.d.ts +15 -0
- package/build/ed25519/verify.js +36 -0
- package/build/ethereum/encode.d.ts +2 -0
- package/build/ethereum/encode.js +25 -0
- package/build/ethereum/index.d.ts +3 -0
- package/build/ethereum/index.js +3 -0
- package/build/ethereum/isAddress.d.ts +1 -0
- package/build/ethereum/isAddress.js +11 -0
- package/build/ethereum/isChecksum.d.ts +1 -0
- package/build/ethereum/isChecksum.js +17 -0
- package/build/hd/ethereum/index.d.ts +2 -0
- package/build/hd/ethereum/index.js +44 -0
- package/build/hd/index.d.ts +3 -0
- package/build/hd/index.js +3 -0
- package/build/hd/ledger/derivePrivate.d.ts +1 -0
- package/build/hd/ledger/derivePrivate.js +12 -0
- package/build/hd/ledger/index.d.ts +2 -0
- package/build/hd/ledger/index.js +30 -0
- package/build/hd/ledger/master.d.ts +1 -0
- package/build/hd/ledger/master.js +16 -0
- package/build/hd/validatePath.d.ts +2 -0
- package/build/hd/validatePath.js +16 -0
- package/build/helpers.d.ts +12 -0
- package/build/helpers.js +19 -0
- package/build/hmac/index.d.ts +1 -0
- package/build/hmac/index.js +1 -0
- package/build/hmac/shaAsU8a.d.ts +15 -0
- package/build/hmac/shaAsU8a.js +36 -0
- package/build/index.d.ts +2 -0
- package/build/index.js +2 -0
- package/build/json/constants.d.ts +6 -0
- package/build/json/constants.js +5 -0
- package/build/json/decrypt.d.ts +2 -0
- package/build/json/decrypt.js +13 -0
- package/build/json/decryptData.d.ts +2 -0
- package/build/json/decryptData.js +29 -0
- package/build/json/encrypt.d.ts +2 -0
- package/build/json/encrypt.js +15 -0
- package/build/json/encryptFormat.d.ts +2 -0
- package/build/json/encryptFormat.js +14 -0
- package/build/json/index.d.ts +4 -0
- package/build/json/index.js +4 -0
- package/build/json/types.d.ts +16 -0
- package/build/json/types.js +1 -0
- package/build/keccak/asU8a.d.ts +30 -0
- package/build/keccak/asU8a.js +33 -0
- package/build/keccak/index.d.ts +4 -0
- package/build/keccak/index.js +4 -0
- package/build/key/DeriveJunction.d.ts +12 -0
- package/build/key/DeriveJunction.js +58 -0
- package/build/key/extractPath.d.ts +9 -0
- package/build/key/extractPath.js +23 -0
- package/build/key/extractSuri.d.ts +11 -0
- package/build/key/extractSuri.js +22 -0
- package/build/key/fromPath.d.ts +3 -0
- package/build/key/fromPath.js +18 -0
- package/build/key/hdkdDerive.d.ts +3 -0
- package/build/key/hdkdDerive.js +8 -0
- package/build/key/hdkdEcdsa.d.ts +1 -0
- package/build/key/hdkdEcdsa.js +4 -0
- package/build/key/hdkdEd25519.d.ts +1 -0
- package/build/key/hdkdEd25519.js +3 -0
- package/build/key/hdkdSr25519.d.ts +3 -0
- package/build/key/hdkdSr25519.js +7 -0
- package/build/key/index.d.ts +9 -0
- package/build/key/index.js +9 -0
- package/build/mnemonic/bip39.d.ts +5 -0
- package/build/mnemonic/bip39.js +82 -0
- package/build/mnemonic/generate.d.ts +13 -0
- package/build/mnemonic/generate.js +20 -0
- package/build/mnemonic/index.d.ts +8 -0
- package/build/mnemonic/index.js +8 -0
- package/build/mnemonic/toEntropy.d.ts +1 -0
- package/build/mnemonic/toEntropy.js +8 -0
- package/build/mnemonic/toLegacySeed.d.ts +18 -0
- package/build/mnemonic/toLegacySeed.js +34 -0
- package/build/mnemonic/toMiniSecret.d.ts +1 -0
- package/build/mnemonic/toMiniSecret.js +17 -0
- package/build/mnemonic/validate.d.ts +14 -0
- package/build/mnemonic/validate.js +21 -0
- package/build/mnemonic/wordlists/en.d.ts +2 -0
- package/build/mnemonic/wordlists/en.js +1 -0
- package/build/mnemonic/wordlists/es.d.ts +2 -0
- package/build/mnemonic/wordlists/es.js +1 -0
- package/build/mnemonic/wordlists/fr.d.ts +2 -0
- package/build/mnemonic/wordlists/fr.js +1 -0
- package/build/mnemonic/wordlists/index.d.ts +8 -0
- package/build/mnemonic/wordlists/index.js +8 -0
- package/build/mnemonic/wordlists/it.d.ts +2 -0
- package/build/mnemonic/wordlists/it.js +1 -0
- package/build/mnemonic/wordlists/jp.d.ts +2 -0
- package/build/mnemonic/wordlists/jp.js +1 -0
- package/build/mnemonic/wordlists/ko.d.ts +2 -0
- package/build/mnemonic/wordlists/ko.js +1 -0
- package/build/mnemonic/wordlists/zh-s.d.ts +2 -0
- package/build/mnemonic/wordlists/zh-s.js +1 -0
- package/build/mnemonic/wordlists/zh-t.d.ts +2 -0
- package/build/mnemonic/wordlists/zh-t.js +1 -0
- package/build/nacl/decrypt.d.ts +15 -0
- package/build/nacl/decrypt.js +18 -0
- package/build/nacl/encrypt.d.ts +20 -0
- package/build/nacl/encrypt.js +22 -0
- package/build/nacl/index.d.ts +5 -0
- package/build/nacl/index.js +5 -0
- package/build/nacl/tweetnacl.d.ts +2 -0
- package/build/nacl/tweetnacl.js +234 -0
- package/build/networks.d.ts +1 -0
- package/build/networks.js +1 -0
- package/build/package.json +2057 -0
- package/build/packageDetect.d.ts +1 -0
- package/build/packageDetect.js +6 -0
- package/build/packageInfo.d.ts +6 -0
- package/build/packageInfo.js +1 -0
- package/build/pbkdf2/encode.d.ts +7 -0
- package/build/pbkdf2/encode.js +16 -0
- package/build/pbkdf2/index.d.ts +1 -0
- package/build/pbkdf2/index.js +1 -0
- package/build/random/asNumber.d.ts +15 -0
- package/build/random/asNumber.js +20 -0
- package/build/random/asU8a.d.ts +20 -0
- package/build/random/asU8a.js +24 -0
- package/build/random/index.d.ts +5 -0
- package/build/random/index.js +5 -0
- package/build/scrypt/defaults.d.ts +3 -0
- package/build/scrypt/defaults.js +13 -0
- package/build/scrypt/encode.d.ts +8 -0
- package/build/scrypt/encode.js +15 -0
- package/build/scrypt/fromU8a.d.ts +7 -0
- package/build/scrypt/fromU8a.js +24 -0
- package/build/scrypt/index.d.ts +3 -0
- package/build/scrypt/index.js +3 -0
- package/build/scrypt/toU8a.d.ts +2 -0
- package/build/scrypt/toU8a.js +5 -0
- package/build/scrypt/types.d.ts +6 -0
- package/build/scrypt/types.js +1 -0
- package/build/secp256k1/compress.d.ts +1 -0
- package/build/secp256k1/compress.js +14 -0
- package/build/secp256k1/deriveHard.d.ts +1 -0
- package/build/secp256k1/deriveHard.js +10 -0
- package/build/secp256k1/expand.d.ts +1 -0
- package/build/secp256k1/expand.js +17 -0
- package/build/secp256k1/hasher.d.ts +2 -0
- package/build/secp256k1/hasher.js +7 -0
- package/build/secp256k1/index.d.ts +7 -0
- package/build/secp256k1/index.js +7 -0
- package/build/secp256k1/pair/fromSeed.d.ts +6 -0
- package/build/secp256k1/pair/fromSeed.js +31 -0
- package/build/secp256k1/recover.d.ts +6 -0
- package/build/secp256k1/recover.js +26 -0
- package/build/secp256k1/sign.d.ts +7 -0
- package/build/secp256k1/sign.js +20 -0
- package/build/secp256k1/tweakAdd.d.ts +1 -0
- package/build/secp256k1/tweakAdd.js +45 -0
- package/build/secp256k1/types.d.ts +1 -0
- package/build/secp256k1/types.js +1 -0
- package/build/secp256k1/verify.d.ts +6 -0
- package/build/secp256k1/verify.js +20 -0
- package/build/sha/asU8a.d.ts +15 -0
- package/build/sha/asU8a.js +19 -0
- package/build/sha/index.d.ts +4 -0
- package/build/sha/index.js +4 -0
- package/build/signature/index.d.ts +4 -0
- package/build/signature/index.js +4 -0
- package/build/signature/verify.d.ts +2 -0
- package/build/signature/verify.js +78 -0
- package/build/sr25519/agreement.d.ts +5 -0
- package/build/sr25519/agreement.js +17 -0
- package/build/sr25519/derive.d.ts +2 -0
- package/build/sr25519/derive.js +12 -0
- package/build/sr25519/deriveHard.d.ts +1 -0
- package/build/sr25519/deriveHard.js +3 -0
- package/build/sr25519/derivePublic.d.ts +1 -0
- package/build/sr25519/derivePublic.js +12 -0
- package/build/sr25519/deriveSoft.d.ts +1 -0
- package/build/sr25519/deriveSoft.js +3 -0
- package/build/sr25519/index.d.ts +9 -0
- package/build/sr25519/index.js +9 -0
- package/build/sr25519/pair/fromSeed.d.ts +6 -0
- package/build/sr25519/pair/fromSeed.js +18 -0
- package/build/sr25519/pair/fromU8a.d.ts +2 -0
- package/build/sr25519/pair/fromU8a.js +14 -0
- package/build/sr25519/pair/toU8a.d.ts +2 -0
- package/build/sr25519/pair/toU8a.js +4 -0
- package/build/sr25519/sign.d.ts +6 -0
- package/build/sr25519/sign.js +15 -0
- package/build/sr25519/verify.d.ts +5 -0
- package/build/sr25519/verify.js +17 -0
- package/build/sr25519/vrfSign.d.ts +6 -0
- package/build/sr25519/vrfSign.js +15 -0
- package/build/sr25519/vrfVerify.d.ts +5 -0
- package/build/sr25519/vrfVerify.js +18 -0
- package/build/types.d.ts +26 -0
- package/build/types.js +2 -0
- package/build/xxhash/asU8a.d.ts +20 -0
- package/build/xxhash/asU8a.js +35 -0
- package/build/xxhash/index.d.ts +4 -0
- package/build/xxhash/index.js +4 -0
- package/build/xxhash/xxhash64.d.ts +1 -0
- package/build/xxhash/xxhash64.js +100 -0
- package/build-deno/README.md +17 -0
- package/build-deno/address/addressToEvm.ts +10 -0
- package/build-deno/address/check.ts +32 -0
- package/build-deno/address/checksum.ts +23 -0
- package/build-deno/address/decode.ts +38 -0
- package/build-deno/address/defaults.ts +10 -0
- package/build-deno/address/derive.ts +34 -0
- package/build-deno/address/encode.ts +39 -0
- package/build-deno/address/encodeDerived.ts +17 -0
- package/build-deno/address/encodeMulti.ts +16 -0
- package/build-deno/address/eq.ts +22 -0
- package/build-deno/address/evmToAddress.ts +22 -0
- package/build-deno/address/index.ts +18 -0
- package/build-deno/address/is.ts +12 -0
- package/build-deno/address/keyDerived.ts +20 -0
- package/build-deno/address/keyMulti.ts +21 -0
- package/build-deno/address/setSS58Format.ts +18 -0
- package/build-deno/address/sort.ts +15 -0
- package/build-deno/address/sshash.ts +10 -0
- package/build-deno/address/types.ts +2 -0
- package/build-deno/address/util.ts +6 -0
- package/build-deno/address/validate.ts +8 -0
- package/build-deno/base32/bs32.ts +51 -0
- package/build-deno/base32/helpers.ts +90 -0
- package/build-deno/base32/index.ts +6 -0
- package/build-deno/base58/bs58.ts +41 -0
- package/build-deno/base58/index.ts +6 -0
- package/build-deno/base64/bs64.ts +41 -0
- package/build-deno/base64/index.ts +8 -0
- package/build-deno/base64/pad.ts +8 -0
- package/build-deno/base64/trim.ts +12 -0
- package/build-deno/blake2/asU8a.ts +38 -0
- package/build-deno/blake2/index.ts +6 -0
- package/build-deno/bn.ts +13 -0
- package/build-deno/bundle.ts +29 -0
- package/build-deno/bundleInit.ts +8 -0
- package/build-deno/crypto.ts +16 -0
- package/build-deno/ed25519/deriveHard.ts +16 -0
- package/build-deno/ed25519/index.ts +11 -0
- package/build-deno/ed25519/pair/fromRandom.ts +23 -0
- package/build-deno/ed25519/pair/fromSecret.ts +27 -0
- package/build-deno/ed25519/pair/fromSeed.ts +39 -0
- package/build-deno/ed25519/pair/fromString.ts +29 -0
- package/build-deno/ed25519/sign.ts +36 -0
- package/build-deno/ed25519/verify.ts +39 -0
- package/build-deno/ethereum/encode.ts +37 -0
- package/build-deno/ethereum/index.ts +4 -0
- package/build-deno/ethereum/isAddress.ts +14 -0
- package/build-deno/ethereum/isChecksum.ts +25 -0
- package/build-deno/hd/ethereum/index.ts +69 -0
- package/build-deno/hd/index.ts +4 -0
- package/build-deno/hd/ledger/derivePrivate.ts +31 -0
- package/build-deno/hd/ledger/index.ts +40 -0
- package/build-deno/hd/ledger/master.ts +23 -0
- package/build-deno/hd/validatePath.ts +22 -0
- package/build-deno/helpers.ts +35 -0
- package/build-deno/hmac/index.ts +2 -0
- package/build-deno/hmac/shaAsU8a.ts +46 -0
- package/build-deno/index.ts +4 -0
- package/build-deno/json/constants.ts +9 -0
- package/build-deno/json/decrypt.ts +23 -0
- package/build-deno/json/decryptData.ts +43 -0
- package/build-deno/json/encrypt.ts +23 -0
- package/build-deno/json/encryptFormat.ts +18 -0
- package/build-deno/json/index.ts +5 -0
- package/build-deno/json/types.ts +20 -0
- package/build-deno/keccak/asU8a.ts +45 -0
- package/build-deno/keccak/index.ts +6 -0
- package/build-deno/key/DeriveJunction.ts +77 -0
- package/build-deno/key/extractPath.ts +35 -0
- package/build-deno/key/extractSuri.ts +38 -0
- package/build-deno/key/fromPath.ts +26 -0
- package/build-deno/key/hdkdDerive.ts +15 -0
- package/build-deno/key/hdkdEcdsa.ts +6 -0
- package/build-deno/key/hdkdEd25519.ts +5 -0
- package/build-deno/key/hdkdSr25519.ts +12 -0
- package/build-deno/key/index.ts +10 -0
- package/build-deno/mnemonic/bip39.ts +115 -0
- package/build-deno/mnemonic/generate.ts +23 -0
- package/build-deno/mnemonic/index.ts +9 -0
- package/build-deno/mnemonic/toEntropy.ts +11 -0
- package/build-deno/mnemonic/toLegacySeed.ts +37 -0
- package/build-deno/mnemonic/toMiniSecret.ts +21 -0
- package/build-deno/mnemonic/validate.ts +24 -0
- package/build-deno/mnemonic/wordlists/en.ts +3 -0
- package/build-deno/mnemonic/wordlists/es.ts +3 -0
- package/build-deno/mnemonic/wordlists/fr.ts +3 -0
- package/build-deno/mnemonic/wordlists/index.ts +9 -0
- package/build-deno/mnemonic/wordlists/it.ts +3 -0
- package/build-deno/mnemonic/wordlists/jp.ts +3 -0
- package/build-deno/mnemonic/wordlists/ko.ts +3 -0
- package/build-deno/mnemonic/wordlists/zh-s.ts +3 -0
- package/build-deno/mnemonic/wordlists/zh-t.ts +3 -0
- package/build-deno/mod.ts +2 -0
- package/build-deno/nacl/decrypt.ts +20 -0
- package/build-deno/nacl/encrypt.ts +29 -0
- package/build-deno/nacl/index.ts +6 -0
- package/build-deno/nacl/tweetnacl.ts +344 -0
- package/build-deno/networks.ts +2 -0
- package/build-deno/packageDetect.ts +10 -0
- package/build-deno/packageInfo.ts +3 -0
- package/build-deno/pbkdf2/encode.ts +27 -0
- package/build-deno/pbkdf2/index.ts +2 -0
- package/build-deno/random/asNumber.ts +26 -0
- package/build-deno/random/asU8a.ts +28 -0
- package/build-deno/random/index.ts +7 -0
- package/build-deno/scrypt/defaults.ts +17 -0
- package/build-deno/scrypt/encode.ts +28 -0
- package/build-deno/scrypt/fromU8a.ts +42 -0
- package/build-deno/scrypt/index.ts +4 -0
- package/build-deno/scrypt/toU8a.ts +15 -0
- package/build-deno/scrypt/types.ts +7 -0
- package/build-deno/secp256k1/compress.ts +19 -0
- package/build-deno/secp256k1/deriveHard.ts +15 -0
- package/build-deno/secp256k1/expand.ts +28 -0
- package/build-deno/secp256k1/hasher.ts +11 -0
- package/build-deno/secp256k1/index.ts +8 -0
- package/build-deno/secp256k1/pair/fromSeed.ts +40 -0
- package/build-deno/secp256k1/recover.ts +34 -0
- package/build-deno/secp256k1/sign.ts +35 -0
- package/build-deno/secp256k1/tweakAdd.ts +61 -0
- package/build-deno/secp256k1/types.ts +2 -0
- package/build-deno/secp256k1/verify.ts +30 -0
- package/build-deno/sha/asU8a.ts +28 -0
- package/build-deno/sha/index.ts +6 -0
- package/build-deno/signature/index.ts +6 -0
- package/build-deno/signature/verify.ts +112 -0
- package/build-deno/sr25519/agreement.ts +21 -0
- package/build-deno/sr25519/derive.ts +19 -0
- package/build-deno/sr25519/deriveHard.ts +6 -0
- package/build-deno/sr25519/derivePublic.ts +16 -0
- package/build-deno/sr25519/deriveSoft.ts +6 -0
- package/build-deno/sr25519/index.ts +10 -0
- package/build-deno/sr25519/pair/fromSeed.ts +26 -0
- package/build-deno/sr25519/pair/fromU8a.ts +21 -0
- package/build-deno/sr25519/pair/toU8a.ts +8 -0
- package/build-deno/sr25519/sign.ts +20 -0
- package/build-deno/sr25519/verify.ts +21 -0
- package/build-deno/sr25519/vrfSign.ts +22 -0
- package/build-deno/sr25519/vrfVerify.ts +23 -0
- package/build-deno/test/index.ts +4 -0
- package/build-deno/test/performance.ts +15 -0
- package/build-deno/types.ts +31 -0
- package/build-deno/xxhash/asU8a.ts +45 -0
- package/build-deno/xxhash/index.ts +6 -0
- package/build-deno/xxhash/xxhash64.ts +138 -0
- package/build-tsc/address/encodeDerived.d.ts +9 -0
- package/build-tsc/address/encodeMulti.d.ts +9 -0
- package/build-tsc/address/eq.d.ts +15 -0
- package/build-tsc/address/keyDerived.d.ts +2 -0
- package/build-tsc/address/keyMulti.d.ts +2 -0
- package/build-tsc/base32/bs32.d.ts +26 -0
- package/build-tsc/base32/helpers.d.ts +25 -0
- package/build-tsc/base58/bs58.d.ts +26 -0
- package/build-tsc/base64/bs64.d.ts +26 -0
- package/build-tsc/blake2/asU8a.d.ts +20 -0
- package/build-tsc/bundleInit.d.ts +1 -0
- package/build-tsc/crypto.d.ts +3 -0
- package/build-tsc/ed25519/pair/fromRandom.d.ts +16 -0
- package/build-tsc/ed25519/pair/fromSecret.d.ts +16 -0
- package/build-tsc/ed25519/pair/fromSeed.d.ts +16 -0
- package/build-tsc/ed25519/pair/fromString.d.ts +16 -0
- package/build-tsc/ed25519/sign.d.ts +16 -0
- package/build-tsc/ed25519/verify.d.ts +15 -0
- package/build-tsc/ethereum/encode.d.ts +2 -0
- package/build-tsc/helpers.d.ts +12 -0
- package/build-tsc/keccak/asU8a.d.ts +30 -0
- package/build-tsc/key/DeriveJunction.d.ts +12 -0
- package/build-tsc/mnemonic/generate.d.ts +13 -0
- package/build-tsc/mnemonic/toLegacySeed.d.ts +18 -0
- package/build-tsc/mnemonic/validate.d.ts +14 -0
- package/build-tsc/nacl/decrypt.d.ts +15 -0
- package/build-tsc/nacl/encrypt.d.ts +20 -0
- package/build-tsc/networks.d.ts +1 -0
- package/build-tsc/random/asNumber.d.ts +15 -0
- package/build-tsc/random/asU8a.d.ts +20 -0
- package/build-tsc/xxhash/asU8a.d.ts +20 -0
- package/build-tsc-cjs/packageDetect.js +8 -0
- package/build-tsc-cjs/packageInfo.js +4 -0
- package/build-tsc-esm/packageInfo.js +1 -0
- package/package.json +10 -2022
- package/src/address/addressToEvm.spec.ts +16 -0
- package/src/address/addressToEvm.ts +12 -0
- package/src/address/check.spec.ts +44 -0
- package/src/address/check.ts +34 -0
- package/src/address/checksum.spec.ts +45 -0
- package/src/address/checksum.ts +25 -0
- package/src/address/decode.spec.ts +138 -0
- package/src/address/decode.ts +41 -0
- package/src/address/defaults.ts +12 -0
- package/src/address/derive.spec.ts +26 -0
- package/src/address/derive.ts +36 -0
- package/src/address/encode.spec.ts +177 -0
- package/src/address/encode.ts +43 -0
- package/src/address/encodeDerived.spec.ts +14 -0
- package/src/address/encodeDerived.ts +19 -0
- package/src/address/encodeMulti.spec.ts +18 -0
- package/src/address/encodeMulti.ts +18 -0
- package/src/address/eq.spec.ts +45 -0
- package/src/address/eq.ts +24 -0
- package/src/address/evmToAddress.spec.ts +20 -0
- package/src/address/evmToAddress.ts +24 -0
- package/src/address/index.ts +21 -0
- package/src/address/is.spec.ts +113 -0
- package/src/address/is.ts +14 -0
- package/src/address/keyDerived.spec.ts +24 -0
- package/src/address/keyDerived.ts +22 -0
- package/src/address/keyMulti.spec.ts +20 -0
- package/src/address/keyMulti.ts +23 -0
- package/src/address/setSS58Format.spec.ts +21 -0
- package/src/address/setSS58Format.ts +20 -0
- package/src/address/sort.spec.ts +22 -0
- package/src/address/sort.ts +17 -0
- package/src/address/sshash.ts +12 -0
- package/src/address/types.ts +6 -0
- package/src/address/util.ts +8 -0
- package/src/address/validate.spec.ts +113 -0
- package/src/address/validate.ts +10 -0
- package/src/base32/bs32.ts +53 -0
- package/src/base32/decode.spec.ts +34 -0
- package/src/base32/encode.spec.ts +30 -0
- package/src/base32/helpers.ts +93 -0
- package/src/base32/index.ts +8 -0
- package/src/base32/is.spec.ts +32 -0
- package/src/base32/validate.spec.ts +44 -0
- package/src/base58/bs58.ts +43 -0
- package/src/base58/decode.spec.ts +31 -0
- package/src/base58/encode.spec.ts +26 -0
- package/src/base58/index.ts +8 -0
- package/src/base58/validate.spec.ts +20 -0
- package/src/base64/bs64.ts +43 -0
- package/src/base64/decode.spec.ts +42 -0
- package/src/base64/encode.spec.ts +14 -0
- package/src/base64/index.ts +10 -0
- package/src/base64/pad.spec.ts +14 -0
- package/src/base64/pad.ts +10 -0
- package/src/base64/trim.spec.ts +14 -0
- package/src/base64/trim.ts +14 -0
- package/src/base64/validate.spec.ts +32 -0
- package/src/blake2/asHex.spec.ts +57 -0
- package/src/blake2/asU8a.spec.ts +74 -0
- package/src/blake2/asU8a.ts +40 -0
- package/src/blake2/index.ts +8 -0
- package/src/bn.ts +15 -0
- package/src/bundle.ts +33 -0
- package/src/bundleInit.ts +11 -0
- package/src/crypto.spec.ts +18 -0
- package/src/crypto.ts +18 -0
- package/src/ed25519/deriveHard.ts +18 -0
- package/src/ed25519/index.ts +13 -0
- package/src/ed25519/pair/fromRandom.spec.ts +28 -0
- package/src/ed25519/pair/fromRandom.ts +25 -0
- package/src/ed25519/pair/fromSecret.spec.ts +33 -0
- package/src/ed25519/pair/fromSecret.ts +29 -0
- package/src/ed25519/pair/fromSeed.spec.ts +42 -0
- package/src/ed25519/pair/fromSeed.ts +41 -0
- package/src/ed25519/pair/fromString.spec.ts +17 -0
- package/src/ed25519/pair/fromString.ts +31 -0
- package/src/ed25519/sign.spec.ts +40 -0
- package/src/ed25519/sign.ts +38 -0
- package/src/ed25519/verify.spec.ts +84 -0
- package/src/ed25519/verify.ts +41 -0
- package/src/ethereum/encode.spec.ts +59 -0
- package/src/ethereum/encode.ts +39 -0
- package/src/ethereum/index.ts +6 -0
- package/src/ethereum/isAddress.spec.ts +34 -0
- package/src/ethereum/isAddress.ts +16 -0
- package/src/ethereum/isChecksum.ts +27 -0
- package/src/ethereum/isCheksum.spec.ts +30 -0
- package/src/hd/ethereum/index.spec.ts +54 -0
- package/src/hd/ethereum/index.ts +69 -0
- package/src/hd/index.ts +6 -0
- package/src/hd/ledger/derivePrivate.ts +34 -0
- package/src/hd/ledger/index.spec.ts +64 -0
- package/src/hd/ledger/index.ts +42 -0
- package/src/hd/ledger/master.spec.ts +19 -0
- package/src/hd/ledger/master.ts +26 -0
- package/src/hd/validatePath.spec.ts +30 -0
- package/src/hd/validatePath.ts +24 -0
- package/src/helpers.ts +38 -0
- package/src/hmac/index.ts +4 -0
- package/src/hmac/shaAsU8a.spec.ts +45 -0
- package/src/hmac/shaAsU8a.ts +48 -0
- package/src/index.ts +6 -0
- package/src/json/constants.ts +11 -0
- package/src/json/decrypt.ts +25 -0
- package/src/json/decryptData.ts +45 -0
- package/src/json/encrypt.ts +25 -0
- package/src/json/encryptFormat.ts +20 -0
- package/src/json/index.ts +7 -0
- package/src/json/types.ts +22 -0
- package/src/keccak/asHex.spec.ts +30 -0
- package/src/keccak/asU8a.spec.ts +56 -0
- package/src/keccak/asU8a.ts +45 -0
- package/src/keccak/index.ts +8 -0
- package/src/key/DeriveJunction.ts +79 -0
- package/src/key/extractPath.spec.ts +51 -0
- package/src/key/extractPath.ts +37 -0
- package/src/key/extractSuri.spec.ts +147 -0
- package/src/key/extractSuri.ts +40 -0
- package/src/key/fromPath.ts +28 -0
- package/src/key/hdkdDerive.ts +17 -0
- package/src/key/hdkdEcdsa.ts +8 -0
- package/src/key/hdkdEd25519.ts +7 -0
- package/src/key/hdkdSr25519.ts +14 -0
- package/src/key/index.ts +12 -0
- package/src/mnemonic/bip39.spec.ts +80 -0
- package/src/mnemonic/bip39.ts +127 -0
- package/src/mnemonic/generate.spec.ts +58 -0
- package/src/mnemonic/generate.ts +25 -0
- package/src/mnemonic/index.ts +11 -0
- package/src/mnemonic/toEntropy.spec.ts +36 -0
- package/src/mnemonic/toEntropy.ts +13 -0
- package/src/mnemonic/toLegacySeed.spec.ts +52 -0
- package/src/mnemonic/toLegacySeed.ts +39 -0
- package/src/mnemonic/toMiniSecret.spec.ts +67 -0
- package/src/mnemonic/toMiniSecret.ts +23 -0
- package/src/mnemonic/toMiniSecretCmp.spec.ts +64 -0
- package/src/mnemonic/validate.spec.ts +39 -0
- package/src/mnemonic/validate.ts +26 -0
- package/src/mnemonic/wordlists/en.ts +7 -0
- package/src/mnemonic/wordlists/es.ts +7 -0
- package/src/mnemonic/wordlists/fr.ts +7 -0
- package/src/mnemonic/wordlists/index.ts +11 -0
- package/src/mnemonic/wordlists/it.ts +7 -0
- package/src/mnemonic/wordlists/jp.ts +7 -0
- package/src/mnemonic/wordlists/ko.ts +7 -0
- package/src/mnemonic/wordlists/zh-s.ts +7 -0
- package/src/mnemonic/wordlists/zh-t.ts +7 -0
- package/src/mod.ts +4 -0
- package/src/nacl/decrypt.spec.ts +26 -0
- package/src/nacl/decrypt.ts +22 -0
- package/src/nacl/encrypt.spec.ts +20 -0
- package/src/nacl/encrypt.ts +31 -0
- package/src/nacl/index.ts +8 -0
- package/src/nacl/tweetnacl-secretbox-data.spec.ts +4629 -0
- package/src/nacl/tweetnacl-secretbox.spec.ts +161 -0
- package/src/nacl/tweetnacl.ts +1159 -0
- package/src/networks.ts +5 -0
- package/src/packageDetect.ts +14 -0
- package/src/packageInfo.ts +6 -0
- package/src/pbkdf2/encode.spec.ts +54 -0
- package/src/pbkdf2/encode.ts +29 -0
- package/src/pbkdf2/index.ts +4 -0
- package/src/random/asHex.spec.ts +38 -0
- package/src/random/asNumber.spec.ts +16 -0
- package/src/random/asNumber.ts +28 -0
- package/src/random/asU8a.spec.ts +36 -0
- package/src/random/asU8a.ts +30 -0
- package/src/random/index.ts +9 -0
- package/src/scrypt/defaults.ts +19 -0
- package/src/scrypt/encode.spec.ts +43 -0
- package/src/scrypt/encode.ts +30 -0
- package/src/scrypt/fromU8a.ts +44 -0
- package/src/scrypt/index.ts +6 -0
- package/src/scrypt/toU8a.ts +17 -0
- package/src/scrypt/types.ts +9 -0
- package/src/secp256k1/compress.spec.ts +47 -0
- package/src/secp256k1/compress.ts +21 -0
- package/src/secp256k1/deriveHard.ts +17 -0
- package/src/secp256k1/expand.spec.ts +47 -0
- package/src/secp256k1/expand.ts +30 -0
- package/src/secp256k1/hasher.spec.ts +24 -0
- package/src/secp256k1/hasher.ts +13 -0
- package/src/secp256k1/index.ts +10 -0
- package/src/secp256k1/pair/fromSeed.spec.ts +75 -0
- package/src/secp256k1/pair/fromSeed.ts +42 -0
- package/src/secp256k1/recover.spec.ts +35 -0
- package/src/secp256k1/recover.ts +36 -0
- package/src/secp256k1/sign.spec.ts +39 -0
- package/src/secp256k1/sign.ts +37 -0
- package/src/secp256k1/signVerify.spec.ts +94 -0
- package/src/secp256k1/tweakAdd.spec.ts +35 -0
- package/src/secp256k1/tweakAdd.ts +65 -0
- package/src/secp256k1/types.ts +4 -0
- package/src/secp256k1/verify.spec.ts +81 -0
- package/src/secp256k1/verify.ts +32 -0
- package/src/sha/asU8a.ts +30 -0
- package/src/sha/asU8a256.spec.ts +55 -0
- package/src/sha/asU8a512.spec.ts +33 -0
- package/src/sha/index.ts +8 -0
- package/src/signature/index.ts +8 -0
- package/src/signature/verify.spec.ts +230 -0
- package/src/signature/verify.ts +114 -0
- package/src/sr25519/agreement.spec.ts +31 -0
- package/src/sr25519/agreement.ts +23 -0
- package/src/sr25519/derive.ts +21 -0
- package/src/sr25519/deriveHard.ts +9 -0
- package/src/sr25519/derivePublic.ts +18 -0
- package/src/sr25519/deriveSoft.ts +9 -0
- package/src/sr25519/index.ts +12 -0
- package/src/sr25519/pair/fromSeed.spec.ts +35 -0
- package/src/sr25519/pair/fromSeed.ts +28 -0
- package/src/sr25519/pair/fromU8a.ts +23 -0
- package/src/sr25519/pair/testing.spec.ts +161 -0
- package/src/sr25519/pair/toU8a.ts +10 -0
- package/src/sr25519/sign.spec.ts +28 -0
- package/src/sr25519/sign.ts +22 -0
- package/src/sr25519/verify.spec.ts +42 -0
- package/src/sr25519/verify.ts +23 -0
- package/src/sr25519/vrfSign.ts +24 -0
- package/src/sr25519/vrfSignVerify.spec.ts +73 -0
- package/src/sr25519/vrfVerify.ts +25 -0
- package/src/test/index.ts +8 -0
- package/src/test/performance.ts +17 -0
- package/src/types.ts +33 -0
- package/src/xxhash/asHex.spec.ts +36 -0
- package/src/xxhash/asU8a.spec.ts +48 -0
- package/src/xxhash/asU8a.ts +45 -0
- package/src/xxhash/index.ts +8 -0
- package/src/xxhash/xxhash64.ts +155 -0
- package/tsconfig.build.json +18 -0
- package/tsconfig.build.tsbuildinfo +1 -0
- package/tsconfig.spec.json +20 -0
- package/tsconfig.spec.tsbuildinfo +1 -0
- package/address/encodeDerived.d.ts +0 -9
- package/address/encodeMulti.d.ts +0 -9
- package/address/eq.d.ts +0 -15
- package/address/keyDerived.d.ts +0 -2
- package/address/keyMulti.d.ts +0 -2
- package/base32/bs32.d.ts +0 -26
- package/base32/helpers.d.ts +0 -25
- package/base58/bs58.d.ts +0 -26
- package/base64/bs64.d.ts +0 -26
- package/blake2/asU8a.d.ts +0 -20
- package/bridge.d.ts +0 -82
- package/bridge.js +0 -168
- package/bundle-polkadot-util-crypto.js +0 -11813
- package/bundleInit.d.ts +0 -1
- package/cjs/address/encodeDerived.d.ts +0 -9
- package/cjs/address/encodeMulti.d.ts +0 -9
- package/cjs/address/eq.d.ts +0 -15
- package/cjs/address/keyDerived.d.ts +0 -2
- package/cjs/address/keyMulti.d.ts +0 -2
- package/cjs/base32/bs32.d.ts +0 -26
- package/cjs/base32/helpers.d.ts +0 -25
- package/cjs/base58/bs58.d.ts +0 -26
- package/cjs/base64/bs64.d.ts +0 -26
- package/cjs/blake2/asU8a.d.ts +0 -20
- package/cjs/bridge.d.ts +0 -82
- package/cjs/bridge.js +0 -172
- package/cjs/bundleInit.d.ts +0 -1
- package/cjs/crypto.d.ts +0 -3
- package/cjs/ed25519/pair/fromRandom.d.ts +0 -16
- package/cjs/ed25519/pair/fromSecret.d.ts +0 -16
- package/cjs/ed25519/pair/fromSeed.d.ts +0 -16
- package/cjs/ed25519/pair/fromString.d.ts +0 -16
- package/cjs/ed25519/sign.d.ts +0 -16
- package/cjs/ed25519/verify.d.ts +0 -15
- package/cjs/ethereum/encode.d.ts +0 -2
- package/cjs/helpers.d.ts +0 -12
- package/cjs/init.d.ts +0 -10
- package/cjs/init.js +0 -43
- package/cjs/keccak/asU8a.d.ts +0 -30
- package/cjs/key/DeriveJunction.d.ts +0 -12
- package/cjs/mnemonic/generate.d.ts +0 -13
- package/cjs/mnemonic/toLegacySeed.d.ts +0 -18
- package/cjs/mnemonic/validate.d.ts +0 -14
- package/cjs/nacl/decrypt.d.ts +0 -15
- package/cjs/nacl/encrypt.d.ts +0 -20
- package/cjs/networks.d.ts +0 -1
- package/cjs/packageInfo.js +0 -4
- package/cjs/random/asNumber.d.ts +0 -15
- package/cjs/random/asU8a.d.ts +0 -20
- package/cjs/wbg.d.ts +0 -36
- package/cjs/wbg.js +0 -65
- package/cjs/xxhash/asU8a.d.ts +0 -20
- package/crypto.d.ts +0 -3
- package/ed25519/pair/fromRandom.d.ts +0 -16
- package/ed25519/pair/fromSecret.d.ts +0 -16
- package/ed25519/pair/fromSeed.d.ts +0 -16
- package/ed25519/pair/fromString.d.ts +0 -16
- package/ed25519/sign.d.ts +0 -16
- package/ed25519/verify.d.ts +0 -15
- package/ethereum/encode.d.ts +0 -2
- package/helpers.d.ts +0 -12
- package/init.d.ts +0 -10
- package/init.js +0 -40
- package/keccak/asU8a.d.ts +0 -30
- package/key/DeriveJunction.d.ts +0 -12
- package/mnemonic/generate.d.ts +0 -13
- package/mnemonic/toLegacySeed.d.ts +0 -18
- package/mnemonic/validate.d.ts +0 -14
- package/nacl/decrypt.d.ts +0 -15
- package/nacl/encrypt.d.ts +0 -20
- package/networks.d.ts +0 -1
- package/packageInfo.js +0 -1
- package/random/asNumber.d.ts +0 -15
- package/random/asU8a.d.ts +0 -20
- package/wbg.d.ts +0 -36
- package/wbg.js +0 -61
- package/xxhash/asU8a.d.ts +0 -20
- /package/{LICENSE → build/LICENSE} +0 -0
- /package/{cjs → build}/address/addressToEvm.d.ts +0 -0
- /package/{cjs → build}/address/check.d.ts +0 -0
- /package/{cjs → build}/address/checksum.d.ts +0 -0
- /package/{cjs → build}/address/decode.d.ts +0 -0
- /package/{cjs → build}/address/defaults.d.ts +0 -0
- /package/{cjs → build}/address/derive.d.ts +0 -0
- /package/{cjs → build}/address/encode.d.ts +0 -0
- /package/{cjs → build}/address/evmToAddress.d.ts +0 -0
- /package/{cjs → build}/address/index.d.ts +0 -0
- /package/{cjs → build}/address/is.d.ts +0 -0
- /package/{cjs → build}/address/setSS58Format.d.ts +0 -0
- /package/{cjs → build}/address/sort.d.ts +0 -0
- /package/{cjs → build}/address/sshash.d.ts +0 -0
- /package/{cjs → build}/address/types.d.ts +0 -0
- /package/{packageDetect.d.ts → build/address/types.js} +0 -0
- /package/{cjs → build}/address/util.d.ts +0 -0
- /package/{cjs → build}/address/validate.d.ts +0 -0
- /package/{cjs → build}/base32/index.d.ts +0 -0
- /package/{cjs → build}/base58/index.d.ts +0 -0
- /package/{cjs → build}/base64/index.d.ts +0 -0
- /package/{cjs → build}/base64/pad.d.ts +0 -0
- /package/{cjs → build}/base64/trim.d.ts +0 -0
- /package/{cjs → build}/blake2/index.d.ts +0 -0
- /package/{cjs → build}/bn.d.ts +0 -0
- /package/{cjs → build}/bundle.d.ts +0 -0
- /package/{ed25519 → build/cjs/ed25519}/deriveHard.d.ts +0 -0
- /package/{ed25519 → build/cjs/ed25519}/index.d.ts +0 -0
- /package/{ethereum → build/cjs/ethereum}/index.d.ts +0 -0
- /package/{ethereum → build/cjs/ethereum}/isAddress.d.ts +0 -0
- /package/{ethereum → build/cjs/ethereum}/isChecksum.d.ts +0 -0
- /package/{hd → build/cjs/hd}/ethereum/index.d.ts +0 -0
- /package/{hd → build/cjs/hd}/index.d.ts +0 -0
- /package/{hd → build/cjs/hd}/ledger/derivePrivate.d.ts +0 -0
- /package/{hd → build/cjs/hd}/ledger/index.d.ts +0 -0
- /package/{hd → build/cjs/hd}/ledger/master.d.ts +0 -0
- /package/{hd → build/cjs/hd}/validatePath.d.ts +0 -0
- /package/{hmac → build/cjs/hmac}/index.d.ts +0 -0
- /package/{hmac → build/cjs/hmac}/shaAsU8a.d.ts +0 -0
- /package/{index.d.ts → build/cjs/index.d.ts} +0 -0
- /package/{json → build/cjs/json}/constants.d.ts +0 -0
- /package/{json → build/cjs/json}/decrypt.d.ts +0 -0
- /package/{json → build/cjs/json}/decryptData.d.ts +0 -0
- /package/{json → build/cjs/json}/encrypt.d.ts +0 -0
- /package/{json → build/cjs/json}/encryptFormat.d.ts +0 -0
- /package/{json → build/cjs/json}/index.d.ts +0 -0
- /package/{json → build/cjs/json}/types.d.ts +0 -0
- /package/{keccak → build/cjs/keccak}/index.d.ts +0 -0
- /package/{key → build/cjs/key}/extractPath.d.ts +0 -0
- /package/{key → build/cjs/key}/extractSuri.d.ts +0 -0
- /package/{key → build/cjs/key}/fromPath.d.ts +0 -0
- /package/{key → build/cjs/key}/hdkdDerive.d.ts +0 -0
- /package/{key → build/cjs/key}/hdkdEcdsa.d.ts +0 -0
- /package/{key → build/cjs/key}/hdkdEd25519.d.ts +0 -0
- /package/{key → build/cjs/key}/hdkdSr25519.d.ts +0 -0
- /package/{key → build/cjs/key}/index.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/bip39.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/index.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/toEntropy.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/toMiniSecret.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/wordlists/en.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/wordlists/es.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/wordlists/fr.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/wordlists/index.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/wordlists/it.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/wordlists/jp.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/wordlists/ko.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/wordlists/zh-s.d.ts +0 -0
- /package/{mnemonic → build/cjs/mnemonic}/wordlists/zh-t.d.ts +0 -0
- /package/{nacl → build/cjs/nacl}/index.d.ts +0 -0
- /package/{nacl → build/cjs/nacl}/tweetnacl.d.ts +0 -0
- /package/{cjs → build/cjs}/package.json +0 -0
- /package/{cjs → build/cjs}/packageDetect.js +0 -0
- /package/{packageInfo.d.ts → build/cjs/packageInfo.d.ts} +0 -0
- /package/{pbkdf2 → build/cjs/pbkdf2}/encode.d.ts +0 -0
- /package/{pbkdf2 → build/cjs/pbkdf2}/index.d.ts +0 -0
- /package/{random → build/cjs/random}/index.d.ts +0 -0
- /package/{scrypt → build/cjs/scrypt}/defaults.d.ts +0 -0
- /package/{scrypt → build/cjs/scrypt}/encode.d.ts +0 -0
- /package/{scrypt → build/cjs/scrypt}/fromU8a.d.ts +0 -0
- /package/{scrypt → build/cjs/scrypt}/index.d.ts +0 -0
- /package/{scrypt → build/cjs/scrypt}/toU8a.d.ts +0 -0
- /package/{scrypt → build/cjs/scrypt}/types.d.ts +0 -0
- /package/{secp256k1 → build/cjs/secp256k1}/compress.d.ts +0 -0
- /package/{secp256k1 → build/cjs/secp256k1}/deriveHard.d.ts +0 -0
- /package/{secp256k1 → build/cjs/secp256k1}/expand.d.ts +0 -0
- /package/{secp256k1 → build/cjs/secp256k1}/hasher.d.ts +0 -0
- /package/{secp256k1 → build/cjs/secp256k1}/index.d.ts +0 -0
- /package/{secp256k1 → build/cjs/secp256k1}/pair/fromSeed.d.ts +0 -0
- /package/{secp256k1 → build/cjs/secp256k1}/recover.d.ts +0 -0
- /package/{secp256k1 → build/cjs/secp256k1}/sign.d.ts +0 -0
- /package/{secp256k1 → build/cjs/secp256k1}/tweakAdd.d.ts +0 -0
- /package/{secp256k1 → build/cjs/secp256k1}/types.d.ts +0 -0
- /package/{secp256k1 → build/cjs/secp256k1}/verify.d.ts +0 -0
- /package/{sha → build/cjs/sha}/asU8a.d.ts +0 -0
- /package/{sha → build/cjs/sha}/index.d.ts +0 -0
- /package/{signature → build/cjs/signature}/index.d.ts +0 -0
- /package/{signature → build/cjs/signature}/verify.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/agreement.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/derive.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/deriveHard.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/derivePublic.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/deriveSoft.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/index.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/pair/fromSeed.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/pair/fromU8a.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/pair/toU8a.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/sign.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/verify.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/vrfSign.d.ts +0 -0
- /package/{sr25519 → build/cjs/sr25519}/vrfVerify.d.ts +0 -0
- /package/{types.d.ts → build/cjs/types.d.ts} +0 -0
- /package/{xxhash → build/cjs/xxhash}/index.d.ts +0 -0
- /package/{xxhash → build/cjs/xxhash}/xxhash64.d.ts +0 -0
- /package/{address → build-tsc/address}/addressToEvm.d.ts +0 -0
- /package/{address → build-tsc/address}/check.d.ts +0 -0
- /package/{address → build-tsc/address}/checksum.d.ts +0 -0
- /package/{address → build-tsc/address}/decode.d.ts +0 -0
- /package/{address → build-tsc/address}/defaults.d.ts +0 -0
- /package/{address → build-tsc/address}/derive.d.ts +0 -0
- /package/{address → build-tsc/address}/encode.d.ts +0 -0
- /package/{address → build-tsc/address}/evmToAddress.d.ts +0 -0
- /package/{address → build-tsc/address}/index.d.ts +0 -0
- /package/{address → build-tsc/address}/is.d.ts +0 -0
- /package/{address → build-tsc/address}/setSS58Format.d.ts +0 -0
- /package/{address → build-tsc/address}/sort.d.ts +0 -0
- /package/{address → build-tsc/address}/sshash.d.ts +0 -0
- /package/{address → build-tsc/address}/types.d.ts +0 -0
- /package/{address → build-tsc/address}/util.d.ts +0 -0
- /package/{address → build-tsc/address}/validate.d.ts +0 -0
- /package/{base32 → build-tsc/base32}/index.d.ts +0 -0
- /package/{base58 → build-tsc/base58}/index.d.ts +0 -0
- /package/{base64 → build-tsc/base64}/index.d.ts +0 -0
- /package/{base64 → build-tsc/base64}/pad.d.ts +0 -0
- /package/{base64 → build-tsc/base64}/trim.d.ts +0 -0
- /package/{blake2 → build-tsc/blake2}/index.d.ts +0 -0
- /package/{bn.d.ts → build-tsc/bn.d.ts} +0 -0
- /package/{bundle.d.ts → build-tsc/bundle.d.ts} +0 -0
- /package/{cjs → build-tsc}/ed25519/deriveHard.d.ts +0 -0
- /package/{cjs → build-tsc}/ed25519/index.d.ts +0 -0
- /package/{cjs → build-tsc}/ethereum/index.d.ts +0 -0
- /package/{cjs → build-tsc}/ethereum/isAddress.d.ts +0 -0
- /package/{cjs → build-tsc}/ethereum/isChecksum.d.ts +0 -0
- /package/{cjs → build-tsc}/hd/ethereum/index.d.ts +0 -0
- /package/{cjs → build-tsc}/hd/index.d.ts +0 -0
- /package/{cjs → build-tsc}/hd/ledger/derivePrivate.d.ts +0 -0
- /package/{cjs → build-tsc}/hd/ledger/index.d.ts +0 -0
- /package/{cjs → build-tsc}/hd/ledger/master.d.ts +0 -0
- /package/{cjs → build-tsc}/hd/validatePath.d.ts +0 -0
- /package/{cjs → build-tsc}/hmac/index.d.ts +0 -0
- /package/{cjs → build-tsc}/hmac/shaAsU8a.d.ts +0 -0
- /package/{cjs → build-tsc}/index.d.ts +0 -0
- /package/{cjs → build-tsc}/json/constants.d.ts +0 -0
- /package/{cjs → build-tsc}/json/decrypt.d.ts +0 -0
- /package/{cjs → build-tsc}/json/decryptData.d.ts +0 -0
- /package/{cjs → build-tsc}/json/encrypt.d.ts +0 -0
- /package/{cjs → build-tsc}/json/encryptFormat.d.ts +0 -0
- /package/{cjs → build-tsc}/json/index.d.ts +0 -0
- /package/{cjs → build-tsc}/json/types.d.ts +0 -0
- /package/{cjs → build-tsc}/keccak/index.d.ts +0 -0
- /package/{cjs → build-tsc}/key/extractPath.d.ts +0 -0
- /package/{cjs → build-tsc}/key/extractSuri.d.ts +0 -0
- /package/{cjs → build-tsc}/key/fromPath.d.ts +0 -0
- /package/{cjs → build-tsc}/key/hdkdDerive.d.ts +0 -0
- /package/{cjs → build-tsc}/key/hdkdEcdsa.d.ts +0 -0
- /package/{cjs → build-tsc}/key/hdkdEd25519.d.ts +0 -0
- /package/{cjs → build-tsc}/key/hdkdSr25519.d.ts +0 -0
- /package/{cjs → build-tsc}/key/index.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/bip39.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/index.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/toEntropy.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/toMiniSecret.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/wordlists/en.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/wordlists/es.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/wordlists/fr.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/wordlists/index.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/wordlists/it.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/wordlists/jp.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/wordlists/ko.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/wordlists/zh-s.d.ts +0 -0
- /package/{cjs → build-tsc}/mnemonic/wordlists/zh-t.d.ts +0 -0
- /package/{cjs → build-tsc}/nacl/index.d.ts +0 -0
- /package/{cjs → build-tsc}/nacl/tweetnacl.d.ts +0 -0
- /package/{cjs → build-tsc}/packageDetect.d.ts +0 -0
- /package/{cjs → build-tsc}/packageInfo.d.ts +0 -0
- /package/{cjs → build-tsc}/pbkdf2/encode.d.ts +0 -0
- /package/{cjs → build-tsc}/pbkdf2/index.d.ts +0 -0
- /package/{cjs → build-tsc}/random/index.d.ts +0 -0
- /package/{cjs → build-tsc}/scrypt/defaults.d.ts +0 -0
- /package/{cjs → build-tsc}/scrypt/encode.d.ts +0 -0
- /package/{cjs → build-tsc}/scrypt/fromU8a.d.ts +0 -0
- /package/{cjs → build-tsc}/scrypt/index.d.ts +0 -0
- /package/{cjs → build-tsc}/scrypt/toU8a.d.ts +0 -0
- /package/{cjs → build-tsc}/scrypt/types.d.ts +0 -0
- /package/{cjs → build-tsc}/secp256k1/compress.d.ts +0 -0
- /package/{cjs → build-tsc}/secp256k1/deriveHard.d.ts +0 -0
- /package/{cjs → build-tsc}/secp256k1/expand.d.ts +0 -0
- /package/{cjs → build-tsc}/secp256k1/hasher.d.ts +0 -0
- /package/{cjs → build-tsc}/secp256k1/index.d.ts +0 -0
- /package/{cjs → build-tsc}/secp256k1/pair/fromSeed.d.ts +0 -0
- /package/{cjs → build-tsc}/secp256k1/recover.d.ts +0 -0
- /package/{cjs → build-tsc}/secp256k1/sign.d.ts +0 -0
- /package/{cjs → build-tsc}/secp256k1/tweakAdd.d.ts +0 -0
- /package/{cjs → build-tsc}/secp256k1/types.d.ts +0 -0
- /package/{cjs → build-tsc}/secp256k1/verify.d.ts +0 -0
- /package/{cjs → build-tsc}/sha/asU8a.d.ts +0 -0
- /package/{cjs → build-tsc}/sha/index.d.ts +0 -0
- /package/{cjs → build-tsc}/signature/index.d.ts +0 -0
- /package/{cjs → build-tsc}/signature/verify.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/agreement.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/derive.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/deriveHard.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/derivePublic.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/deriveSoft.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/index.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/pair/fromSeed.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/pair/fromU8a.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/pair/toU8a.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/sign.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/verify.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/vrfSign.d.ts +0 -0
- /package/{cjs → build-tsc}/sr25519/vrfVerify.d.ts +0 -0
- /package/{cjs → build-tsc}/types.d.ts +0 -0
- /package/{cjs → build-tsc}/xxhash/index.d.ts +0 -0
- /package/{cjs → build-tsc}/xxhash/xxhash64.d.ts +0 -0
- /package/{cjs → build-tsc-cjs}/address/addressToEvm.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/check.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/checksum.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/decode.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/defaults.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/derive.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/encode.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/encodeDerived.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/encodeMulti.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/eq.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/evmToAddress.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/is.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/keyDerived.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/keyMulti.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/setSS58Format.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/sort.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/sshash.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/types.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/util.js +0 -0
- /package/{cjs → build-tsc-cjs}/address/validate.js +0 -0
- /package/{cjs → build-tsc-cjs}/base32/bs32.js +0 -0
- /package/{cjs → build-tsc-cjs}/base32/helpers.js +0 -0
- /package/{cjs → build-tsc-cjs}/base32/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/base58/bs58.js +0 -0
- /package/{cjs → build-tsc-cjs}/base58/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/base64/bs64.js +0 -0
- /package/{cjs → build-tsc-cjs}/base64/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/base64/pad.js +0 -0
- /package/{cjs → build-tsc-cjs}/base64/trim.js +0 -0
- /package/{cjs → build-tsc-cjs}/blake2/asU8a.js +0 -0
- /package/{cjs → build-tsc-cjs}/blake2/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/bn.js +0 -0
- /package/{cjs → build-tsc-cjs}/bundle.js +0 -0
- /package/{cjs → build-tsc-cjs}/bundleInit.js +0 -0
- /package/{cjs → build-tsc-cjs}/crypto.js +0 -0
- /package/{cjs → build-tsc-cjs}/ed25519/deriveHard.js +0 -0
- /package/{cjs → build-tsc-cjs}/ed25519/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/ed25519/pair/fromRandom.js +0 -0
- /package/{cjs → build-tsc-cjs}/ed25519/pair/fromSecret.js +0 -0
- /package/{cjs → build-tsc-cjs}/ed25519/pair/fromSeed.js +0 -0
- /package/{cjs → build-tsc-cjs}/ed25519/pair/fromString.js +0 -0
- /package/{cjs → build-tsc-cjs}/ed25519/sign.js +0 -0
- /package/{cjs → build-tsc-cjs}/ed25519/verify.js +0 -0
- /package/{cjs → build-tsc-cjs}/ethereum/encode.js +0 -0
- /package/{cjs → build-tsc-cjs}/ethereum/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/ethereum/isAddress.js +0 -0
- /package/{cjs → build-tsc-cjs}/ethereum/isChecksum.js +0 -0
- /package/{cjs → build-tsc-cjs}/hd/ethereum/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/hd/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/hd/ledger/derivePrivate.js +0 -0
- /package/{cjs → build-tsc-cjs}/hd/ledger/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/hd/ledger/master.js +0 -0
- /package/{cjs → build-tsc-cjs}/hd/validatePath.js +0 -0
- /package/{cjs → build-tsc-cjs}/helpers.js +0 -0
- /package/{cjs → build-tsc-cjs}/hmac/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/hmac/shaAsU8a.js +0 -0
- /package/{cjs → build-tsc-cjs}/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/json/constants.js +0 -0
- /package/{cjs → build-tsc-cjs}/json/decrypt.js +0 -0
- /package/{cjs → build-tsc-cjs}/json/decryptData.js +0 -0
- /package/{cjs → build-tsc-cjs}/json/encrypt.js +0 -0
- /package/{cjs → build-tsc-cjs}/json/encryptFormat.js +0 -0
- /package/{cjs → build-tsc-cjs}/json/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/json/types.js +0 -0
- /package/{cjs → build-tsc-cjs}/keccak/asU8a.js +0 -0
- /package/{cjs → build-tsc-cjs}/keccak/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/key/DeriveJunction.js +0 -0
- /package/{cjs → build-tsc-cjs}/key/extractPath.js +0 -0
- /package/{cjs → build-tsc-cjs}/key/extractSuri.js +0 -0
- /package/{cjs → build-tsc-cjs}/key/fromPath.js +0 -0
- /package/{cjs → build-tsc-cjs}/key/hdkdDerive.js +0 -0
- /package/{cjs → build-tsc-cjs}/key/hdkdEcdsa.js +0 -0
- /package/{cjs → build-tsc-cjs}/key/hdkdEd25519.js +0 -0
- /package/{cjs → build-tsc-cjs}/key/hdkdSr25519.js +0 -0
- /package/{cjs → build-tsc-cjs}/key/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/bip39.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/generate.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/toEntropy.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/toLegacySeed.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/toMiniSecret.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/validate.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/wordlists/en.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/wordlists/es.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/wordlists/fr.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/wordlists/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/wordlists/it.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/wordlists/jp.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/wordlists/ko.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/wordlists/zh-s.js +0 -0
- /package/{cjs → build-tsc-cjs}/mnemonic/wordlists/zh-t.js +0 -0
- /package/{cjs → build-tsc-cjs}/nacl/decrypt.js +0 -0
- /package/{cjs → build-tsc-cjs}/nacl/encrypt.js +0 -0
- /package/{cjs → build-tsc-cjs}/nacl/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/nacl/tweetnacl.js +0 -0
- /package/{cjs → build-tsc-cjs}/networks.js +0 -0
- /package/{cjs → build-tsc-cjs}/pbkdf2/encode.js +0 -0
- /package/{cjs → build-tsc-cjs}/pbkdf2/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/random/asNumber.js +0 -0
- /package/{cjs → build-tsc-cjs}/random/asU8a.js +0 -0
- /package/{cjs → build-tsc-cjs}/random/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/scrypt/defaults.js +0 -0
- /package/{cjs → build-tsc-cjs}/scrypt/encode.js +0 -0
- /package/{cjs → build-tsc-cjs}/scrypt/fromU8a.js +0 -0
- /package/{cjs → build-tsc-cjs}/scrypt/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/scrypt/toU8a.js +0 -0
- /package/{cjs → build-tsc-cjs}/scrypt/types.js +0 -0
- /package/{cjs → build-tsc-cjs}/secp256k1/compress.js +0 -0
- /package/{cjs → build-tsc-cjs}/secp256k1/deriveHard.js +0 -0
- /package/{cjs → build-tsc-cjs}/secp256k1/expand.js +0 -0
- /package/{cjs → build-tsc-cjs}/secp256k1/hasher.js +0 -0
- /package/{cjs → build-tsc-cjs}/secp256k1/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/secp256k1/pair/fromSeed.js +0 -0
- /package/{cjs → build-tsc-cjs}/secp256k1/recover.js +0 -0
- /package/{cjs → build-tsc-cjs}/secp256k1/sign.js +0 -0
- /package/{cjs → build-tsc-cjs}/secp256k1/tweakAdd.js +0 -0
- /package/{cjs → build-tsc-cjs}/secp256k1/types.js +0 -0
- /package/{cjs → build-tsc-cjs}/secp256k1/verify.js +0 -0
- /package/{cjs → build-tsc-cjs}/sha/asU8a.js +0 -0
- /package/{cjs → build-tsc-cjs}/sha/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/signature/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/signature/verify.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/agreement.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/derive.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/deriveHard.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/derivePublic.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/deriveSoft.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/pair/fromSeed.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/pair/fromU8a.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/pair/toU8a.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/sign.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/verify.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/vrfSign.js +0 -0
- /package/{cjs → build-tsc-cjs}/sr25519/vrfVerify.js +0 -0
- /package/{cjs → build-tsc-cjs}/types.js +0 -0
- /package/{cjs → build-tsc-cjs}/xxhash/asU8a.js +0 -0
- /package/{cjs → build-tsc-cjs}/xxhash/index.js +0 -0
- /package/{cjs → build-tsc-cjs}/xxhash/xxhash64.js +0 -0
- /package/{address → build-tsc-esm/address}/addressToEvm.js +0 -0
- /package/{address → build-tsc-esm/address}/check.js +0 -0
- /package/{address → build-tsc-esm/address}/checksum.js +0 -0
- /package/{address → build-tsc-esm/address}/decode.js +0 -0
- /package/{address → build-tsc-esm/address}/defaults.js +0 -0
- /package/{address → build-tsc-esm/address}/derive.js +0 -0
- /package/{address → build-tsc-esm/address}/encode.js +0 -0
- /package/{address → build-tsc-esm/address}/encodeDerived.js +0 -0
- /package/{address → build-tsc-esm/address}/encodeMulti.js +0 -0
- /package/{address → build-tsc-esm/address}/eq.js +0 -0
- /package/{address → build-tsc-esm/address}/evmToAddress.js +0 -0
- /package/{address → build-tsc-esm/address}/index.js +0 -0
- /package/{address → build-tsc-esm/address}/is.js +0 -0
- /package/{address → build-tsc-esm/address}/keyDerived.js +0 -0
- /package/{address → build-tsc-esm/address}/keyMulti.js +0 -0
- /package/{address → build-tsc-esm/address}/setSS58Format.js +0 -0
- /package/{address → build-tsc-esm/address}/sort.js +0 -0
- /package/{address → build-tsc-esm/address}/sshash.js +0 -0
- /package/{address → build-tsc-esm/address}/types.js +0 -0
- /package/{address → build-tsc-esm/address}/util.js +0 -0
- /package/{address → build-tsc-esm/address}/validate.js +0 -0
- /package/{base32 → build-tsc-esm/base32}/bs32.js +0 -0
- /package/{base32 → build-tsc-esm/base32}/helpers.js +0 -0
- /package/{base32 → build-tsc-esm/base32}/index.js +0 -0
- /package/{base58 → build-tsc-esm/base58}/bs58.js +0 -0
- /package/{base58 → build-tsc-esm/base58}/index.js +0 -0
- /package/{base64 → build-tsc-esm/base64}/bs64.js +0 -0
- /package/{base64 → build-tsc-esm/base64}/index.js +0 -0
- /package/{base64 → build-tsc-esm/base64}/pad.js +0 -0
- /package/{base64 → build-tsc-esm/base64}/trim.js +0 -0
- /package/{blake2 → build-tsc-esm/blake2}/asU8a.js +0 -0
- /package/{blake2 → build-tsc-esm/blake2}/index.js +0 -0
- /package/{bn.js → build-tsc-esm/bn.js} +0 -0
- /package/{bundle.js → build-tsc-esm/bundle.js} +0 -0
- /package/{bundleInit.js → build-tsc-esm/bundleInit.js} +0 -0
- /package/{crypto.js → build-tsc-esm/crypto.js} +0 -0
- /package/{ed25519 → build-tsc-esm/ed25519}/deriveHard.js +0 -0
- /package/{ed25519 → build-tsc-esm/ed25519}/index.js +0 -0
- /package/{ed25519 → build-tsc-esm/ed25519}/pair/fromRandom.js +0 -0
- /package/{ed25519 → build-tsc-esm/ed25519}/pair/fromSecret.js +0 -0
- /package/{ed25519 → build-tsc-esm/ed25519}/pair/fromSeed.js +0 -0
- /package/{ed25519 → build-tsc-esm/ed25519}/pair/fromString.js +0 -0
- /package/{ed25519 → build-tsc-esm/ed25519}/sign.js +0 -0
- /package/{ed25519 → build-tsc-esm/ed25519}/verify.js +0 -0
- /package/{ethereum → build-tsc-esm/ethereum}/encode.js +0 -0
- /package/{ethereum → build-tsc-esm/ethereum}/index.js +0 -0
- /package/{ethereum → build-tsc-esm/ethereum}/isAddress.js +0 -0
- /package/{ethereum → build-tsc-esm/ethereum}/isChecksum.js +0 -0
- /package/{hd → build-tsc-esm/hd}/ethereum/index.js +0 -0
- /package/{hd → build-tsc-esm/hd}/index.js +0 -0
- /package/{hd → build-tsc-esm/hd}/ledger/derivePrivate.js +0 -0
- /package/{hd → build-tsc-esm/hd}/ledger/index.js +0 -0
- /package/{hd → build-tsc-esm/hd}/ledger/master.js +0 -0
- /package/{hd → build-tsc-esm/hd}/validatePath.js +0 -0
- /package/{helpers.js → build-tsc-esm/helpers.js} +0 -0
- /package/{hmac → build-tsc-esm/hmac}/index.js +0 -0
- /package/{hmac → build-tsc-esm/hmac}/shaAsU8a.js +0 -0
- /package/{index.js → build-tsc-esm/index.js} +0 -0
- /package/{json → build-tsc-esm/json}/constants.js +0 -0
- /package/{json → build-tsc-esm/json}/decrypt.js +0 -0
- /package/{json → build-tsc-esm/json}/decryptData.js +0 -0
- /package/{json → build-tsc-esm/json}/encrypt.js +0 -0
- /package/{json → build-tsc-esm/json}/encryptFormat.js +0 -0
- /package/{json → build-tsc-esm/json}/index.js +0 -0
- /package/{json → build-tsc-esm/json}/types.js +0 -0
- /package/{keccak → build-tsc-esm/keccak}/asU8a.js +0 -0
- /package/{keccak → build-tsc-esm/keccak}/index.js +0 -0
- /package/{key → build-tsc-esm/key}/DeriveJunction.js +0 -0
- /package/{key → build-tsc-esm/key}/extractPath.js +0 -0
- /package/{key → build-tsc-esm/key}/extractSuri.js +0 -0
- /package/{key → build-tsc-esm/key}/fromPath.js +0 -0
- /package/{key → build-tsc-esm/key}/hdkdDerive.js +0 -0
- /package/{key → build-tsc-esm/key}/hdkdEcdsa.js +0 -0
- /package/{key → build-tsc-esm/key}/hdkdEd25519.js +0 -0
- /package/{key → build-tsc-esm/key}/hdkdSr25519.js +0 -0
- /package/{key → build-tsc-esm/key}/index.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/bip39.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/generate.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/index.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/toEntropy.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/toLegacySeed.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/toMiniSecret.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/validate.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/wordlists/en.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/wordlists/es.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/wordlists/fr.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/wordlists/index.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/wordlists/it.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/wordlists/jp.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/wordlists/ko.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/wordlists/zh-s.js +0 -0
- /package/{mnemonic → build-tsc-esm/mnemonic}/wordlists/zh-t.js +0 -0
- /package/{nacl → build-tsc-esm/nacl}/decrypt.js +0 -0
- /package/{nacl → build-tsc-esm/nacl}/encrypt.js +0 -0
- /package/{nacl → build-tsc-esm/nacl}/index.js +0 -0
- /package/{nacl → build-tsc-esm/nacl}/tweetnacl.js +0 -0
- /package/{networks.js → build-tsc-esm/networks.js} +0 -0
- /package/{packageDetect.js → build-tsc-esm/packageDetect.js} +0 -0
- /package/{pbkdf2 → build-tsc-esm/pbkdf2}/encode.js +0 -0
- /package/{pbkdf2 → build-tsc-esm/pbkdf2}/index.js +0 -0
- /package/{random → build-tsc-esm/random}/asNumber.js +0 -0
- /package/{random → build-tsc-esm/random}/asU8a.js +0 -0
- /package/{random → build-tsc-esm/random}/index.js +0 -0
- /package/{scrypt → build-tsc-esm/scrypt}/defaults.js +0 -0
- /package/{scrypt → build-tsc-esm/scrypt}/encode.js +0 -0
- /package/{scrypt → build-tsc-esm/scrypt}/fromU8a.js +0 -0
- /package/{scrypt → build-tsc-esm/scrypt}/index.js +0 -0
- /package/{scrypt → build-tsc-esm/scrypt}/toU8a.js +0 -0
- /package/{scrypt → build-tsc-esm/scrypt}/types.js +0 -0
- /package/{secp256k1 → build-tsc-esm/secp256k1}/compress.js +0 -0
- /package/{secp256k1 → build-tsc-esm/secp256k1}/deriveHard.js +0 -0
- /package/{secp256k1 → build-tsc-esm/secp256k1}/expand.js +0 -0
- /package/{secp256k1 → build-tsc-esm/secp256k1}/hasher.js +0 -0
- /package/{secp256k1 → build-tsc-esm/secp256k1}/index.js +0 -0
- /package/{secp256k1 → build-tsc-esm/secp256k1}/pair/fromSeed.js +0 -0
- /package/{secp256k1 → build-tsc-esm/secp256k1}/recover.js +0 -0
- /package/{secp256k1 → build-tsc-esm/secp256k1}/sign.js +0 -0
- /package/{secp256k1 → build-tsc-esm/secp256k1}/tweakAdd.js +0 -0
- /package/{secp256k1 → build-tsc-esm/secp256k1}/types.js +0 -0
- /package/{secp256k1 → build-tsc-esm/secp256k1}/verify.js +0 -0
- /package/{sha → build-tsc-esm/sha}/asU8a.js +0 -0
- /package/{sha → build-tsc-esm/sha}/index.js +0 -0
- /package/{signature → build-tsc-esm/signature}/index.js +0 -0
- /package/{signature → build-tsc-esm/signature}/verify.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/agreement.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/derive.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/deriveHard.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/derivePublic.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/deriveSoft.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/index.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/pair/fromSeed.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/pair/fromU8a.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/pair/toU8a.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/sign.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/verify.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/vrfSign.js +0 -0
- /package/{sr25519 → build-tsc-esm/sr25519}/vrfVerify.js +0 -0
- /package/{types.js → build-tsc-esm/types.js} +0 -0
- /package/{xxhash → build-tsc-esm/xxhash}/asU8a.js +0 -0
- /package/{xxhash → build-tsc-esm/xxhash}/index.js +0 -0
- /package/{xxhash → build-tsc-esm/xxhash}/xxhash64.js +0 -0
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
/// <reference types="@pezkuwi/dev-test/globals.d.ts" />
|
|
5
|
+
|
|
6
|
+
import type { ExtractResult } from './extractSuri.js';
|
|
7
|
+
|
|
8
|
+
import { keyExtractSuri } from './extractSuri.js';
|
|
9
|
+
|
|
10
|
+
describe('keyExtractSuri', (): void => {
|
|
11
|
+
it('does not extract from invalid suri', (): void => {
|
|
12
|
+
expect(
|
|
13
|
+
(): ExtractResult => keyExtractSuri('//2')
|
|
14
|
+
).toThrow('Unable to match provided value to a secret URI');
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
it('derives on "hello world"', (): void => {
|
|
18
|
+
const test = keyExtractSuri('hello world');
|
|
19
|
+
|
|
20
|
+
expect(test.phrase).toEqual('hello world');
|
|
21
|
+
expect(test.path.length).toEqual(0);
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
it('derives on "hello world/1', (): void => {
|
|
25
|
+
const test = keyExtractSuri('hello world/1');
|
|
26
|
+
|
|
27
|
+
expect(test.password).not.toBeDefined();
|
|
28
|
+
expect(test.phrase).toEqual('hello world');
|
|
29
|
+
expect(test.path.length).toEqual(1);
|
|
30
|
+
expect(test.path[0].isHard).toEqual(false);
|
|
31
|
+
expect(test.path[0].chainCode).toEqual(Uint8Array.from([1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
it('derives on "hello world/DOT', (): void => {
|
|
35
|
+
const test = keyExtractSuri('hello world/DOT');
|
|
36
|
+
|
|
37
|
+
expect(test.password).not.toBeDefined();
|
|
38
|
+
expect(test.phrase).toEqual('hello world');
|
|
39
|
+
expect(test.path.length).toEqual(1);
|
|
40
|
+
expect(test.path[0].isHard).toEqual(false);
|
|
41
|
+
expect(test.path[0].chainCode).toEqual(Uint8Array.from([12, 68, 79, 84, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
it('derives on "hello world//1', (): void => {
|
|
45
|
+
const test = keyExtractSuri('hello world//1');
|
|
46
|
+
|
|
47
|
+
expect(test.password).not.toBeDefined();
|
|
48
|
+
expect(test.phrase).toEqual('hello world');
|
|
49
|
+
expect(test.path.length).toEqual(1);
|
|
50
|
+
expect(test.path[0].isHard).toEqual(true);
|
|
51
|
+
expect(test.path[0].chainCode).toEqual(Uint8Array.from([1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
it('derives on "hello world//DOT', (): void => {
|
|
55
|
+
const test = keyExtractSuri('hello world//DOT');
|
|
56
|
+
|
|
57
|
+
expect(test.password).not.toBeDefined();
|
|
58
|
+
expect(test.phrase).toEqual('hello world');
|
|
59
|
+
expect(test.path.length).toEqual(1);
|
|
60
|
+
expect(test.path[0].isHard).toEqual(true);
|
|
61
|
+
expect(test.path[0].chainCode).toEqual(Uint8Array.from([12, 68, 79, 84, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
it('derives on "hello world//1/DOT', (): void => {
|
|
65
|
+
const test = keyExtractSuri('hello world//1/DOT');
|
|
66
|
+
|
|
67
|
+
expect(test.password).not.toBeDefined();
|
|
68
|
+
expect(test.phrase).toEqual('hello world');
|
|
69
|
+
expect(test.path.length).toEqual(2);
|
|
70
|
+
expect(test.path[0].isHard).toEqual(true);
|
|
71
|
+
expect(test.path[0].chainCode).toEqual(Uint8Array.from([1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
72
|
+
expect(test.path[1].isHard).toEqual(false);
|
|
73
|
+
expect(test.path[1].chainCode).toEqual(Uint8Array.from([12, 68, 79, 84, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
it('derives on "hello world//DOT/1', (): void => {
|
|
77
|
+
const test = keyExtractSuri('hello world//DOT/1');
|
|
78
|
+
|
|
79
|
+
expect(test.password).not.toBeDefined();
|
|
80
|
+
expect(test.phrase).toEqual('hello world');
|
|
81
|
+
expect(test.path.length).toEqual(2);
|
|
82
|
+
expect(test.path[0].isHard).toEqual(true);
|
|
83
|
+
expect(test.path[0].chainCode).toEqual(Uint8Array.from([12, 68, 79, 84, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
84
|
+
expect(test.path[1].isHard).toEqual(false);
|
|
85
|
+
expect(test.path[1].chainCode).toEqual(Uint8Array.from([1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
it('derives on "hello world///password"', (): void => {
|
|
89
|
+
const test = keyExtractSuri('hello world///password');
|
|
90
|
+
|
|
91
|
+
expect(test.password).toEqual('password');
|
|
92
|
+
expect(test.phrase).toEqual('hello world');
|
|
93
|
+
expect(test.path.length).toEqual(0);
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
it('derives on "hello world//1/DOT///password"', (): void => {
|
|
97
|
+
const test = keyExtractSuri('hello world//1/DOT///password');
|
|
98
|
+
|
|
99
|
+
expect(test.password).toEqual('password');
|
|
100
|
+
expect(test.phrase).toEqual('hello world');
|
|
101
|
+
expect(test.path.length).toEqual(2);
|
|
102
|
+
expect(test.path[0].isHard).toEqual(true);
|
|
103
|
+
expect(test.path[0].chainCode).toEqual(Uint8Array.from([1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
104
|
+
expect(test.path[1].isHard).toEqual(false);
|
|
105
|
+
expect(test.path[1].chainCode).toEqual(Uint8Array.from([12, 68, 79, 84, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
it('derives on "hello world/1//DOT///password"', (): void => {
|
|
109
|
+
const test = keyExtractSuri('hello world/1//DOT///password');
|
|
110
|
+
|
|
111
|
+
expect(test.password).toEqual('password');
|
|
112
|
+
expect(test.phrase).toEqual('hello world');
|
|
113
|
+
expect(test.path.length).toEqual(2);
|
|
114
|
+
expect(test.path[0].isHard).toEqual(false);
|
|
115
|
+
expect(test.path[0].chainCode).toEqual(Uint8Array.from([1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
116
|
+
expect(test.path[1].isHard).toEqual(true);
|
|
117
|
+
expect(test.path[1].chainCode).toEqual(Uint8Array.from([12, 68, 79, 84, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
it('derives on actual Alice', (): void => {
|
|
121
|
+
const test = keyExtractSuri('bottom drive obey lake curtain smoke basket hold race lonely fit walk//Alice');
|
|
122
|
+
|
|
123
|
+
expect(test.password).not.toBeDefined();
|
|
124
|
+
expect(test.phrase).toEqual('bottom drive obey lake curtain smoke basket hold race lonely fit walk');
|
|
125
|
+
expect(test.path.length).toEqual(1);
|
|
126
|
+
expect(test.path[0].isHard).toEqual(true);
|
|
127
|
+
expect(test.path[0].chainCode).toEqual(Uint8Array.from([20, 65, 108, 105, 99, 101, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]));
|
|
128
|
+
});
|
|
129
|
+
|
|
130
|
+
it('derives on uncommon characters', (): void => {
|
|
131
|
+
const languageMnemonics = {
|
|
132
|
+
chineseSimplified: '熙 礼 淀 谋 耗 搜 雨 瑞 雷 合 析 感',
|
|
133
|
+
chineseTraditional: '召 胸 捕 乏 講 祥 隙 幫 動 框 場 給',
|
|
134
|
+
french: 'ruiner minute maison ouragan palourde piscine nerveux descente romance édifier ancien médaille',
|
|
135
|
+
japanese: 'ほったん はちみつ おやゆび ほかん いりぐち さんいん てぶくろ だいじょうぶ ふとん でぬかえ ちしき あわてる',
|
|
136
|
+
korean: '김밥 방향 논리 저절로 증상 지진 회장 오히려 시리즈 최근 학용품 곡식'
|
|
137
|
+
};
|
|
138
|
+
|
|
139
|
+
Object.keys(languageMnemonics).forEach((mnemonic) => {
|
|
140
|
+
const test = keyExtractSuri(mnemonic);
|
|
141
|
+
|
|
142
|
+
expect(test.password).not.toBeDefined();
|
|
143
|
+
expect(test.phrase).toEqual(mnemonic);
|
|
144
|
+
expect(test.path.length).toEqual(0);
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
});
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { DeriveJunction } from './DeriveJunction.js';
|
|
5
|
+
|
|
6
|
+
import { keyExtractPath } from './extractPath.js';
|
|
7
|
+
|
|
8
|
+
export interface ExtractResult {
|
|
9
|
+
derivePath: string,
|
|
10
|
+
password?: string;
|
|
11
|
+
path: DeriveJunction[];
|
|
12
|
+
phrase: string;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
const RE_CAPTURE = /^((0x[a-fA-F0-9]+|[\p{L}\d]+(?: [\p{L}\d]+)*))((\/\/?[^/]+)*)(\/\/\/(.*))?$/u;
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* @description Extracts the phrase, path and password from a SURI format for specifying secret keys `<secret>/<soft-key>//<hard-key>///<password>` (the `///password` may be omitted, and `/<soft-key>` and `//<hard-key>` maybe repeated and mixed).
|
|
19
|
+
*/
|
|
20
|
+
export function keyExtractSuri (suri: string): ExtractResult {
|
|
21
|
+
// Normalize Unicode to NFC to avoid accent-related mismatches
|
|
22
|
+
const normalizedSuri = suri.normalize('NFC');
|
|
23
|
+
|
|
24
|
+
// eslint-disable-next-line @typescript-eslint/prefer-regexp-exec
|
|
25
|
+
const matches = normalizedSuri.match(RE_CAPTURE);
|
|
26
|
+
|
|
27
|
+
if (matches === null) {
|
|
28
|
+
throw new Error('Unable to match provided value to a secret URI');
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
const [, phrase, , derivePath, , , password] = matches;
|
|
32
|
+
const { path } = keyExtractPath(derivePath);
|
|
33
|
+
|
|
34
|
+
return {
|
|
35
|
+
derivePath,
|
|
36
|
+
password,
|
|
37
|
+
path,
|
|
38
|
+
phrase
|
|
39
|
+
};
|
|
40
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { Keypair, KeypairType } from '../types.js';
|
|
5
|
+
import type { DeriveJunction } from './DeriveJunction.js';
|
|
6
|
+
|
|
7
|
+
import { keyHdkdEcdsa } from './hdkdEcdsa.js';
|
|
8
|
+
import { keyHdkdEd25519 } from './hdkdEd25519.js';
|
|
9
|
+
import { keyHdkdSr25519 } from './hdkdSr25519.js';
|
|
10
|
+
|
|
11
|
+
const generators = {
|
|
12
|
+
ecdsa: keyHdkdEcdsa,
|
|
13
|
+
ed25519: keyHdkdEd25519,
|
|
14
|
+
// FIXME This is Substrate-compatible, not Ethereum-compatible
|
|
15
|
+
ethereum: keyHdkdEcdsa,
|
|
16
|
+
sr25519: keyHdkdSr25519
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
export function keyFromPath (pair: Keypair, path: DeriveJunction[], type: KeypairType): Keypair {
|
|
20
|
+
const keyHdkd = generators[type];
|
|
21
|
+
let result = pair;
|
|
22
|
+
|
|
23
|
+
for (const junction of path) {
|
|
24
|
+
result = keyHdkd(result, junction);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
return result;
|
|
28
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { Keypair } from '../types.js';
|
|
5
|
+
import type { DeriveJunction } from './DeriveJunction.js';
|
|
6
|
+
|
|
7
|
+
export function createSeedDeriveFn (fromSeed: (seed: Uint8Array) => Keypair, derive: (seed: Uint8Array, chainCode: Uint8Array) => Uint8Array): (keypair: Keypair, junction: DeriveJunction) => Keypair {
|
|
8
|
+
return (keypair: Keypair, { chainCode, isHard }: DeriveJunction): Keypair => {
|
|
9
|
+
if (!isHard) {
|
|
10
|
+
throw new Error('A soft key was found in the path and is not supported');
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
return fromSeed(
|
|
14
|
+
derive(keypair.secretKey.subarray(0, 32), chainCode)
|
|
15
|
+
);
|
|
16
|
+
};
|
|
17
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import { secp256k1DeriveHard } from '../secp256k1/deriveHard.js';
|
|
5
|
+
import { secp256k1PairFromSeed } from '../secp256k1/pair/fromSeed.js';
|
|
6
|
+
import { createSeedDeriveFn } from './hdkdDerive.js';
|
|
7
|
+
|
|
8
|
+
export const keyHdkdEcdsa = /*#__PURE__*/ createSeedDeriveFn(secp256k1PairFromSeed, secp256k1DeriveHard);
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import { ed25519DeriveHard, ed25519PairFromSeed } from '../ed25519/index.js';
|
|
5
|
+
import { createSeedDeriveFn } from './hdkdDerive.js';
|
|
6
|
+
|
|
7
|
+
export const keyHdkdEd25519 = /*#__PURE__*/ createSeedDeriveFn(ed25519PairFromSeed, ed25519DeriveHard);
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { Keypair } from '../types.js';
|
|
5
|
+
import type { DeriveJunction } from './DeriveJunction.js';
|
|
6
|
+
|
|
7
|
+
import { sr25519DeriveHard } from '../sr25519/deriveHard.js';
|
|
8
|
+
import { sr25519DeriveSoft } from '../sr25519/deriveSoft.js';
|
|
9
|
+
|
|
10
|
+
export function keyHdkdSr25519 (keypair: Keypair, { chainCode, isSoft }: DeriveJunction): Keypair {
|
|
11
|
+
return isSoft
|
|
12
|
+
? sr25519DeriveSoft(keypair, chainCode)
|
|
13
|
+
: sr25519DeriveHard(keypair, chainCode);
|
|
14
|
+
}
|
package/src/key/index.ts
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* @summary Create keys from paths, seeds and password
|
|
6
|
+
*/
|
|
7
|
+
export { keyExtractPath } from './extractPath.js';
|
|
8
|
+
export { keyExtractSuri } from './extractSuri.js';
|
|
9
|
+
export { keyFromPath } from './fromPath.js';
|
|
10
|
+
export { keyHdkdEcdsa } from './hdkdEcdsa.js';
|
|
11
|
+
export { keyHdkdEd25519 } from './hdkdEd25519.js';
|
|
12
|
+
export { keyHdkdSr25519 } from './hdkdSr25519.js';
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
/// <reference types="@pezkuwi/dev-test/globals.d.ts" />
|
|
5
|
+
|
|
6
|
+
import * as lists from './wordlists/index.js';
|
|
7
|
+
import { entropyToMnemonic, generateMnemonic, mnemonicToEntropy, validateMnemonic } from './bip39.js';
|
|
8
|
+
|
|
9
|
+
describe('wordlists', (): void => {
|
|
10
|
+
for (const [lang, words] of Object.entries(lists)) {
|
|
11
|
+
describe(`language ${lang}`, (): void => {
|
|
12
|
+
it('has the correct number of words', (): void => {
|
|
13
|
+
expect(words).toHaveLength(2048);
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
it('has no empty words', (): void => {
|
|
17
|
+
expect(
|
|
18
|
+
words.some((w) => !w.length || w.trim() !== w)
|
|
19
|
+
).toEqual(false);
|
|
20
|
+
});
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
describe('bip39', (): void => {
|
|
26
|
+
const m = 'seed sock milk update focus rotate barely fade car face mechanic mercy';
|
|
27
|
+
const e = mnemonicToEntropy(m);
|
|
28
|
+
|
|
29
|
+
it('generates a known entropy', (): void => {
|
|
30
|
+
expect(e).toEqual(
|
|
31
|
+
new Uint8Array([194, 249, 194, 50, 119, 69, 163, 120, 68, 162, 142, 34, 74, 50, 40, 197])
|
|
32
|
+
);
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
it('has a two-way entropy <-> mnemonic (default wordlist)', (): void => {
|
|
36
|
+
expect(
|
|
37
|
+
entropyToMnemonic(mnemonicToEntropy(entropyToMnemonic(e)))
|
|
38
|
+
).toEqual(m);
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
for (const [lang, words] of Object.entries(lists)) {
|
|
42
|
+
const isUsingList = (test: string, length = 12): void => {
|
|
43
|
+
const split = test.split(' ');
|
|
44
|
+
|
|
45
|
+
expect(
|
|
46
|
+
split
|
|
47
|
+
).toHaveLength(length);
|
|
48
|
+
expect(
|
|
49
|
+
split.some((w) => words.indexOf(w) === -1)
|
|
50
|
+
).toEqual(false);
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
describe(`language ${lang}`, (): void => {
|
|
54
|
+
it('has a two-way entropy <-> mnemonic', (): void => {
|
|
55
|
+
const test = entropyToMnemonic(e, words);
|
|
56
|
+
const entr = mnemonicToEntropy(test, words);
|
|
57
|
+
|
|
58
|
+
isUsingList(test);
|
|
59
|
+
|
|
60
|
+
expect(
|
|
61
|
+
entr
|
|
62
|
+
).toEqual(e);
|
|
63
|
+
|
|
64
|
+
expect(
|
|
65
|
+
entropyToMnemonic(entr, words)
|
|
66
|
+
).toEqual(test);
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
it('generates a valid mnemonic', (): void => {
|
|
70
|
+
const test = generateMnemonic(24, words);
|
|
71
|
+
|
|
72
|
+
isUsingList(test, 24);
|
|
73
|
+
|
|
74
|
+
expect(
|
|
75
|
+
validateMnemonic(test, words)
|
|
76
|
+
).toEqual(true);
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
});
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
// Adapted from the bitcoinjs/bip39 source
|
|
5
|
+
// https://github.com/bitcoinjs/bip39/blob/1d063b6a6aee4145b34d701037cd3e67f5446ff9/ts_src/index.ts
|
|
6
|
+
// Copyright (c) 2014, Wei Lu <luwei.here@gmail.com> and Daniel Cousens <email@dcousens.com>
|
|
7
|
+
// ISC Licence
|
|
8
|
+
//
|
|
9
|
+
// Change made in this version -
|
|
10
|
+
// - Adjust formatting (just eslint differences)
|
|
11
|
+
// - Only English wordlist (this aligns with the wasm-crypto implementation)
|
|
12
|
+
// - Use util-crypto randomAsU8a (instead of randombytes)
|
|
13
|
+
// - Remove setting of wordlist passing of wordlist in functions
|
|
14
|
+
// - Remove mnemonicToSeed (we only use the sync variant)
|
|
15
|
+
// - generateMnemonic takes number of words (instead of strength)
|
|
16
|
+
|
|
17
|
+
import { stringToU8a, u8aToU8a } from '@pezkuwi/util';
|
|
18
|
+
|
|
19
|
+
import { pbkdf2Encode } from '../pbkdf2/index.js';
|
|
20
|
+
import { randomAsU8a } from '../random/index.js';
|
|
21
|
+
import { sha256AsU8a } from '../sha/index.js';
|
|
22
|
+
import DEFAULT_WORDLIST from './wordlists/en.js';
|
|
23
|
+
|
|
24
|
+
const INVALID_MNEMONIC = 'Invalid mnemonic';
|
|
25
|
+
const INVALID_ENTROPY = 'Invalid entropy';
|
|
26
|
+
const INVALID_CHECKSUM = 'Invalid mnemonic checksum';
|
|
27
|
+
|
|
28
|
+
/** @internal */
|
|
29
|
+
function normalize (str?: string): string {
|
|
30
|
+
return (str || '').normalize('NFKD');
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/** @internal */
|
|
34
|
+
function binaryToByte (bin: string): number {
|
|
35
|
+
return parseInt(bin, 2);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
/** @internal */
|
|
39
|
+
function bytesToBinary (bytes: number[]): string {
|
|
40
|
+
return bytes.map((x) => x.toString(2).padStart(8, '0')).join('');
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/** @internal */
|
|
44
|
+
function deriveChecksumBits (entropyBuffer: Uint8Array): string {
|
|
45
|
+
return bytesToBinary(
|
|
46
|
+
Array.from(sha256AsU8a(entropyBuffer))
|
|
47
|
+
).slice(0, (entropyBuffer.length * 8) / 32);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
export function mnemonicToSeedSync (mnemonic: string, password?: string): Uint8Array {
|
|
51
|
+
return pbkdf2Encode(
|
|
52
|
+
stringToU8a(normalize(mnemonic)),
|
|
53
|
+
stringToU8a(`mnemonic${normalize(password)}`)
|
|
54
|
+
).password;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
export function mnemonicToEntropy (mnemonic: string, wordlist: string[] = DEFAULT_WORDLIST): Uint8Array {
|
|
58
|
+
const words = normalize(mnemonic).split(' ');
|
|
59
|
+
|
|
60
|
+
if (words.length % 3 !== 0) {
|
|
61
|
+
throw new Error(INVALID_MNEMONIC);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
// convert word indices to 11 bit binary strings
|
|
65
|
+
const bits = words
|
|
66
|
+
.map((word): string => {
|
|
67
|
+
const index = wordlist.indexOf(word);
|
|
68
|
+
|
|
69
|
+
if (index === -1) {
|
|
70
|
+
throw new Error(INVALID_MNEMONIC);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
return index.toString(2).padStart(11, '0');
|
|
74
|
+
})
|
|
75
|
+
.join('');
|
|
76
|
+
|
|
77
|
+
// split the binary string into ENT/CS
|
|
78
|
+
const dividerIndex = Math.floor(bits.length / 33) * 32;
|
|
79
|
+
const entropyBits = bits.slice(0, dividerIndex);
|
|
80
|
+
const checksumBits = bits.slice(dividerIndex);
|
|
81
|
+
|
|
82
|
+
// calculate the checksum and compare
|
|
83
|
+
const matched = entropyBits.match(/(.{1,8})/g);
|
|
84
|
+
const entropyBytes = matched?.map(binaryToByte);
|
|
85
|
+
|
|
86
|
+
if (!entropyBytes || (entropyBytes.length % 4 !== 0) || (entropyBytes.length < 16) || (entropyBytes.length > 32)) {
|
|
87
|
+
throw new Error(INVALID_ENTROPY);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
const entropy = u8aToU8a(entropyBytes);
|
|
91
|
+
|
|
92
|
+
if (deriveChecksumBits(entropy) !== checksumBits) {
|
|
93
|
+
throw new Error(INVALID_CHECKSUM);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
return entropy;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
export function entropyToMnemonic (entropy: Uint8Array, wordlist: string[] = DEFAULT_WORDLIST): string {
|
|
100
|
+
// 128 <= ENT <= 256
|
|
101
|
+
if ((entropy.length % 4 !== 0) || (entropy.length < 16) || (entropy.length > 32)) {
|
|
102
|
+
throw new Error(INVALID_ENTROPY);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
const matched = `${bytesToBinary(Array.from(entropy))}${deriveChecksumBits(entropy)}`.match(/(.{1,11})/g);
|
|
106
|
+
const mapped = matched?.map((b) => wordlist[binaryToByte(b)]);
|
|
107
|
+
|
|
108
|
+
if (!mapped || (mapped.length < 12)) {
|
|
109
|
+
throw new Error('Unable to map entropy to mnemonic');
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
return mapped.join(' ');
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
export function generateMnemonic (numWords: 12 | 15 | 18 | 21 | 24, wordlist?: string[]): string {
|
|
116
|
+
return entropyToMnemonic(randomAsU8a((numWords / 3) * 4), wordlist);
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
export function validateMnemonic (mnemonic: string, wordlist?: string[]): boolean {
|
|
120
|
+
try {
|
|
121
|
+
mnemonicToEntropy(mnemonic, wordlist);
|
|
122
|
+
} catch {
|
|
123
|
+
return false;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
return true;
|
|
127
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
/// <reference types="@pezkuwi/dev-test/globals.d.ts" />
|
|
5
|
+
|
|
6
|
+
import { cryptoWaitReady } from '../index.js';
|
|
7
|
+
import { french as frenchWords } from './wordlists/index.js';
|
|
8
|
+
import { mnemonicGenerate } from './generate.js';
|
|
9
|
+
import { mnemonicValidate } from './validate.js';
|
|
10
|
+
|
|
11
|
+
await cryptoWaitReady();
|
|
12
|
+
|
|
13
|
+
describe('mnemonicGenerate', (): void => {
|
|
14
|
+
it('generates a valid mnemonic (default strength)', (): void => {
|
|
15
|
+
expect(
|
|
16
|
+
mnemonicValidate(mnemonicGenerate())
|
|
17
|
+
).toEqual(true);
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
it('generates a french mnemonic', (): void => {
|
|
21
|
+
const mnemonic = mnemonicGenerate(24, frenchWords);
|
|
22
|
+
const words = mnemonic.split(' ');
|
|
23
|
+
|
|
24
|
+
expect(words).toHaveLength(24);
|
|
25
|
+
expect(
|
|
26
|
+
mnemonicValidate(mnemonic, frenchWords)
|
|
27
|
+
).toEqual(true);
|
|
28
|
+
expect(
|
|
29
|
+
mnemonicValidate(mnemonic)
|
|
30
|
+
).toEqual(false);
|
|
31
|
+
expect(
|
|
32
|
+
words.every((w) => frenchWords.includes(w))
|
|
33
|
+
).toEqual(true);
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
for (const onlyJs of [false, true]) {
|
|
37
|
+
describe(`onlyJs=${(onlyJs && 'true') || 'false'}`, (): void => {
|
|
38
|
+
for (const num of [12, 15, 18, 21, 24] as const) {
|
|
39
|
+
it(`generates a valid mnemonic (${num} words)`, (): void => {
|
|
40
|
+
const mnemonic = mnemonicGenerate(num, undefined, onlyJs);
|
|
41
|
+
const isValid = mnemonicValidate(mnemonic);
|
|
42
|
+
|
|
43
|
+
expect(mnemonic.split(' ')).toHaveLength(num);
|
|
44
|
+
expect(isValid).toEqual(true);
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
it('generates non-deterministic', (): void => {
|
|
49
|
+
const m1 = mnemonicGenerate(24, undefined, onlyJs);
|
|
50
|
+
const m2 = mnemonicGenerate(24, undefined, onlyJs);
|
|
51
|
+
|
|
52
|
+
expect(m1 === m2).toEqual(false);
|
|
53
|
+
expect(mnemonicValidate(m1)).toEqual(true);
|
|
54
|
+
expect(mnemonicValidate(m2)).toEqual(true);
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
});
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import { hasBigInt } from '@pezkuwi/util';
|
|
5
|
+
import { bip39Generate, isReady } from '@pezkuwi/wasm-crypto';
|
|
6
|
+
|
|
7
|
+
import { generateMnemonic } from './bip39.js';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* @name mnemonicGenerate
|
|
11
|
+
* @summary Creates a valid mnemonic string using using [BIP39](https://github.com/bitcoin/bips/blob/master/bip-0039.mediawiki).
|
|
12
|
+
* @example
|
|
13
|
+
* <BR>
|
|
14
|
+
*
|
|
15
|
+
* ```javascript
|
|
16
|
+
* import { mnemonicGenerate } from '@pezkuwi/util-crypto';
|
|
17
|
+
*
|
|
18
|
+
* const mnemonic = mnemonicGenerate(); // => string
|
|
19
|
+
* ```
|
|
20
|
+
*/
|
|
21
|
+
export function mnemonicGenerate (numWords: 12 | 15 | 18 | 21 | 24 = 12, wordlist?: string[], onlyJs?: boolean): string {
|
|
22
|
+
return !hasBigInt || (!wordlist && !onlyJs && isReady())
|
|
23
|
+
? bip39Generate(numWords)
|
|
24
|
+
: generateMnemonic(numWords, wordlist);
|
|
25
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* @summary Create valid mnemonic strings, validate them using BIP39, and convert them to valid seeds
|
|
6
|
+
*/
|
|
7
|
+
export { mnemonicGenerate } from './generate.js';
|
|
8
|
+
export { mnemonicToEntropy } from './toEntropy.js';
|
|
9
|
+
export { mnemonicToLegacySeed } from './toLegacySeed.js';
|
|
10
|
+
export { mnemonicToMiniSecret } from './toMiniSecret.js';
|
|
11
|
+
export { mnemonicValidate } from './validate.js';
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
/// <reference types="@pezkuwi/dev-test/globals.d.ts" />
|
|
5
|
+
|
|
6
|
+
import { u8aToHex } from '@pezkuwi/util';
|
|
7
|
+
|
|
8
|
+
import { cryptoWaitReady } from '../index.js';
|
|
9
|
+
import tests from '../sr25519/pair/testing.spec.js';
|
|
10
|
+
import { french as frenchWords } from './wordlists/index.js';
|
|
11
|
+
import { mnemonicToEntropy } from './toEntropy.js';
|
|
12
|
+
|
|
13
|
+
await cryptoWaitReady();
|
|
14
|
+
|
|
15
|
+
describe('mnemonicToEntropy', (): void => {
|
|
16
|
+
for (const onlyJs of [false, true]) {
|
|
17
|
+
describe(`onlyJs=${(onlyJs && 'true') || 'false'}`, (): void => {
|
|
18
|
+
tests.forEach(([mnemonic, entropy], index): void => {
|
|
19
|
+
it(`Created correct entropy for ${index}`, (): void => {
|
|
20
|
+
expect(u8aToHex(mnemonicToEntropy(mnemonic, undefined, onlyJs))).toEqual(entropy);
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
it('has the correct entropy for non-Englist mnemonics', (): void => {
|
|
27
|
+
const mnemonic = 'pompier circuler pulpe injure aspect abyssal nuque boueux équerre balisage pieuvre médecin petit suffixe soleil cumuler monstre arlequin liasse pixel garrigue noble buisson scandale';
|
|
28
|
+
|
|
29
|
+
expect(
|
|
30
|
+
() => mnemonicToEntropy(mnemonic)
|
|
31
|
+
).toThrow();
|
|
32
|
+
expect(
|
|
33
|
+
mnemonicToEntropy(mnemonic, frenchWords)
|
|
34
|
+
).toEqual(new Uint8Array([189, 230, 55, 17, 65, 33, 40, 4, 106, 9, 11, 88, 227, 26, 229, 76, 59, 123, 200, 55, 177, 232, 158, 66, 34, 54, 93, 54, 255, 74, 137, 70]));
|
|
35
|
+
});
|
|
36
|
+
});
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import { hasBigInt } from '@pezkuwi/util';
|
|
5
|
+
import { bip39ToEntropy, isReady } from '@pezkuwi/wasm-crypto';
|
|
6
|
+
|
|
7
|
+
import { mnemonicToEntropy as jsToEntropy } from './bip39.js';
|
|
8
|
+
|
|
9
|
+
export function mnemonicToEntropy (mnemonic: string, wordlist?: string[], onlyJs?: boolean): Uint8Array {
|
|
10
|
+
return !hasBigInt || (!wordlist && !onlyJs && isReady())
|
|
11
|
+
? bip39ToEntropy(mnemonic)
|
|
12
|
+
: jsToEntropy(mnemonic, wordlist);
|
|
13
|
+
}
|