@pezkuwi/util-crypto 14.0.21 → 14.0.23
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/blake2/asU8a.d.ts +1 -1
- package/build/LICENSE +201 -0
- package/build/README.md +17 -0
- package/build/address/addressToEvm.d.ts +5 -0
- package/build/address/addressToEvm.js +8 -0
- package/build/address/check.d.ts +8 -0
- package/build/address/check.js +26 -0
- package/build/address/checksum.d.ts +1 -0
- package/build/address/checksum.js +16 -0
- package/build/address/decode.d.ts +2 -0
- package/build/address/decode.js +29 -0
- package/build/address/defaults.d.ts +6 -0
- package/build/address/defaults.js +8 -0
- package/build/address/derive.d.ts +8 -0
- package/build/address/derive.js +24 -0
- package/build/address/encode.d.ts +2 -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.d.ts +7 -0
- package/build/address/evmToAddress.js +14 -0
- package/build/address/index.d.ts +16 -0
- package/build/address/index.js +16 -0
- package/build/address/is.d.ts +2 -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.d.ts +6 -0
- package/build/address/setSS58Format.js +11 -0
- package/build/address/sort.d.ts +2 -0
- package/build/address/sort.js +7 -0
- package/build/address/sshash.d.ts +1 -0
- package/build/address/sshash.js +6 -0
- package/build/address/types.d.ts +1 -0
- package/build/address/types.js +1 -0
- package/build/address/util.d.ts +1 -0
- package/build/address/util.js +4 -0
- package/build/address/validate.d.ts +2 -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.d.ts +4 -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.d.ts +4 -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.d.ts +6 -0
- package/build/base64/index.js +6 -0
- package/build/base64/pad.d.ts +5 -0
- package/build/base64/pad.js +7 -0
- package/build/base64/trim.d.ts +5 -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.d.ts +4 -0
- package/build/blake2/index.js +4 -0
- package/build/bn.d.ts +30 -0
- package/build/bn.js +8 -0
- package/build/bundle.d.ts +26 -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.d.ts +1 -0
- package/build/cjs/ed25519/deriveHard.js +12 -0
- package/build/cjs/ed25519/index.d.ts +10 -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.d.ts +3 -0
- package/build/cjs/ethereum/index.js +9 -0
- package/build/cjs/ethereum/isAddress.d.ts +1 -0
- package/build/cjs/ethereum/isAddress.js +14 -0
- package/build/cjs/ethereum/isChecksum.d.ts +1 -0
- package/build/cjs/ethereum/isChecksum.js +20 -0
- package/build/cjs/hd/ethereum/index.d.ts +2 -0
- package/build/cjs/hd/ethereum/index.js +47 -0
- package/build/cjs/hd/index.d.ts +3 -0
- package/build/cjs/hd/index.js +9 -0
- package/build/cjs/hd/ledger/derivePrivate.d.ts +1 -0
- package/build/cjs/hd/ledger/derivePrivate.js +15 -0
- package/build/cjs/hd/ledger/index.d.ts +2 -0
- package/build/cjs/hd/ledger/index.js +33 -0
- package/build/cjs/hd/ledger/master.d.ts +1 -0
- package/build/cjs/hd/ledger/master.js +19 -0
- package/build/cjs/hd/validatePath.d.ts +2 -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.d.ts +1 -0
- package/build/cjs/hmac/index.js +7 -0
- package/build/cjs/hmac/shaAsU8a.d.ts +15 -0
- package/build/cjs/hmac/shaAsU8a.js +40 -0
- package/build/cjs/index.d.ts +2 -0
- package/build/cjs/index.js +5 -0
- package/build/cjs/json/constants.d.ts +6 -0
- package/build/cjs/json/constants.js +8 -0
- package/build/cjs/json/decrypt.d.ts +2 -0
- package/build/cjs/json/decrypt.js +16 -0
- package/build/cjs/json/decryptData.d.ts +2 -0
- package/build/cjs/json/decryptData.js +32 -0
- package/build/cjs/json/encrypt.d.ts +2 -0
- package/build/cjs/json/encrypt.js +18 -0
- package/build/cjs/json/encryptFormat.d.ts +2 -0
- package/build/cjs/json/encryptFormat.js +17 -0
- package/build/cjs/json/index.d.ts +4 -0
- package/build/cjs/json/index.js +11 -0
- package/build/cjs/json/types.d.ts +16 -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.d.ts +4 -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.d.ts +9 -0
- package/build/cjs/key/extractPath.js +26 -0
- package/build/cjs/key/extractSuri.d.ts +11 -0
- package/build/cjs/key/extractSuri.js +25 -0
- package/build/cjs/key/fromPath.d.ts +3 -0
- package/build/cjs/key/fromPath.js +21 -0
- package/build/cjs/key/hdkdDerive.d.ts +3 -0
- package/build/cjs/key/hdkdDerive.js +11 -0
- package/build/cjs/key/hdkdEcdsa.d.ts +1 -0
- package/build/cjs/key/hdkdEcdsa.js +7 -0
- package/build/cjs/key/hdkdEd25519.d.ts +1 -0
- package/build/cjs/key/hdkdEd25519.js +6 -0
- package/build/cjs/key/hdkdSr25519.d.ts +3 -0
- package/build/cjs/key/hdkdSr25519.js +10 -0
- package/build/cjs/key/index.d.ts +9 -0
- package/build/cjs/key/index.js +18 -0
- package/build/cjs/mnemonic/bip39.d.ts +5 -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.d.ts +8 -0
- package/build/cjs/mnemonic/index.js +16 -0
- package/build/cjs/mnemonic/toEntropy.d.ts +1 -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.d.ts +1 -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.d.ts +2 -0
- package/build/cjs/mnemonic/wordlists/en.js +3 -0
- package/build/cjs/mnemonic/wordlists/es.d.ts +2 -0
- package/build/cjs/mnemonic/wordlists/es.js +3 -0
- package/build/cjs/mnemonic/wordlists/fr.d.ts +2 -0
- package/build/cjs/mnemonic/wordlists/fr.js +3 -0
- package/build/cjs/mnemonic/wordlists/index.d.ts +8 -0
- package/build/cjs/mnemonic/wordlists/index.js +20 -0
- package/build/cjs/mnemonic/wordlists/it.d.ts +2 -0
- package/build/cjs/mnemonic/wordlists/it.js +3 -0
- package/build/cjs/mnemonic/wordlists/jp.d.ts +2 -0
- package/build/cjs/mnemonic/wordlists/jp.js +3 -0
- package/build/cjs/mnemonic/wordlists/ko.d.ts +2 -0
- package/build/cjs/mnemonic/wordlists/ko.js +3 -0
- package/build/cjs/mnemonic/wordlists/zh-s.d.ts +2 -0
- package/build/cjs/mnemonic/wordlists/zh-s.js +3 -0
- package/build/cjs/mnemonic/wordlists/zh-t.d.ts +2 -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.d.ts +5 -0
- package/build/cjs/nacl/index.js +10 -0
- package/build/cjs/nacl/tweetnacl.d.ts +2 -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/package.json +3 -0
- package/build/cjs/packageDetect.d.ts +1 -0
- package/build/cjs/packageDetect.js +8 -0
- package/build/cjs/packageInfo.d.ts +6 -0
- package/build/cjs/packageInfo.js +4 -0
- package/build/cjs/pbkdf2/encode.d.ts +7 -0
- package/build/cjs/pbkdf2/encode.js +19 -0
- package/build/cjs/pbkdf2/index.d.ts +1 -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.d.ts +5 -0
- package/build/cjs/random/index.js +11 -0
- package/build/cjs/scrypt/defaults.d.ts +3 -0
- package/build/cjs/scrypt/defaults.js +16 -0
- package/build/cjs/scrypt/encode.d.ts +8 -0
- package/build/cjs/scrypt/encode.js +18 -0
- package/build/cjs/scrypt/fromU8a.d.ts +7 -0
- package/build/cjs/scrypt/fromU8a.js +27 -0
- package/build/cjs/scrypt/index.d.ts +3 -0
- package/build/cjs/scrypt/index.js +9 -0
- package/build/cjs/scrypt/toU8a.d.ts +2 -0
- package/build/cjs/scrypt/toU8a.js +8 -0
- package/build/cjs/scrypt/types.d.ts +6 -0
- package/build/cjs/scrypt/types.js +2 -0
- package/build/cjs/secp256k1/compress.d.ts +1 -0
- package/build/cjs/secp256k1/compress.js +17 -0
- package/build/cjs/secp256k1/deriveHard.d.ts +1 -0
- package/build/cjs/secp256k1/deriveHard.js +13 -0
- package/build/cjs/secp256k1/expand.d.ts +1 -0
- package/build/cjs/secp256k1/expand.js +20 -0
- package/build/cjs/secp256k1/hasher.d.ts +2 -0
- package/build/cjs/secp256k1/hasher.js +10 -0
- package/build/cjs/secp256k1/index.d.ts +7 -0
- package/build/cjs/secp256k1/index.js +17 -0
- package/build/cjs/secp256k1/pair/fromSeed.d.ts +6 -0
- package/build/cjs/secp256k1/pair/fromSeed.js +34 -0
- package/build/cjs/secp256k1/recover.d.ts +6 -0
- package/build/cjs/secp256k1/recover.js +29 -0
- package/build/cjs/secp256k1/sign.d.ts +7 -0
- package/build/cjs/secp256k1/sign.js +23 -0
- package/build/cjs/secp256k1/tweakAdd.d.ts +1 -0
- package/build/cjs/secp256k1/tweakAdd.js +48 -0
- package/build/cjs/secp256k1/types.d.ts +1 -0
- package/build/cjs/secp256k1/types.js +2 -0
- package/build/cjs/secp256k1/verify.d.ts +6 -0
- package/build/cjs/secp256k1/verify.js +23 -0
- package/build/cjs/sha/asU8a.d.ts +15 -0
- package/build/cjs/sha/asU8a.js +22 -0
- package/build/cjs/sha/index.d.ts +4 -0
- package/build/cjs/sha/index.js +10 -0
- package/build/cjs/signature/index.d.ts +4 -0
- package/build/cjs/signature/index.js +8 -0
- package/build/cjs/signature/verify.d.ts +2 -0
- package/build/cjs/signature/verify.js +81 -0
- package/build/cjs/sr25519/agreement.d.ts +5 -0
- package/build/cjs/sr25519/agreement.js +20 -0
- package/build/cjs/sr25519/derive.d.ts +2 -0
- package/build/cjs/sr25519/derive.js +16 -0
- package/build/cjs/sr25519/deriveHard.d.ts +1 -0
- package/build/cjs/sr25519/deriveHard.js +7 -0
- package/build/cjs/sr25519/derivePublic.d.ts +1 -0
- package/build/cjs/sr25519/derivePublic.js +16 -0
- package/build/cjs/sr25519/deriveSoft.d.ts +1 -0
- package/build/cjs/sr25519/deriveSoft.js +7 -0
- package/build/cjs/sr25519/index.d.ts +9 -0
- package/build/cjs/sr25519/index.js +21 -0
- package/build/cjs/sr25519/pair/fromSeed.d.ts +6 -0
- package/build/cjs/sr25519/pair/fromSeed.js +22 -0
- package/build/cjs/sr25519/pair/fromU8a.d.ts +2 -0
- package/build/cjs/sr25519/pair/fromU8a.js +17 -0
- package/build/cjs/sr25519/pair/toU8a.d.ts +2 -0
- package/build/cjs/sr25519/pair/toU8a.js +7 -0
- package/build/cjs/sr25519/sign.d.ts +6 -0
- package/build/cjs/sr25519/sign.js +19 -0
- package/build/cjs/sr25519/verify.d.ts +5 -0
- package/build/cjs/sr25519/verify.js +21 -0
- package/build/cjs/sr25519/vrfSign.d.ts +6 -0
- package/build/cjs/sr25519/vrfSign.js +19 -0
- package/build/cjs/sr25519/vrfVerify.d.ts +5 -0
- package/build/cjs/sr25519/vrfVerify.js +22 -0
- package/build/cjs/types.d.ts +26 -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.d.ts +4 -0
- package/build/cjs/xxhash/index.js +9 -0
- package/build/cjs/xxhash/xxhash64.d.ts +1 -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/addressToEvm.d.ts +5 -0
- package/build-tsc/address/check.d.ts +8 -0
- package/build-tsc/address/checksum.d.ts +1 -0
- package/build-tsc/address/decode.d.ts +2 -0
- package/build-tsc/address/defaults.d.ts +6 -0
- package/build-tsc/address/derive.d.ts +8 -0
- package/build-tsc/address/encode.d.ts +2 -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/evmToAddress.d.ts +7 -0
- package/build-tsc/address/index.d.ts +16 -0
- package/build-tsc/address/is.d.ts +2 -0
- package/build-tsc/address/keyDerived.d.ts +2 -0
- package/build-tsc/address/keyMulti.d.ts +2 -0
- package/build-tsc/address/setSS58Format.d.ts +6 -0
- package/build-tsc/address/sort.d.ts +2 -0
- package/build-tsc/address/sshash.d.ts +1 -0
- package/build-tsc/address/types.d.ts +1 -0
- package/build-tsc/address/util.d.ts +1 -0
- package/build-tsc/address/validate.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/base32/index.d.ts +4 -0
- package/build-tsc/base58/bs58.d.ts +26 -0
- package/build-tsc/base58/index.d.ts +4 -0
- package/build-tsc/base64/bs64.d.ts +26 -0
- package/build-tsc/base64/index.d.ts +6 -0
- package/build-tsc/base64/pad.d.ts +5 -0
- package/build-tsc/base64/trim.d.ts +5 -0
- package/build-tsc/blake2/asU8a.d.ts +20 -0
- package/build-tsc/blake2/index.d.ts +4 -0
- package/build-tsc/bn.d.ts +30 -0
- package/build-tsc/bundle.d.ts +26 -0
- package/build-tsc/bundleInit.d.ts +1 -0
- package/build-tsc/crypto.d.ts +3 -0
- package/build-tsc/ed25519/deriveHard.d.ts +1 -0
- package/build-tsc/ed25519/index.d.ts +10 -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/ethereum/index.d.ts +3 -0
- package/build-tsc/ethereum/isAddress.d.ts +1 -0
- package/build-tsc/ethereum/isChecksum.d.ts +1 -0
- package/build-tsc/hd/ethereum/index.d.ts +2 -0
- package/build-tsc/hd/index.d.ts +3 -0
- package/build-tsc/hd/ledger/derivePrivate.d.ts +1 -0
- package/build-tsc/hd/ledger/index.d.ts +2 -0
- package/build-tsc/hd/ledger/master.d.ts +1 -0
- package/build-tsc/hd/validatePath.d.ts +2 -0
- package/build-tsc/helpers.d.ts +12 -0
- package/build-tsc/hmac/index.d.ts +1 -0
- package/build-tsc/hmac/shaAsU8a.d.ts +15 -0
- package/build-tsc/index.d.ts +2 -0
- package/build-tsc/json/constants.d.ts +6 -0
- package/build-tsc/json/decrypt.d.ts +2 -0
- package/build-tsc/json/decryptData.d.ts +2 -0
- package/build-tsc/json/encrypt.d.ts +2 -0
- package/build-tsc/json/encryptFormat.d.ts +2 -0
- package/build-tsc/json/index.d.ts +4 -0
- package/build-tsc/json/types.d.ts +16 -0
- package/build-tsc/keccak/asU8a.d.ts +30 -0
- package/build-tsc/keccak/index.d.ts +4 -0
- package/build-tsc/key/DeriveJunction.d.ts +12 -0
- package/build-tsc/key/extractPath.d.ts +9 -0
- package/build-tsc/key/extractSuri.d.ts +11 -0
- package/build-tsc/key/fromPath.d.ts +3 -0
- package/build-tsc/key/hdkdDerive.d.ts +3 -0
- package/build-tsc/key/hdkdEcdsa.d.ts +1 -0
- package/build-tsc/key/hdkdEd25519.d.ts +1 -0
- package/build-tsc/key/hdkdSr25519.d.ts +3 -0
- package/build-tsc/key/index.d.ts +9 -0
- package/build-tsc/mnemonic/bip39.d.ts +5 -0
- package/build-tsc/mnemonic/generate.d.ts +13 -0
- package/build-tsc/mnemonic/index.d.ts +8 -0
- package/build-tsc/mnemonic/toEntropy.d.ts +1 -0
- package/build-tsc/mnemonic/toLegacySeed.d.ts +18 -0
- package/build-tsc/mnemonic/toMiniSecret.d.ts +1 -0
- package/build-tsc/mnemonic/validate.d.ts +14 -0
- package/build-tsc/mnemonic/wordlists/en.d.ts +2 -0
- package/build-tsc/mnemonic/wordlists/es.d.ts +2 -0
- package/build-tsc/mnemonic/wordlists/fr.d.ts +2 -0
- package/build-tsc/mnemonic/wordlists/index.d.ts +8 -0
- package/build-tsc/mnemonic/wordlists/it.d.ts +2 -0
- package/build-tsc/mnemonic/wordlists/jp.d.ts +2 -0
- package/build-tsc/mnemonic/wordlists/ko.d.ts +2 -0
- package/build-tsc/mnemonic/wordlists/zh-s.d.ts +2 -0
- package/build-tsc/mnemonic/wordlists/zh-t.d.ts +2 -0
- package/build-tsc/nacl/decrypt.d.ts +15 -0
- package/build-tsc/nacl/encrypt.d.ts +20 -0
- package/build-tsc/nacl/index.d.ts +5 -0
- package/build-tsc/nacl/tweetnacl.d.ts +2 -0
- package/build-tsc/networks.d.ts +1 -0
- package/build-tsc/packageDetect.d.ts +1 -0
- package/build-tsc/packageInfo.d.ts +6 -0
- package/build-tsc/pbkdf2/encode.d.ts +7 -0
- package/build-tsc/pbkdf2/index.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/random/index.d.ts +5 -0
- package/build-tsc/scrypt/defaults.d.ts +3 -0
- package/build-tsc/scrypt/encode.d.ts +8 -0
- package/build-tsc/scrypt/fromU8a.d.ts +7 -0
- package/build-tsc/scrypt/index.d.ts +3 -0
- package/build-tsc/scrypt/toU8a.d.ts +2 -0
- package/build-tsc/scrypt/types.d.ts +6 -0
- package/build-tsc/secp256k1/compress.d.ts +1 -0
- package/build-tsc/secp256k1/deriveHard.d.ts +1 -0
- package/build-tsc/secp256k1/expand.d.ts +1 -0
- package/build-tsc/secp256k1/hasher.d.ts +2 -0
- package/build-tsc/secp256k1/index.d.ts +7 -0
- package/build-tsc/secp256k1/pair/fromSeed.d.ts +6 -0
- package/build-tsc/secp256k1/recover.d.ts +6 -0
- package/build-tsc/secp256k1/sign.d.ts +7 -0
- package/build-tsc/secp256k1/tweakAdd.d.ts +1 -0
- package/build-tsc/secp256k1/types.d.ts +1 -0
- package/build-tsc/secp256k1/verify.d.ts +6 -0
- package/build-tsc/sha/asU8a.d.ts +15 -0
- package/build-tsc/sha/index.d.ts +4 -0
- package/build-tsc/signature/index.d.ts +4 -0
- package/build-tsc/signature/verify.d.ts +2 -0
- package/build-tsc/sr25519/agreement.d.ts +5 -0
- package/build-tsc/sr25519/derive.d.ts +2 -0
- package/build-tsc/sr25519/deriveHard.d.ts +1 -0
- package/build-tsc/sr25519/derivePublic.d.ts +1 -0
- package/build-tsc/sr25519/deriveSoft.d.ts +1 -0
- package/build-tsc/sr25519/index.d.ts +9 -0
- package/build-tsc/sr25519/pair/fromSeed.d.ts +6 -0
- package/build-tsc/sr25519/pair/fromU8a.d.ts +2 -0
- package/build-tsc/sr25519/pair/toU8a.d.ts +2 -0
- package/build-tsc/sr25519/sign.d.ts +6 -0
- package/build-tsc/sr25519/verify.d.ts +5 -0
- package/build-tsc/sr25519/vrfSign.d.ts +6 -0
- package/build-tsc/sr25519/vrfVerify.d.ts +5 -0
- package/build-tsc/types.d.ts +26 -0
- package/build-tsc/xxhash/asU8a.d.ts +20 -0
- package/build-tsc/xxhash/index.d.ts +4 -0
- package/build-tsc/xxhash/xxhash64.d.ts +1 -0
- package/build-tsc-cjs/address/addressToEvm.js +11 -0
- package/build-tsc-cjs/address/check.js +29 -0
- package/build-tsc-cjs/address/checksum.js +19 -0
- package/build-tsc-cjs/address/decode.js +32 -0
- package/build-tsc-cjs/address/defaults.js +11 -0
- package/build-tsc-cjs/address/derive.js +27 -0
- package/build-tsc-cjs/address/encode.js +26 -0
- package/build-tsc-cjs/address/encodeDerived.js +15 -0
- package/build-tsc-cjs/address/encodeMulti.js +14 -0
- package/build-tsc-cjs/address/eq.js +22 -0
- package/build-tsc-cjs/address/evmToAddress.js +17 -0
- package/build-tsc-cjs/address/index.js +35 -0
- package/build-tsc-cjs/address/is.js +12 -0
- package/build-tsc-cjs/address/keyDerived.js +11 -0
- package/build-tsc-cjs/address/keyMulti.js +11 -0
- package/build-tsc-cjs/address/setSS58Format.js +14 -0
- package/build-tsc-cjs/address/sort.js +10 -0
- package/build-tsc-cjs/address/sshash.js +9 -0
- package/build-tsc-cjs/address/types.js +2 -0
- package/build-tsc-cjs/address/util.js +7 -0
- package/build-tsc-cjs/address/validate.js +7 -0
- package/build-tsc-cjs/base32/bs32.js +43 -0
- package/build-tsc-cjs/base32/helpers.js +67 -0
- package/build-tsc-cjs/base32/index.js +11 -0
- package/build-tsc-cjs/base58/bs58.js +37 -0
- package/build-tsc-cjs/base58/index.js +11 -0
- package/build-tsc-cjs/base64/bs64.js +37 -0
- package/build-tsc-cjs/base64/index.js +15 -0
- package/build-tsc-cjs/base64/pad.js +10 -0
- package/build-tsc-cjs/base64/trim.js +13 -0
- package/build-tsc-cjs/blake2/asU8a.js +36 -0
- package/build-tsc-cjs/blake2/index.js +9 -0
- package/build-tsc-cjs/bn.js +11 -0
- package/build-tsc-cjs/bundle.js +31 -0
- package/build-tsc-cjs/bundleInit.js +7 -0
- package/build-tsc-cjs/crypto.js +16 -0
- package/build-tsc-cjs/ed25519/deriveHard.js +12 -0
- package/build-tsc-cjs/ed25519/index.js +20 -0
- package/build-tsc-cjs/ed25519/pair/fromRandom.js +22 -0
- package/build-tsc-cjs/ed25519/pair/fromSecret.js +26 -0
- package/build-tsc-cjs/ed25519/pair/fromSeed.js +34 -0
- package/build-tsc-cjs/ed25519/pair/fromString.js +23 -0
- package/build-tsc-cjs/ed25519/sign.js +33 -0
- package/build-tsc-cjs/ed25519/verify.js +39 -0
- package/build-tsc-cjs/ethereum/encode.js +28 -0
- package/build-tsc-cjs/ethereum/index.js +9 -0
- package/build-tsc-cjs/ethereum/isAddress.js +14 -0
- package/build-tsc-cjs/ethereum/isChecksum.js +20 -0
- package/build-tsc-cjs/hd/ethereum/index.js +47 -0
- package/build-tsc-cjs/hd/index.js +9 -0
- package/build-tsc-cjs/hd/ledger/derivePrivate.js +15 -0
- package/build-tsc-cjs/hd/ledger/index.js +33 -0
- package/build-tsc-cjs/hd/ledger/master.js +19 -0
- package/build-tsc-cjs/hd/validatePath.js +20 -0
- package/build-tsc-cjs/helpers.js +24 -0
- package/build-tsc-cjs/hmac/index.js +7 -0
- package/build-tsc-cjs/hmac/shaAsU8a.js +40 -0
- package/build-tsc-cjs/index.js +5 -0
- package/build-tsc-cjs/json/constants.js +8 -0
- package/build-tsc-cjs/json/decrypt.js +16 -0
- package/build-tsc-cjs/json/decryptData.js +32 -0
- package/build-tsc-cjs/json/encrypt.js +18 -0
- package/build-tsc-cjs/json/encryptFormat.js +17 -0
- package/build-tsc-cjs/json/index.js +11 -0
- package/build-tsc-cjs/json/types.js +2 -0
- package/build-tsc-cjs/keccak/asU8a.js +36 -0
- package/build-tsc-cjs/keccak/index.js +11 -0
- package/build-tsc-cjs/key/DeriveJunction.js +62 -0
- package/build-tsc-cjs/key/extractPath.js +26 -0
- package/build-tsc-cjs/key/extractSuri.js +25 -0
- package/build-tsc-cjs/key/fromPath.js +21 -0
- package/build-tsc-cjs/key/hdkdDerive.js +11 -0
- package/build-tsc-cjs/key/hdkdEcdsa.js +7 -0
- package/build-tsc-cjs/key/hdkdEd25519.js +6 -0
- package/build-tsc-cjs/key/hdkdSr25519.js +10 -0
- package/build-tsc-cjs/key/index.js +18 -0
- package/build-tsc-cjs/mnemonic/bip39.js +90 -0
- package/build-tsc-cjs/mnemonic/generate.js +23 -0
- package/build-tsc-cjs/mnemonic/index.js +16 -0
- package/build-tsc-cjs/mnemonic/toEntropy.js +11 -0
- package/build-tsc-cjs/mnemonic/toLegacySeed.js +37 -0
- package/build-tsc-cjs/mnemonic/toMiniSecret.js +20 -0
- package/build-tsc-cjs/mnemonic/validate.js +24 -0
- package/build-tsc-cjs/mnemonic/wordlists/en.js +3 -0
- package/build-tsc-cjs/mnemonic/wordlists/es.js +3 -0
- package/build-tsc-cjs/mnemonic/wordlists/fr.js +3 -0
- package/build-tsc-cjs/mnemonic/wordlists/index.js +20 -0
- package/build-tsc-cjs/mnemonic/wordlists/it.js +3 -0
- package/build-tsc-cjs/mnemonic/wordlists/jp.js +3 -0
- package/build-tsc-cjs/mnemonic/wordlists/ko.js +3 -0
- package/build-tsc-cjs/mnemonic/wordlists/zh-s.js +3 -0
- package/build-tsc-cjs/mnemonic/wordlists/zh-t.js +3 -0
- package/build-tsc-cjs/nacl/decrypt.js +21 -0
- package/build-tsc-cjs/nacl/encrypt.js +25 -0
- package/build-tsc-cjs/nacl/index.js +10 -0
- package/build-tsc-cjs/nacl/tweetnacl.js +238 -0
- package/build-tsc-cjs/networks.js +7 -0
- package/build-tsc-cjs/packageDetect.js +8 -0
- package/build-tsc-cjs/packageInfo.js +4 -0
- package/build-tsc-cjs/pbkdf2/encode.js +19 -0
- package/build-tsc-cjs/pbkdf2/index.js +5 -0
- package/build-tsc-cjs/random/asNumber.js +23 -0
- package/build-tsc-cjs/random/asU8a.js +28 -0
- package/build-tsc-cjs/random/index.js +11 -0
- package/build-tsc-cjs/scrypt/defaults.js +16 -0
- package/build-tsc-cjs/scrypt/encode.js +18 -0
- package/build-tsc-cjs/scrypt/fromU8a.js +27 -0
- package/build-tsc-cjs/scrypt/index.js +9 -0
- package/build-tsc-cjs/scrypt/toU8a.js +8 -0
- package/build-tsc-cjs/scrypt/types.js +2 -0
- package/build-tsc-cjs/secp256k1/compress.js +17 -0
- package/build-tsc-cjs/secp256k1/deriveHard.js +13 -0
- package/build-tsc-cjs/secp256k1/expand.js +20 -0
- package/build-tsc-cjs/secp256k1/hasher.js +10 -0
- package/build-tsc-cjs/secp256k1/index.js +17 -0
- package/build-tsc-cjs/secp256k1/pair/fromSeed.js +34 -0
- package/build-tsc-cjs/secp256k1/recover.js +29 -0
- package/build-tsc-cjs/secp256k1/sign.js +23 -0
- package/build-tsc-cjs/secp256k1/tweakAdd.js +48 -0
- package/build-tsc-cjs/secp256k1/types.js +2 -0
- package/build-tsc-cjs/secp256k1/verify.js +23 -0
- package/build-tsc-cjs/sha/asU8a.js +22 -0
- package/build-tsc-cjs/sha/index.js +10 -0
- package/build-tsc-cjs/signature/index.js +8 -0
- package/build-tsc-cjs/signature/verify.js +81 -0
- package/build-tsc-cjs/sr25519/agreement.js +20 -0
- package/build-tsc-cjs/sr25519/derive.js +16 -0
- package/build-tsc-cjs/sr25519/deriveHard.js +7 -0
- package/build-tsc-cjs/sr25519/derivePublic.js +16 -0
- package/build-tsc-cjs/sr25519/deriveSoft.js +7 -0
- package/build-tsc-cjs/sr25519/index.js +21 -0
- package/build-tsc-cjs/sr25519/pair/fromSeed.js +22 -0
- package/build-tsc-cjs/sr25519/pair/fromU8a.js +17 -0
- package/build-tsc-cjs/sr25519/pair/toU8a.js +7 -0
- package/build-tsc-cjs/sr25519/sign.js +19 -0
- package/build-tsc-cjs/sr25519/verify.js +21 -0
- package/build-tsc-cjs/sr25519/vrfSign.js +19 -0
- package/build-tsc-cjs/sr25519/vrfVerify.js +22 -0
- package/build-tsc-cjs/types.js +5 -0
- package/build-tsc-cjs/xxhash/asU8a.js +39 -0
- package/build-tsc-cjs/xxhash/index.js +9 -0
- package/build-tsc-cjs/xxhash/xxhash64.js +103 -0
- package/build-tsc-esm/address/addressToEvm.js +8 -0
- package/build-tsc-esm/address/check.js +26 -0
- package/build-tsc-esm/address/checksum.js +16 -0
- package/build-tsc-esm/address/decode.js +29 -0
- package/build-tsc-esm/address/defaults.js +8 -0
- package/build-tsc-esm/address/derive.js +24 -0
- package/build-tsc-esm/address/encode.js +23 -0
- package/build-tsc-esm/address/encodeDerived.js +12 -0
- package/build-tsc-esm/address/encodeMulti.js +11 -0
- package/build-tsc-esm/address/eq.js +19 -0
- package/build-tsc-esm/address/evmToAddress.js +14 -0
- package/build-tsc-esm/address/index.js +16 -0
- package/build-tsc-esm/address/is.js +9 -0
- package/build-tsc-esm/address/keyDerived.js +8 -0
- package/build-tsc-esm/address/keyMulti.js +8 -0
- package/build-tsc-esm/address/setSS58Format.js +11 -0
- package/build-tsc-esm/address/sort.js +7 -0
- package/build-tsc-esm/address/sshash.js +6 -0
- package/build-tsc-esm/address/types.js +1 -0
- package/build-tsc-esm/address/util.js +4 -0
- package/build-tsc-esm/address/validate.js +4 -0
- package/build-tsc-esm/base32/bs32.js +40 -0
- package/build-tsc-esm/base32/helpers.js +61 -0
- package/build-tsc-esm/base32/index.js +4 -0
- package/build-tsc-esm/base58/bs58.js +34 -0
- package/build-tsc-esm/base58/index.js +4 -0
- package/build-tsc-esm/base64/bs64.js +34 -0
- package/build-tsc-esm/base64/index.js +6 -0
- package/build-tsc-esm/base64/pad.js +7 -0
- package/build-tsc-esm/base64/trim.js +10 -0
- package/build-tsc-esm/blake2/asU8a.js +32 -0
- package/build-tsc-esm/blake2/index.js +4 -0
- package/build-tsc-esm/bn.js +8 -0
- package/build-tsc-esm/bundle.js +26 -0
- package/build-tsc-esm/bundleInit.js +5 -0
- package/build-tsc-esm/crypto.js +12 -0
- package/build-tsc-esm/ed25519/deriveHard.js +9 -0
- package/build-tsc-esm/ed25519/index.js +10 -0
- package/build-tsc-esm/ed25519/pair/fromRandom.js +19 -0
- package/build-tsc-esm/ed25519/pair/fromSecret.js +23 -0
- package/build-tsc-esm/ed25519/pair/fromSeed.js +31 -0
- package/build-tsc-esm/ed25519/pair/fromString.js +20 -0
- package/build-tsc-esm/ed25519/sign.js +30 -0
- package/build-tsc-esm/ed25519/verify.js +36 -0
- package/build-tsc-esm/ethereum/encode.js +25 -0
- package/build-tsc-esm/ethereum/index.js +3 -0
- package/build-tsc-esm/ethereum/isAddress.js +11 -0
- package/build-tsc-esm/ethereum/isChecksum.js +17 -0
- package/build-tsc-esm/hd/ethereum/index.js +44 -0
- package/build-tsc-esm/hd/index.js +3 -0
- package/build-tsc-esm/hd/ledger/derivePrivate.js +12 -0
- package/build-tsc-esm/hd/ledger/index.js +30 -0
- package/build-tsc-esm/hd/ledger/master.js +16 -0
- package/build-tsc-esm/hd/validatePath.js +16 -0
- package/build-tsc-esm/helpers.js +19 -0
- package/build-tsc-esm/hmac/index.js +1 -0
- package/build-tsc-esm/hmac/shaAsU8a.js +36 -0
- package/build-tsc-esm/index.js +2 -0
- package/build-tsc-esm/json/constants.js +5 -0
- package/build-tsc-esm/json/decrypt.js +13 -0
- package/build-tsc-esm/json/decryptData.js +29 -0
- package/build-tsc-esm/json/encrypt.js +15 -0
- package/build-tsc-esm/json/encryptFormat.js +14 -0
- package/build-tsc-esm/json/index.js +4 -0
- package/build-tsc-esm/json/types.js +1 -0
- package/build-tsc-esm/keccak/asU8a.js +33 -0
- package/build-tsc-esm/keccak/index.js +4 -0
- package/build-tsc-esm/key/DeriveJunction.js +58 -0
- package/build-tsc-esm/key/extractPath.js +23 -0
- package/build-tsc-esm/key/extractSuri.js +22 -0
- package/build-tsc-esm/key/fromPath.js +18 -0
- package/build-tsc-esm/key/hdkdDerive.js +8 -0
- package/build-tsc-esm/key/hdkdEcdsa.js +4 -0
- package/build-tsc-esm/key/hdkdEd25519.js +3 -0
- package/build-tsc-esm/key/hdkdSr25519.js +7 -0
- package/build-tsc-esm/key/index.js +9 -0
- package/build-tsc-esm/mnemonic/bip39.js +82 -0
- package/build-tsc-esm/mnemonic/generate.js +20 -0
- package/build-tsc-esm/mnemonic/index.js +8 -0
- package/build-tsc-esm/mnemonic/toEntropy.js +8 -0
- package/build-tsc-esm/mnemonic/toLegacySeed.js +34 -0
- package/build-tsc-esm/mnemonic/toMiniSecret.js +17 -0
- package/build-tsc-esm/mnemonic/validate.js +21 -0
- package/build-tsc-esm/mnemonic/wordlists/en.js +1 -0
- package/build-tsc-esm/mnemonic/wordlists/es.js +1 -0
- package/build-tsc-esm/mnemonic/wordlists/fr.js +1 -0
- package/build-tsc-esm/mnemonic/wordlists/index.js +8 -0
- package/build-tsc-esm/mnemonic/wordlists/it.js +1 -0
- package/build-tsc-esm/mnemonic/wordlists/jp.js +1 -0
- package/build-tsc-esm/mnemonic/wordlists/ko.js +1 -0
- package/build-tsc-esm/mnemonic/wordlists/zh-s.js +1 -0
- package/build-tsc-esm/mnemonic/wordlists/zh-t.js +1 -0
- package/build-tsc-esm/nacl/decrypt.js +18 -0
- package/build-tsc-esm/nacl/encrypt.js +22 -0
- package/build-tsc-esm/nacl/index.js +5 -0
- package/build-tsc-esm/nacl/tweetnacl.js +234 -0
- package/build-tsc-esm/networks.js +1 -0
- package/build-tsc-esm/packageDetect.js +6 -0
- package/build-tsc-esm/packageInfo.js +1 -0
- package/build-tsc-esm/pbkdf2/encode.js +16 -0
- package/build-tsc-esm/pbkdf2/index.js +1 -0
- package/build-tsc-esm/random/asNumber.js +20 -0
- package/build-tsc-esm/random/asU8a.js +24 -0
- package/build-tsc-esm/random/index.js +5 -0
- package/build-tsc-esm/scrypt/defaults.js +13 -0
- package/build-tsc-esm/scrypt/encode.js +15 -0
- package/build-tsc-esm/scrypt/fromU8a.js +24 -0
- package/build-tsc-esm/scrypt/index.js +3 -0
- package/build-tsc-esm/scrypt/toU8a.js +5 -0
- package/build-tsc-esm/scrypt/types.js +1 -0
- package/build-tsc-esm/secp256k1/compress.js +14 -0
- package/build-tsc-esm/secp256k1/deriveHard.js +10 -0
- package/build-tsc-esm/secp256k1/expand.js +17 -0
- package/build-tsc-esm/secp256k1/hasher.js +7 -0
- package/build-tsc-esm/secp256k1/index.js +7 -0
- package/build-tsc-esm/secp256k1/pair/fromSeed.js +31 -0
- package/build-tsc-esm/secp256k1/recover.js +26 -0
- package/build-tsc-esm/secp256k1/sign.js +20 -0
- package/build-tsc-esm/secp256k1/tweakAdd.js +45 -0
- package/build-tsc-esm/secp256k1/types.js +1 -0
- package/build-tsc-esm/secp256k1/verify.js +20 -0
- package/build-tsc-esm/sha/asU8a.js +19 -0
- package/build-tsc-esm/sha/index.js +4 -0
- package/build-tsc-esm/signature/index.js +4 -0
- package/build-tsc-esm/signature/verify.js +78 -0
- package/build-tsc-esm/sr25519/agreement.js +17 -0
- package/build-tsc-esm/sr25519/derive.js +12 -0
- package/build-tsc-esm/sr25519/deriveHard.js +3 -0
- package/build-tsc-esm/sr25519/derivePublic.js +12 -0
- package/build-tsc-esm/sr25519/deriveSoft.js +3 -0
- package/build-tsc-esm/sr25519/index.js +9 -0
- package/build-tsc-esm/sr25519/pair/fromSeed.js +18 -0
- package/build-tsc-esm/sr25519/pair/fromU8a.js +14 -0
- package/build-tsc-esm/sr25519/pair/toU8a.js +4 -0
- package/build-tsc-esm/sr25519/sign.js +15 -0
- package/build-tsc-esm/sr25519/verify.js +17 -0
- package/build-tsc-esm/sr25519/vrfSign.js +15 -0
- package/build-tsc-esm/sr25519/vrfVerify.js +18 -0
- package/build-tsc-esm/types.js +2 -0
- package/build-tsc-esm/xxhash/asU8a.js +35 -0
- package/build-tsc-esm/xxhash/index.js +4 -0
- package/build-tsc-esm/xxhash/xxhash64.js +100 -0
- package/bundle-pezkuwi-util-crypto.js +8246 -8797
- package/cjs/blake2/asU8a.d.ts +1 -1
- package/cjs/keccak/asU8a.d.ts +1 -1
- package/cjs/packageInfo.js +1 -1
- package/cjs/scrypt/encode.d.ts +1 -1
- package/cjs/sr25519/agreement.js +2 -2
- package/cjs/xxhash/asU8a.d.ts +1 -1
- package/keccak/asU8a.d.ts +1 -1
- package/package.json +14 -14
- package/packageInfo.js +1 -1
- package/scrypt/encode.d.ts +1 -1
- 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/xxhash/asU8a.d.ts +1 -1
|
@@ -0,0 +1,55 @@
|
|
|
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 { hexToU8a } from '@pezkuwi/util';
|
|
7
|
+
import { waitReady } from '@pezkuwi/wasm-crypto';
|
|
8
|
+
|
|
9
|
+
import { perfWasm } from '../test/index.js';
|
|
10
|
+
import { sha256AsU8a } from './index.js';
|
|
11
|
+
|
|
12
|
+
const TESTS = [
|
|
13
|
+
{
|
|
14
|
+
input: '0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855',
|
|
15
|
+
output: '0x5df6e0e2761359d30a8275058e299fcc0381534545f55cf43e41983f5d4c9456'
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
input: '0x7941cb07924fdc7b710e11d98d82850e89566e1c3cb980517ffe4b430f86dfd5',
|
|
19
|
+
output: '0xe668668fa102ccd4d3cf50e4472be8426e7dc52d6d355bee8c5e2177d1de81f7'
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
input: '0x5d9a905bc3ca7c153623af0a05231960eb3f5bdd5b8b7b55ede8b2deac689d65',
|
|
23
|
+
output: '0x6721bc38e80d03f4f45f1544819d17e0c33674eb6efcddf6c6192cd78194dd9f'
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
input: '0xb0cd6528ae4d5baf7c6f0d202e7f372b6488d22b2a5bd72f794f8f1e6031b31f',
|
|
27
|
+
output: '0x353f5a030af27885aed3571cd9e2cac9f4331c51d31cef496a586496aec32256'
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
input: '0x841267bd4110e1b634e17cd019abc6ae4f9a6dd097fb063000c1615a643b5463',
|
|
31
|
+
output: '0x8174a30d921978e7055516189872cca737b49468c6bcf7fdfe59d4a54c489a1f'
|
|
32
|
+
}
|
|
33
|
+
];
|
|
34
|
+
|
|
35
|
+
describe('sha256AsU8a', (): void => {
|
|
36
|
+
beforeEach(async (): Promise<void> => {
|
|
37
|
+
await waitReady();
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
for (const onlyJs of [false, true]) {
|
|
41
|
+
describe(`onlyJs=${(onlyJs && 'true') || 'false'}`, (): void => {
|
|
42
|
+
for (const { input, output } of TESTS) {
|
|
43
|
+
it(`creates known sha-256 hash, ${output}`, (): void => {
|
|
44
|
+
expect(
|
|
45
|
+
sha256AsU8a(hexToU8a(input), onlyJs)
|
|
46
|
+
).toEqual(hexToU8a(output));
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
perfWasm('sha256AsU8a', 128000, (input, onlyJs) =>
|
|
53
|
+
sha256AsU8a(input, onlyJs)
|
|
54
|
+
);
|
|
55
|
+
});
|
|
@@ -0,0 +1,33 @@
|
|
|
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 { waitReady } from '@pezkuwi/wasm-crypto';
|
|
7
|
+
|
|
8
|
+
import { perfWasm } from '../test/index.js';
|
|
9
|
+
import { sha512AsU8a } from './index.js';
|
|
10
|
+
|
|
11
|
+
describe('sha512AsU8a', (): void => {
|
|
12
|
+
beforeEach(async (): Promise<void> => {
|
|
13
|
+
await waitReady();
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
for (const onlyJs of [false, true]) {
|
|
17
|
+
describe(`onlyJs=${(onlyJs && 'true') || 'false'}`, (): void => {
|
|
18
|
+
it('creates a sha-512 hash', (): void => {
|
|
19
|
+
expect(
|
|
20
|
+
sha512AsU8a(Uint8Array.from([0x61, 0x62, 0x63, 0x64]), onlyJs)
|
|
21
|
+
).toEqual(
|
|
22
|
+
Uint8Array.from([
|
|
23
|
+
216, 2, 47, 32, 96, 173, 110, 253, 41, 122, 183, 61, 204, 83, 85, 201, 178, 20, 5, 75, 13, 23, 118, 161, 54, 166, 105, 210, 106, 125, 59, 20, 247, 58, 160, 208, 235, 255, 25, 238, 51, 51, 104, 240, 22, 75, 100, 25, 169, 109, 164, 158, 62, 72, 23, 83, 231, 233, 107, 113, 107, 220, 203, 111
|
|
24
|
+
])
|
|
25
|
+
);
|
|
26
|
+
});
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
perfWasm('sha512AsU8a', 64000, (input, onlyJs) =>
|
|
31
|
+
sha512AsU8a(input, onlyJs)
|
|
32
|
+
);
|
|
33
|
+
});
|
package/src/sha/index.ts
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* @summary Implements Sha-256/512 hashing functions for a variety of input and outputs
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
export { sha256AsU8a, sha512AsU8a, shaAsU8a } from './asU8a.js';
|
|
@@ -0,0 +1,230 @@
|
|
|
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 { hexToU8a, stringToU8a, u8aConcat, u8aToHex, u8aWrapBytes } from '@pezkuwi/util';
|
|
7
|
+
import { waitReady } from '@pezkuwi/wasm-crypto';
|
|
8
|
+
|
|
9
|
+
import { decodeAddress } from '../address/index.js';
|
|
10
|
+
import { secp256k1Sign } from '../secp256k1/sign.js';
|
|
11
|
+
import { signatureVerify } from './index.js';
|
|
12
|
+
|
|
13
|
+
const ADDR_ED = 'DxN4uvzwPzJLtn17yew6jEffPhXQfdKHTp2brufb98vGbPN';
|
|
14
|
+
const ADDR_SR = 'EK1bFgKm2FsghcttHT7TB7rNyXApFgs9fCbijMGQNyFGBQm';
|
|
15
|
+
const ADDR_SR_WRAP = 'J9nD3s7zssCX7bion1xctAF6xcVexcpy2uwy4jTm9JL8yuK';
|
|
16
|
+
const ADDR_EC = 'XyFVXiGaHxoBhXZkSh6NS2rjFyVaVNUo5UiZDqZbuSfUdji';
|
|
17
|
+
const ADDR_ET = '0x54Dab85EE2c7b9F7421100d7134eFb5DfA4239bF';
|
|
18
|
+
const MESSAGE = 'hello world';
|
|
19
|
+
const SIG_ED = '0x299d3bf4c8bb51af732f8067b3a3015c0862a5ff34721749d8ed6577ea2708365d1c5f76bd519009971e41156f12c70abc2533837ceb3bad9a05a99ab923de06';
|
|
20
|
+
const SIG_SR = '0xca01419b5a17219f7b78335658cab3b126db523a5df7be4bfc2bef76c2eb3b1dcf4ca86eb877d0a6cf6df12db5995c51d13b00e005d053b892bd09c594434288';
|
|
21
|
+
const SIG_SR_WRAP = '0x84b6afb1c8e54bbcb3f4872baf172580e21310e9387a53742627d6652d121447fa406b82805ed3184fb7bd519175cc9f99f283f97954d95cf966ee164df85489';
|
|
22
|
+
const SIG_EC = '0x994638ee586d2c5dbd9bacacbc35d9b7e9018de8f7892f00c900db63bc57b1283e2ee7bc51a9b1c1dae121ac4f4b9e2a41cd1d6bf4bb3e24d7fed6faf6d85e0501';
|
|
23
|
+
const SIG_ET = '0x4e35aad35793b71f08566615661c9b741d7c605bc8935ac08608dff685324d71b5704fbd14c9297d2f584ea0735f015dcf0def66b802b3f555e1db916eda4b7700';
|
|
24
|
+
const MUL_ED = u8aToHex(u8aConcat(new Uint8Array([0]), hexToU8a(SIG_ED)));
|
|
25
|
+
const MUL_SR = u8aToHex(u8aConcat(new Uint8Array([1]), hexToU8a(SIG_SR)));
|
|
26
|
+
const MUL_EC = u8aToHex(u8aConcat(new Uint8Array([2]), hexToU8a(SIG_EC)));
|
|
27
|
+
const MUL_ET = u8aToHex(u8aConcat(new Uint8Array([2]), hexToU8a(SIG_ET)));
|
|
28
|
+
|
|
29
|
+
describe('signatureVerify', (): void => {
|
|
30
|
+
beforeEach(async (): Promise<void> => {
|
|
31
|
+
await waitReady();
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
it('throws on invalid signature length', (): void => {
|
|
35
|
+
expect(
|
|
36
|
+
() => signatureVerify(MESSAGE, new Uint8Array(32), ADDR_ED)
|
|
37
|
+
).toThrow('Invalid signature length, expected [64..66] bytes, found 32');
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
describe('verifyDetect', (): void => {
|
|
41
|
+
it('verifies ed25519 signature', (): void => {
|
|
42
|
+
expect(signatureVerify(MESSAGE, SIG_ED, ADDR_ED)).toEqual({
|
|
43
|
+
crypto: 'ed25519',
|
|
44
|
+
isValid: true,
|
|
45
|
+
isWrapped: false,
|
|
46
|
+
publicKey: decodeAddress(ADDR_ED)
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
it('verifies ecdsa signatures', (): void => {
|
|
51
|
+
expect(signatureVerify(MESSAGE, SIG_EC, ADDR_EC)).toEqual({
|
|
52
|
+
crypto: 'ecdsa',
|
|
53
|
+
isValid: true,
|
|
54
|
+
isWrapped: false,
|
|
55
|
+
publicKey: decodeAddress(ADDR_EC)
|
|
56
|
+
});
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
it('verifies an ethereum signature', (): void => {
|
|
60
|
+
expect(signatureVerify(MESSAGE, SIG_ET, ADDR_ET)).toEqual({
|
|
61
|
+
crypto: 'ethereum',
|
|
62
|
+
isValid: true,
|
|
63
|
+
isWrapped: false,
|
|
64
|
+
publicKey: hexToU8a(ADDR_ET)
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
it('verifies an ethereum signature (known)', (): void => {
|
|
69
|
+
const message = 'Pay KSMs to the Kusama account:88dc3417d5058ec4b4503e0c12ea1a0a89be200fe98922423d4334014fa6b0ee';
|
|
70
|
+
|
|
71
|
+
expect(signatureVerify(
|
|
72
|
+
`\x19Ethereum Signed Message:\n${message.length.toString()}${message}`,
|
|
73
|
+
'0x55bd020bdbbdc02de34e915effc9b18a99002f4c29f64e22e8dcbb69e722ea6c28e1bb53b9484063fbbfd205e49dcc1f620929f520c9c4c3695150f05a28f52a01',
|
|
74
|
+
'0x002309df96687e44280bb72c3818358faeeb699c'
|
|
75
|
+
)).toEqual({
|
|
76
|
+
crypto: 'ethereum',
|
|
77
|
+
isValid: true,
|
|
78
|
+
isWrapped: true,
|
|
79
|
+
publicKey: hexToU8a('0x002309df96687e44280bb72c3818358faeeb699c')
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
it('fails on invalid ethereum signature', (): void => {
|
|
84
|
+
expect(signatureVerify(MESSAGE, SIG_EC, ADDR_ET)).toEqual({
|
|
85
|
+
crypto: 'none',
|
|
86
|
+
isValid: false,
|
|
87
|
+
isWrapped: false,
|
|
88
|
+
publicKey: hexToU8a(ADDR_ET)
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
it('verifies an sr25519 signature', (): void => {
|
|
93
|
+
expect(signatureVerify(MESSAGE, SIG_SR, ADDR_SR)).toEqual({
|
|
94
|
+
crypto: 'sr25519',
|
|
95
|
+
isValid: true,
|
|
96
|
+
isWrapped: false,
|
|
97
|
+
publicKey: decodeAddress(ADDR_SR)
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
it('verifies an sr25519 signature (with msg wrapper, without wrapped sig)', (): void => {
|
|
102
|
+
expect(signatureVerify(u8aWrapBytes(MESSAGE), SIG_SR_WRAP, ADDR_SR_WRAP)).toEqual({
|
|
103
|
+
crypto: 'sr25519',
|
|
104
|
+
isValid: true,
|
|
105
|
+
isWrapped: true,
|
|
106
|
+
publicKey: decodeAddress(ADDR_SR_WRAP)
|
|
107
|
+
});
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
it('verifies an sr25519 signature (without msg wrapper, with wrapped sig)', (): void => {
|
|
111
|
+
expect(signatureVerify(MESSAGE, SIG_SR_WRAP, ADDR_SR_WRAP)).toEqual({
|
|
112
|
+
crypto: 'sr25519',
|
|
113
|
+
isValid: true,
|
|
114
|
+
isWrapped: false,
|
|
115
|
+
publicKey: decodeAddress(ADDR_SR_WRAP)
|
|
116
|
+
});
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
it('allows various inputs', (): void => {
|
|
120
|
+
expect(signatureVerify(stringToU8a(MESSAGE), hexToU8a(SIG_ED), decodeAddress(ADDR_ED))).toEqual({
|
|
121
|
+
crypto: 'ed25519',
|
|
122
|
+
isValid: true,
|
|
123
|
+
isWrapped: false,
|
|
124
|
+
publicKey: decodeAddress(ADDR_ED)
|
|
125
|
+
});
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
it('fails on an invalid signature', (): void => {
|
|
129
|
+
expect(signatureVerify(MESSAGE, SIG_SR, ADDR_ED)).toEqual({
|
|
130
|
+
crypto: 'none',
|
|
131
|
+
isValid: false,
|
|
132
|
+
isWrapped: false,
|
|
133
|
+
publicKey: decodeAddress(ADDR_ED)
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
|
|
138
|
+
describe('verifyMultisig', (): void => {
|
|
139
|
+
it('verifies an ed25519 signature', (): void => {
|
|
140
|
+
expect(signatureVerify(MESSAGE, MUL_ED, ADDR_ED)).toEqual({
|
|
141
|
+
crypto: 'ed25519',
|
|
142
|
+
isValid: true,
|
|
143
|
+
isWrapped: false,
|
|
144
|
+
publicKey: decodeAddress(ADDR_ED)
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
it('verifies an ecdsa signature', (): void => {
|
|
149
|
+
expect(signatureVerify(MESSAGE, MUL_EC, ADDR_EC)).toEqual({
|
|
150
|
+
crypto: 'ecdsa',
|
|
151
|
+
isValid: true,
|
|
152
|
+
isWrapped: false,
|
|
153
|
+
publicKey: decodeAddress(ADDR_EC)
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
|
|
157
|
+
it('verifies an ethereum signature', (): void => {
|
|
158
|
+
expect(signatureVerify(MESSAGE, MUL_ET, ADDR_ET)).toEqual({
|
|
159
|
+
crypto: 'ethereum',
|
|
160
|
+
isValid: true,
|
|
161
|
+
isWrapped: false,
|
|
162
|
+
publicKey: hexToU8a(ADDR_ET)
|
|
163
|
+
});
|
|
164
|
+
});
|
|
165
|
+
|
|
166
|
+
it('verifies an sr25519 signature', (): void => {
|
|
167
|
+
expect(signatureVerify(MESSAGE, MUL_SR, ADDR_SR)).toEqual({
|
|
168
|
+
crypto: 'sr25519',
|
|
169
|
+
isValid: true,
|
|
170
|
+
isWrapped: false,
|
|
171
|
+
publicKey: decodeAddress(ADDR_SR)
|
|
172
|
+
});
|
|
173
|
+
});
|
|
174
|
+
|
|
175
|
+
it('fails on an invalid signature', (): void => {
|
|
176
|
+
expect(signatureVerify(MESSAGE, MUL_SR, ADDR_ED)).toEqual({
|
|
177
|
+
crypto: 'none',
|
|
178
|
+
isValid: false,
|
|
179
|
+
isWrapped: false,
|
|
180
|
+
publicKey: new Uint8Array([61, 12, 55, 211, 0, 211, 97, 199, 4, 37, 17, 213, 81, 175, 166, 23, 251, 199, 144, 210, 19, 83, 186, 1, 196, 231, 14, 156, 171, 46, 141, 146])
|
|
181
|
+
});
|
|
182
|
+
});
|
|
183
|
+
/**
|
|
184
|
+
* ref: https://github.com/polkadot-js/common/issues/1898
|
|
185
|
+
*
|
|
186
|
+
* The following test ensures that we cover a reproduction that showed
|
|
187
|
+
* an inherent issue with verifying ecdsa signatures which is fixed in
|
|
188
|
+
* https://github.com/polkadot-js/common/pull/1973.
|
|
189
|
+
*
|
|
190
|
+
* It uses a random secretKey, and publicKey pair along with `secp256k1Sign`
|
|
191
|
+
* as the signer which is used for `ecdsa`.
|
|
192
|
+
*/
|
|
193
|
+
it('Ensure ecdsa can sign and verify 1000 messages', (): void => {
|
|
194
|
+
const verifyThousandMessages = () => {
|
|
195
|
+
const secretKey = new Uint8Array([
|
|
196
|
+
103, 97, 114, 98, 97, 103, 101, 32, 114, 105, 100,
|
|
197
|
+
103, 101, 32, 107, 105, 99, 107, 32, 114, 111, 115,
|
|
198
|
+
101, 32, 101, 110, 100, 32, 115, 113, 117, 101
|
|
199
|
+
]);
|
|
200
|
+
const publicKey = new Uint8Array([
|
|
201
|
+
2, 179, 102, 92, 246, 50, 172, 88,
|
|
202
|
+
81, 116, 8, 211, 192, 131, 154, 184,
|
|
203
|
+
122, 83, 180, 104, 4, 227, 214, 195,
|
|
204
|
+
140, 11, 82, 229, 49, 211, 185, 176,
|
|
205
|
+
63
|
|
206
|
+
]);
|
|
207
|
+
|
|
208
|
+
for (let i = 0; i < 1000; i++) {
|
|
209
|
+
const message = `message ${i}`;
|
|
210
|
+
const encodedMessage = stringToU8a(message);
|
|
211
|
+
const signature = secp256k1Sign(encodedMessage, { secretKey });
|
|
212
|
+
|
|
213
|
+
const { isValid: valid } = signatureVerify(
|
|
214
|
+
message,
|
|
215
|
+
signature,
|
|
216
|
+
publicKey
|
|
217
|
+
);
|
|
218
|
+
|
|
219
|
+
if (!valid) {
|
|
220
|
+
return false;
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
return true;
|
|
225
|
+
};
|
|
226
|
+
|
|
227
|
+
expect(verifyThousandMessages()).toEqual(true);
|
|
228
|
+
});
|
|
229
|
+
});
|
|
230
|
+
});
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { KeypairType, VerifyResult } from '../types.js';
|
|
5
|
+
|
|
6
|
+
import { u8aIsWrapped, u8aToU8a, u8aUnwrapBytes, u8aWrapBytes } from '@pezkuwi/util';
|
|
7
|
+
|
|
8
|
+
import { decodeAddress } from '../address/decode.js';
|
|
9
|
+
import { ed25519Verify } from '../ed25519/verify.js';
|
|
10
|
+
import { secp256k1Verify } from '../secp256k1/verify.js';
|
|
11
|
+
import { sr25519Verify } from '../sr25519/verify.js';
|
|
12
|
+
|
|
13
|
+
interface VerifyInput {
|
|
14
|
+
message: Uint8Array;
|
|
15
|
+
publicKey: Uint8Array;
|
|
16
|
+
signature: Uint8Array;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
type Verifier = [KeypairType, (message: Uint8Array | string, signature: Uint8Array, publicKey: Uint8Array) => boolean];
|
|
20
|
+
|
|
21
|
+
type VerifyFn = (result: VerifyResult, input: VerifyInput) => VerifyResult;
|
|
22
|
+
|
|
23
|
+
const secp256k1VerifyHasher = (hashType: 'blake2' | 'keccak') =>
|
|
24
|
+
(message: Uint8Array | string, signature: Uint8Array, publicKey: Uint8Array) =>
|
|
25
|
+
secp256k1Verify(message, signature, publicKey, hashType, true);
|
|
26
|
+
|
|
27
|
+
const VERIFIERS_ECDSA: Verifier[] = [
|
|
28
|
+
['ecdsa', secp256k1VerifyHasher('blake2')],
|
|
29
|
+
['ethereum', secp256k1VerifyHasher('keccak')]
|
|
30
|
+
];
|
|
31
|
+
|
|
32
|
+
const VERIFIERS: Verifier[] = [
|
|
33
|
+
['ed25519', ed25519Verify],
|
|
34
|
+
['sr25519', sr25519Verify]
|
|
35
|
+
];
|
|
36
|
+
|
|
37
|
+
function verifyDetect (result: VerifyResult, { message, publicKey, signature }: VerifyInput, verifiers = [...VERIFIERS, ...VERIFIERS_ECDSA]): VerifyResult {
|
|
38
|
+
result.isValid = verifiers.some(([crypto, verify]): boolean => {
|
|
39
|
+
try {
|
|
40
|
+
if (verify(message, signature, publicKey)) {
|
|
41
|
+
result.crypto = crypto;
|
|
42
|
+
|
|
43
|
+
return true;
|
|
44
|
+
}
|
|
45
|
+
} catch {
|
|
46
|
+
// do nothing, result.isValid still set to false
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
return false;
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
return result;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
function verifyMultisig (result: VerifyResult, { message, publicKey, signature }: VerifyInput): VerifyResult {
|
|
56
|
+
if (![0, 1, 2].includes(signature[0]) || ![65, 66].includes(signature.length)) {
|
|
57
|
+
throw new Error(`Unknown crypto type, expected signature prefix [0..2], found ${signature[0]}`);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
// If the signature is 66 bytes it must be an ecdsa signature
|
|
61
|
+
// containing: prefix [1 byte] + signature [65] bytes.
|
|
62
|
+
// Remove the and then verify
|
|
63
|
+
if (signature.length === 66) {
|
|
64
|
+
result = verifyDetect(result, { message, publicKey, signature: signature.subarray(1) }, VERIFIERS_ECDSA);
|
|
65
|
+
} else {
|
|
66
|
+
// The signature contains 65 bytes which is either
|
|
67
|
+
// - A ed25519 or sr25519 signature [1 byte prefix + 64 bytes]
|
|
68
|
+
// - An ecdsa signature [65 bytes]
|
|
69
|
+
result = verifyDetect(result, { message, publicKey, signature: signature.subarray(1) }, VERIFIERS);
|
|
70
|
+
|
|
71
|
+
if (!result.isValid) {
|
|
72
|
+
result = verifyDetect(result, { message, publicKey, signature }, VERIFIERS_ECDSA);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
// If both failed, explicitly set crypto to 'none'
|
|
76
|
+
if (!result.isValid) {
|
|
77
|
+
result.crypto = 'none';
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
return result;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
function getVerifyFn (signature: Uint8Array): VerifyFn {
|
|
85
|
+
return [0, 1, 2].includes(signature[0]) && [65, 66].includes(signature.length)
|
|
86
|
+
? verifyMultisig
|
|
87
|
+
: verifyDetect;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
export function signatureVerify (message: string | Uint8Array, signature: string | Uint8Array, addressOrPublicKey: string | Uint8Array): VerifyResult {
|
|
91
|
+
const signatureU8a = u8aToU8a(signature);
|
|
92
|
+
|
|
93
|
+
if (![64, 65, 66].includes(signatureU8a.length)) {
|
|
94
|
+
throw new Error(`Invalid signature length, expected [64..66] bytes, found ${signatureU8a.length}`);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
const publicKey = decodeAddress(addressOrPublicKey);
|
|
98
|
+
const input = { message: u8aToU8a(message), publicKey, signature: signatureU8a };
|
|
99
|
+
const result: VerifyResult = { crypto: 'none', isValid: false, isWrapped: u8aIsWrapped(input.message, true), publicKey };
|
|
100
|
+
const isWrappedBytes = u8aIsWrapped(input.message, false);
|
|
101
|
+
const verifyFn = getVerifyFn(signatureU8a);
|
|
102
|
+
|
|
103
|
+
verifyFn(result, input);
|
|
104
|
+
|
|
105
|
+
if (result.crypto !== 'none' || (result.isWrapped && !isWrappedBytes)) {
|
|
106
|
+
return result;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
input.message = isWrappedBytes
|
|
110
|
+
? u8aUnwrapBytes(input.message)
|
|
111
|
+
: u8aWrapBytes(input.message);
|
|
112
|
+
|
|
113
|
+
return verifyFn(result, input);
|
|
114
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
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 { Keypair } from '../types.js';
|
|
7
|
+
|
|
8
|
+
import { u8aToHex } from '@pezkuwi/util';
|
|
9
|
+
|
|
10
|
+
import { sr25519Agreement, sr25519PairFromSeed } from './index.js';
|
|
11
|
+
|
|
12
|
+
describe('agreement', (): void => {
|
|
13
|
+
let pairA: Keypair;
|
|
14
|
+
let pairB: Keypair;
|
|
15
|
+
|
|
16
|
+
beforeEach((): void => {
|
|
17
|
+
pairA = sr25519PairFromSeed('0x98b3d305d5a5eace562387e47e59badd4d77e3f72cabfb10a60f8a197059f0a8');
|
|
18
|
+
pairB = sr25519PairFromSeed('0x9732eea001851ff862d949a1699c9971f3a26edbede2ad7922cbbe9a0701f366');
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
it('matches a known agreement (both ways)', (): void => {
|
|
22
|
+
const TEST = '0xb03a0b198c34c16f35cae933d88b16341b4cef3e84e851f20e664c6a30527f4e';
|
|
23
|
+
|
|
24
|
+
expect(
|
|
25
|
+
u8aToHex(sr25519Agreement(pairA.secretKey, pairB.publicKey))
|
|
26
|
+
).toEqual(TEST);
|
|
27
|
+
expect(
|
|
28
|
+
u8aToHex(sr25519Agreement(pairB.secretKey, pairA.publicKey))
|
|
29
|
+
).toEqual(TEST);
|
|
30
|
+
});
|
|
31
|
+
});
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import { getSharedSecret } from '@pezkuwi/scure-sr25519';
|
|
5
|
+
|
|
6
|
+
import { u8aToU8a } from '@pezkuwi/util';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* @name sr25519Agreement
|
|
10
|
+
* @description Key agreement between other's public key and self secret key
|
|
11
|
+
*/
|
|
12
|
+
export function sr25519Agreement (secretKey: string | Uint8Array, publicKey: string | Uint8Array): Uint8Array {
|
|
13
|
+
const secretKeyU8a = u8aToU8a(secretKey);
|
|
14
|
+
const publicKeyU8a = u8aToU8a(publicKey);
|
|
15
|
+
|
|
16
|
+
if (publicKeyU8a.length !== 32) {
|
|
17
|
+
throw new Error(`Invalid publicKey, received ${publicKeyU8a.length} bytes, expected 32`);
|
|
18
|
+
} else if (secretKeyU8a.length !== 64) {
|
|
19
|
+
throw new Error(`Invalid secretKey, received ${secretKeyU8a.length} bytes, expected 64`);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
return getSharedSecret(secretKeyU8a, publicKeyU8a);
|
|
23
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
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
|
+
|
|
6
|
+
import * as sr25519 from '@pezkuwi/scure-sr25519';
|
|
7
|
+
|
|
8
|
+
import { isU8a } from '@pezkuwi/util';
|
|
9
|
+
|
|
10
|
+
export function createDeriveFn (derive: (pair: Uint8Array, cc: Uint8Array) => Uint8Array): (keypair: Keypair, chainCode: Uint8Array) => Keypair {
|
|
11
|
+
return (keypair: Keypair, chainCode: Uint8Array): Keypair => {
|
|
12
|
+
if (!isU8a(chainCode) || chainCode.length !== 32) {
|
|
13
|
+
throw new Error('Invalid chainCode passed to derive');
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const secretKey = derive(keypair.secretKey, chainCode);
|
|
17
|
+
const publicKey = sr25519.getPublicKey(secretKey);
|
|
18
|
+
|
|
19
|
+
return { publicKey, secretKey };
|
|
20
|
+
};
|
|
21
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import * as sr25519 from '@pezkuwi/scure-sr25519';
|
|
5
|
+
|
|
6
|
+
import { createDeriveFn } from './derive.js';
|
|
7
|
+
|
|
8
|
+
// eslint-disable-next-line @typescript-eslint/unbound-method
|
|
9
|
+
export const sr25519DeriveHard = /*#__PURE__*/ createDeriveFn(sr25519.HDKD.secretHard);
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import * as sr25519 from '@pezkuwi/scure-sr25519';
|
|
5
|
+
|
|
6
|
+
import { isU8a, u8aToU8a } from '@pezkuwi/util';
|
|
7
|
+
|
|
8
|
+
export function sr25519DerivePublic (publicKey: string | Uint8Array, chainCode: Uint8Array): Uint8Array {
|
|
9
|
+
const publicKeyU8a = u8aToU8a(publicKey);
|
|
10
|
+
|
|
11
|
+
if (!isU8a(chainCode) || chainCode.length !== 32) {
|
|
12
|
+
throw new Error('Invalid chainCode passed to derive');
|
|
13
|
+
} else if (publicKeyU8a.length !== 32) {
|
|
14
|
+
throw new Error(`Invalid publicKey, received ${publicKeyU8a.length} bytes, expected 32`);
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
return sr25519.HDKD.publicSoft(publicKeyU8a, chainCode);
|
|
18
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import * as sr25519 from '@pezkuwi/scure-sr25519';
|
|
5
|
+
|
|
6
|
+
import { createDeriveFn } from './derive.js';
|
|
7
|
+
|
|
8
|
+
// eslint-disable-next-line @typescript-eslint/unbound-method
|
|
9
|
+
export const sr25519DeriveSoft = /*#__PURE__*/ createDeriveFn(sr25519.HDKD.secretSoft);
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
// Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
export { sr25519Agreement } from './agreement.js';
|
|
5
|
+
export { sr25519DeriveHard } from './deriveHard.js';
|
|
6
|
+
export { sr25519DerivePublic } from './derivePublic.js';
|
|
7
|
+
export { sr25519DeriveSoft } from './deriveSoft.js';
|
|
8
|
+
export { sr25519PairFromSeed } from './pair/fromSeed.js';
|
|
9
|
+
export { sr25519Sign } from './sign.js';
|
|
10
|
+
export { sr25519Verify } from './verify.js';
|
|
11
|
+
export { sr25519VrfSign } from './vrfSign.js';
|
|
12
|
+
export { sr25519VrfVerify } from './vrfVerify.js';
|
|
@@ -0,0 +1,35 @@
|
|
|
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 { stringToU8a, u8aToHex } from '@pezkuwi/util';
|
|
7
|
+
|
|
8
|
+
import { mnemonicToMiniSecret } from '../../mnemonic/index.js';
|
|
9
|
+
import { sr25519PairFromSeed } from '../index.js';
|
|
10
|
+
import tests from './testing.spec.js';
|
|
11
|
+
|
|
12
|
+
describe('sr25519PairFromSeed', (): void => {
|
|
13
|
+
const TEST = stringToU8a('12345678901234567890123456789012');
|
|
14
|
+
const RESULT = {
|
|
15
|
+
publicKey: new Uint8Array([116, 28, 8, 160, 111, 65, 197, 150, 96, 143, 103, 116, 37, 155, 217, 4, 51, 4, 173, 250, 93, 62, 234, 98, 118, 11, 217, 190, 151, 99, 77, 99]),
|
|
16
|
+
secretKey: new Uint8Array([240, 16, 102, 96, 195, 221, 162, 63, 22, 218, 169, 172, 91, 129, 27, 150, 48, 119, 245, 188, 10, 248, 159, 133, 128, 79, 13, 232, 228, 36, 240, 80, 249, 141, 102, 243, 148, 66, 80, 111, 249, 71, 253, 145, 31, 24, 199, 167, 165, 218, 99, 154, 99, 232, 211, 180, 226, 51, 247, 65, 67, 217, 81, 193])
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
it('generates a valid publicKey/secretKey pair (u8a)', (): void => {
|
|
20
|
+
expect(
|
|
21
|
+
sr25519PairFromSeed(TEST)
|
|
22
|
+
).toEqual(RESULT);
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
tests.forEach(([mnemonic, , , secret], index): void => {
|
|
26
|
+
it(`creates valid against known (${index})`, (): void => {
|
|
27
|
+
const seed = mnemonicToMiniSecret(mnemonic, 'Substrate');
|
|
28
|
+
const pair = sr25519PairFromSeed(seed);
|
|
29
|
+
|
|
30
|
+
expect(
|
|
31
|
+
u8aToHex(pair.secretKey)
|
|
32
|
+
).toEqual(secret);
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
});
|
|
@@ -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 } from '../../types.js';
|
|
5
|
+
|
|
6
|
+
import * as sr25519 from '@pezkuwi/scure-sr25519';
|
|
7
|
+
|
|
8
|
+
import { u8aToU8a } from '@pezkuwi/util';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* @name sr25519PairFromSeed
|
|
12
|
+
* @description Returns a object containing a `publicKey` & `secretKey` generated from the supplied seed.
|
|
13
|
+
*/
|
|
14
|
+
export function sr25519PairFromSeed (seed: string | Uint8Array): Keypair {
|
|
15
|
+
const seedU8a = u8aToU8a(seed);
|
|
16
|
+
|
|
17
|
+
if (seedU8a.length !== 32) {
|
|
18
|
+
throw new Error(`Expected a seed matching 32 bytes, found ${seedU8a.length}`);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
const sec = sr25519.secretFromSeed(seedU8a);
|
|
22
|
+
const pub = sr25519.getPublicKey(sec);
|
|
23
|
+
|
|
24
|
+
return {
|
|
25
|
+
publicKey: pub,
|
|
26
|
+
secretKey: sec
|
|
27
|
+
};
|
|
28
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
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
|
+
|
|
6
|
+
import { u8aToU8a } from '@pezkuwi/util';
|
|
7
|
+
|
|
8
|
+
const SEC_LEN = 64;
|
|
9
|
+
const PUB_LEN = 32;
|
|
10
|
+
const TOT_LEN = SEC_LEN + PUB_LEN;
|
|
11
|
+
|
|
12
|
+
export function sr25519PairFromU8a (full: string | Uint8Array): Keypair {
|
|
13
|
+
const fullU8a = u8aToU8a(full);
|
|
14
|
+
|
|
15
|
+
if (fullU8a.length !== TOT_LEN) {
|
|
16
|
+
throw new Error(`Expected keypair with ${TOT_LEN} bytes, found ${fullU8a.length}`);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
return {
|
|
20
|
+
publicKey: fullU8a.slice(SEC_LEN, TOT_LEN),
|
|
21
|
+
secretKey: fullU8a.slice(0, SEC_LEN)
|
|
22
|
+
};
|
|
23
|
+
}
|