@pezkuwi/util-crypto 14.0.22 → 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.
Files changed (1391) hide show
  1. package/blake2/asU8a.d.ts +1 -1
  2. package/build/LICENSE +201 -0
  3. package/build/README.md +17 -0
  4. package/build/address/addressToEvm.d.ts +5 -0
  5. package/build/address/addressToEvm.js +8 -0
  6. package/build/address/check.d.ts +8 -0
  7. package/build/address/check.js +26 -0
  8. package/build/address/checksum.d.ts +1 -0
  9. package/build/address/checksum.js +16 -0
  10. package/build/address/decode.d.ts +2 -0
  11. package/build/address/decode.js +29 -0
  12. package/build/address/defaults.d.ts +6 -0
  13. package/build/address/defaults.js +8 -0
  14. package/build/address/derive.d.ts +8 -0
  15. package/build/address/derive.js +24 -0
  16. package/build/address/encode.d.ts +2 -0
  17. package/build/address/encode.js +23 -0
  18. package/build/address/encodeDerived.d.ts +9 -0
  19. package/build/address/encodeDerived.js +12 -0
  20. package/build/address/encodeMulti.d.ts +9 -0
  21. package/build/address/encodeMulti.js +11 -0
  22. package/build/address/eq.d.ts +15 -0
  23. package/build/address/eq.js +19 -0
  24. package/build/address/evmToAddress.d.ts +7 -0
  25. package/build/address/evmToAddress.js +14 -0
  26. package/build/address/index.d.ts +16 -0
  27. package/build/address/index.js +16 -0
  28. package/build/address/is.d.ts +2 -0
  29. package/build/address/is.js +9 -0
  30. package/build/address/keyDerived.d.ts +2 -0
  31. package/build/address/keyDerived.js +8 -0
  32. package/build/address/keyMulti.d.ts +2 -0
  33. package/build/address/keyMulti.js +8 -0
  34. package/build/address/setSS58Format.d.ts +6 -0
  35. package/build/address/setSS58Format.js +11 -0
  36. package/build/address/sort.d.ts +2 -0
  37. package/build/address/sort.js +7 -0
  38. package/build/address/sshash.d.ts +1 -0
  39. package/build/address/sshash.js +6 -0
  40. package/build/address/types.d.ts +1 -0
  41. package/build/address/types.js +1 -0
  42. package/build/address/util.d.ts +1 -0
  43. package/build/address/util.js +4 -0
  44. package/build/address/validate.d.ts +2 -0
  45. package/build/address/validate.js +4 -0
  46. package/build/base32/bs32.d.ts +26 -0
  47. package/build/base32/bs32.js +40 -0
  48. package/build/base32/helpers.d.ts +25 -0
  49. package/build/base32/helpers.js +61 -0
  50. package/build/base32/index.d.ts +4 -0
  51. package/build/base32/index.js +4 -0
  52. package/build/base58/bs58.d.ts +26 -0
  53. package/build/base58/bs58.js +34 -0
  54. package/build/base58/index.d.ts +4 -0
  55. package/build/base58/index.js +4 -0
  56. package/build/base64/bs64.d.ts +26 -0
  57. package/build/base64/bs64.js +34 -0
  58. package/build/base64/index.d.ts +6 -0
  59. package/build/base64/index.js +6 -0
  60. package/build/base64/pad.d.ts +5 -0
  61. package/build/base64/pad.js +7 -0
  62. package/build/base64/trim.d.ts +5 -0
  63. package/build/base64/trim.js +10 -0
  64. package/build/blake2/asU8a.d.ts +20 -0
  65. package/build/blake2/asU8a.js +32 -0
  66. package/build/blake2/index.d.ts +4 -0
  67. package/build/blake2/index.js +4 -0
  68. package/build/bn.d.ts +30 -0
  69. package/build/bn.js +8 -0
  70. package/build/bundle.d.ts +26 -0
  71. package/build/bundle.js +26 -0
  72. package/build/bundleInit.d.ts +1 -0
  73. package/build/bundleInit.js +5 -0
  74. package/build/cjs/address/addressToEvm.d.ts +5 -0
  75. package/build/cjs/address/addressToEvm.js +11 -0
  76. package/build/cjs/address/check.d.ts +8 -0
  77. package/build/cjs/address/check.js +29 -0
  78. package/build/cjs/address/checksum.d.ts +1 -0
  79. package/build/cjs/address/checksum.js +19 -0
  80. package/build/cjs/address/decode.d.ts +2 -0
  81. package/build/cjs/address/decode.js +32 -0
  82. package/build/cjs/address/defaults.d.ts +6 -0
  83. package/build/cjs/address/defaults.js +11 -0
  84. package/build/cjs/address/derive.d.ts +8 -0
  85. package/build/cjs/address/derive.js +27 -0
  86. package/build/cjs/address/encode.d.ts +2 -0
  87. package/build/cjs/address/encode.js +26 -0
  88. package/build/cjs/address/encodeDerived.d.ts +9 -0
  89. package/build/cjs/address/encodeDerived.js +15 -0
  90. package/build/cjs/address/encodeMulti.d.ts +9 -0
  91. package/build/cjs/address/encodeMulti.js +14 -0
  92. package/build/cjs/address/eq.d.ts +15 -0
  93. package/build/cjs/address/eq.js +22 -0
  94. package/build/cjs/address/evmToAddress.d.ts +7 -0
  95. package/build/cjs/address/evmToAddress.js +17 -0
  96. package/build/cjs/address/index.d.ts +16 -0
  97. package/build/cjs/address/index.js +35 -0
  98. package/build/cjs/address/is.d.ts +2 -0
  99. package/build/cjs/address/is.js +12 -0
  100. package/build/cjs/address/keyDerived.d.ts +2 -0
  101. package/build/cjs/address/keyDerived.js +11 -0
  102. package/build/cjs/address/keyMulti.d.ts +2 -0
  103. package/build/cjs/address/keyMulti.js +11 -0
  104. package/build/cjs/address/setSS58Format.d.ts +6 -0
  105. package/build/cjs/address/setSS58Format.js +14 -0
  106. package/build/cjs/address/sort.d.ts +2 -0
  107. package/build/cjs/address/sort.js +10 -0
  108. package/build/cjs/address/sshash.d.ts +1 -0
  109. package/build/cjs/address/sshash.js +9 -0
  110. package/build/cjs/address/types.d.ts +1 -0
  111. package/build/cjs/address/types.js +2 -0
  112. package/build/cjs/address/util.d.ts +1 -0
  113. package/build/cjs/address/util.js +7 -0
  114. package/build/cjs/address/validate.d.ts +2 -0
  115. package/build/cjs/address/validate.js +7 -0
  116. package/build/cjs/base32/bs32.d.ts +26 -0
  117. package/build/cjs/base32/bs32.js +43 -0
  118. package/build/cjs/base32/helpers.d.ts +25 -0
  119. package/build/cjs/base32/helpers.js +67 -0
  120. package/build/cjs/base32/index.d.ts +4 -0
  121. package/build/cjs/base32/index.js +11 -0
  122. package/build/cjs/base58/bs58.d.ts +26 -0
  123. package/build/cjs/base58/bs58.js +37 -0
  124. package/build/cjs/base58/index.d.ts +4 -0
  125. package/build/cjs/base58/index.js +11 -0
  126. package/build/cjs/base64/bs64.d.ts +26 -0
  127. package/build/cjs/base64/bs64.js +37 -0
  128. package/build/cjs/base64/index.d.ts +6 -0
  129. package/build/cjs/base64/index.js +15 -0
  130. package/build/cjs/base64/pad.d.ts +5 -0
  131. package/build/cjs/base64/pad.js +10 -0
  132. package/build/cjs/base64/trim.d.ts +5 -0
  133. package/build/cjs/base64/trim.js +13 -0
  134. package/build/cjs/blake2/asU8a.d.ts +20 -0
  135. package/build/cjs/blake2/asU8a.js +36 -0
  136. package/build/cjs/blake2/index.d.ts +4 -0
  137. package/build/cjs/blake2/index.js +9 -0
  138. package/build/cjs/bn.d.ts +30 -0
  139. package/build/cjs/bn.js +11 -0
  140. package/build/cjs/bundle.d.ts +26 -0
  141. package/build/cjs/bundle.js +31 -0
  142. package/build/cjs/bundleInit.d.ts +1 -0
  143. package/build/cjs/bundleInit.js +7 -0
  144. package/build/cjs/crypto.d.ts +3 -0
  145. package/build/cjs/crypto.js +16 -0
  146. package/build/cjs/ed25519/deriveHard.d.ts +1 -0
  147. package/build/cjs/ed25519/deriveHard.js +12 -0
  148. package/build/cjs/ed25519/index.d.ts +10 -0
  149. package/build/cjs/ed25519/index.js +20 -0
  150. package/build/cjs/ed25519/pair/fromRandom.d.ts +16 -0
  151. package/build/cjs/ed25519/pair/fromRandom.js +22 -0
  152. package/build/cjs/ed25519/pair/fromSecret.d.ts +16 -0
  153. package/build/cjs/ed25519/pair/fromSecret.js +26 -0
  154. package/build/cjs/ed25519/pair/fromSeed.d.ts +16 -0
  155. package/build/cjs/ed25519/pair/fromSeed.js +34 -0
  156. package/build/cjs/ed25519/pair/fromString.d.ts +16 -0
  157. package/build/cjs/ed25519/pair/fromString.js +23 -0
  158. package/build/cjs/ed25519/sign.d.ts +16 -0
  159. package/build/cjs/ed25519/sign.js +33 -0
  160. package/build/cjs/ed25519/verify.d.ts +15 -0
  161. package/build/cjs/ed25519/verify.js +39 -0
  162. package/build/cjs/ethereum/encode.d.ts +2 -0
  163. package/build/cjs/ethereum/encode.js +28 -0
  164. package/build/cjs/ethereum/index.d.ts +3 -0
  165. package/build/cjs/ethereum/index.js +9 -0
  166. package/build/cjs/ethereum/isAddress.d.ts +1 -0
  167. package/build/cjs/ethereum/isAddress.js +14 -0
  168. package/build/cjs/ethereum/isChecksum.d.ts +1 -0
  169. package/build/cjs/ethereum/isChecksum.js +20 -0
  170. package/build/cjs/hd/ethereum/index.d.ts +2 -0
  171. package/build/cjs/hd/ethereum/index.js +47 -0
  172. package/build/cjs/hd/index.d.ts +3 -0
  173. package/build/cjs/hd/index.js +9 -0
  174. package/build/cjs/hd/ledger/derivePrivate.d.ts +1 -0
  175. package/build/cjs/hd/ledger/derivePrivate.js +15 -0
  176. package/build/cjs/hd/ledger/index.d.ts +2 -0
  177. package/build/cjs/hd/ledger/index.js +33 -0
  178. package/build/cjs/hd/ledger/master.d.ts +1 -0
  179. package/build/cjs/hd/ledger/master.js +19 -0
  180. package/build/cjs/hd/validatePath.d.ts +2 -0
  181. package/build/cjs/hd/validatePath.js +20 -0
  182. package/build/cjs/helpers.d.ts +12 -0
  183. package/build/cjs/helpers.js +24 -0
  184. package/build/cjs/hmac/index.d.ts +1 -0
  185. package/build/cjs/hmac/index.js +7 -0
  186. package/build/cjs/hmac/shaAsU8a.d.ts +15 -0
  187. package/build/cjs/hmac/shaAsU8a.js +40 -0
  188. package/build/cjs/index.d.ts +2 -0
  189. package/build/cjs/index.js +5 -0
  190. package/build/cjs/json/constants.d.ts +6 -0
  191. package/build/cjs/json/constants.js +8 -0
  192. package/build/cjs/json/decrypt.d.ts +2 -0
  193. package/build/cjs/json/decrypt.js +16 -0
  194. package/build/cjs/json/decryptData.d.ts +2 -0
  195. package/build/cjs/json/decryptData.js +32 -0
  196. package/build/cjs/json/encrypt.d.ts +2 -0
  197. package/build/cjs/json/encrypt.js +18 -0
  198. package/build/cjs/json/encryptFormat.d.ts +2 -0
  199. package/build/cjs/json/encryptFormat.js +17 -0
  200. package/build/cjs/json/index.d.ts +4 -0
  201. package/build/cjs/json/index.js +11 -0
  202. package/build/cjs/json/types.d.ts +16 -0
  203. package/build/cjs/json/types.js +2 -0
  204. package/build/cjs/keccak/asU8a.d.ts +30 -0
  205. package/build/cjs/keccak/asU8a.js +36 -0
  206. package/build/cjs/keccak/index.d.ts +4 -0
  207. package/build/cjs/keccak/index.js +11 -0
  208. package/build/cjs/key/DeriveJunction.d.ts +12 -0
  209. package/build/cjs/key/DeriveJunction.js +62 -0
  210. package/build/cjs/key/extractPath.d.ts +9 -0
  211. package/build/cjs/key/extractPath.js +26 -0
  212. package/build/cjs/key/extractSuri.d.ts +11 -0
  213. package/build/cjs/key/extractSuri.js +25 -0
  214. package/build/cjs/key/fromPath.d.ts +3 -0
  215. package/build/cjs/key/fromPath.js +21 -0
  216. package/build/cjs/key/hdkdDerive.d.ts +3 -0
  217. package/build/cjs/key/hdkdDerive.js +11 -0
  218. package/build/cjs/key/hdkdEcdsa.d.ts +1 -0
  219. package/build/cjs/key/hdkdEcdsa.js +7 -0
  220. package/build/cjs/key/hdkdEd25519.d.ts +1 -0
  221. package/build/cjs/key/hdkdEd25519.js +6 -0
  222. package/build/cjs/key/hdkdSr25519.d.ts +3 -0
  223. package/build/cjs/key/hdkdSr25519.js +10 -0
  224. package/build/cjs/key/index.d.ts +9 -0
  225. package/build/cjs/key/index.js +18 -0
  226. package/build/cjs/mnemonic/bip39.d.ts +5 -0
  227. package/build/cjs/mnemonic/bip39.js +90 -0
  228. package/build/cjs/mnemonic/generate.d.ts +13 -0
  229. package/build/cjs/mnemonic/generate.js +23 -0
  230. package/build/cjs/mnemonic/index.d.ts +8 -0
  231. package/build/cjs/mnemonic/index.js +16 -0
  232. package/build/cjs/mnemonic/toEntropy.d.ts +1 -0
  233. package/build/cjs/mnemonic/toEntropy.js +11 -0
  234. package/build/cjs/mnemonic/toLegacySeed.d.ts +18 -0
  235. package/build/cjs/mnemonic/toLegacySeed.js +37 -0
  236. package/build/cjs/mnemonic/toMiniSecret.d.ts +1 -0
  237. package/build/cjs/mnemonic/toMiniSecret.js +20 -0
  238. package/build/cjs/mnemonic/validate.d.ts +14 -0
  239. package/build/cjs/mnemonic/validate.js +24 -0
  240. package/build/cjs/mnemonic/wordlists/en.d.ts +2 -0
  241. package/build/cjs/mnemonic/wordlists/en.js +3 -0
  242. package/build/cjs/mnemonic/wordlists/es.d.ts +2 -0
  243. package/build/cjs/mnemonic/wordlists/es.js +3 -0
  244. package/build/cjs/mnemonic/wordlists/fr.d.ts +2 -0
  245. package/build/cjs/mnemonic/wordlists/fr.js +3 -0
  246. package/build/cjs/mnemonic/wordlists/index.d.ts +8 -0
  247. package/build/cjs/mnemonic/wordlists/index.js +20 -0
  248. package/build/cjs/mnemonic/wordlists/it.d.ts +2 -0
  249. package/build/cjs/mnemonic/wordlists/it.js +3 -0
  250. package/build/cjs/mnemonic/wordlists/jp.d.ts +2 -0
  251. package/build/cjs/mnemonic/wordlists/jp.js +3 -0
  252. package/build/cjs/mnemonic/wordlists/ko.d.ts +2 -0
  253. package/build/cjs/mnemonic/wordlists/ko.js +3 -0
  254. package/build/cjs/mnemonic/wordlists/zh-s.d.ts +2 -0
  255. package/build/cjs/mnemonic/wordlists/zh-s.js +3 -0
  256. package/build/cjs/mnemonic/wordlists/zh-t.d.ts +2 -0
  257. package/build/cjs/mnemonic/wordlists/zh-t.js +3 -0
  258. package/build/cjs/nacl/decrypt.d.ts +15 -0
  259. package/build/cjs/nacl/decrypt.js +21 -0
  260. package/build/cjs/nacl/encrypt.d.ts +20 -0
  261. package/build/cjs/nacl/encrypt.js +25 -0
  262. package/build/cjs/nacl/index.d.ts +5 -0
  263. package/build/cjs/nacl/index.js +10 -0
  264. package/build/cjs/nacl/tweetnacl.d.ts +2 -0
  265. package/build/cjs/nacl/tweetnacl.js +238 -0
  266. package/build/cjs/networks.d.ts +1 -0
  267. package/build/cjs/networks.js +7 -0
  268. package/build/cjs/package.json +3 -0
  269. package/build/cjs/packageDetect.d.ts +1 -0
  270. package/build/cjs/packageDetect.js +8 -0
  271. package/build/cjs/packageInfo.d.ts +6 -0
  272. package/build/cjs/packageInfo.js +4 -0
  273. package/build/cjs/pbkdf2/encode.d.ts +7 -0
  274. package/build/cjs/pbkdf2/encode.js +19 -0
  275. package/build/cjs/pbkdf2/index.d.ts +1 -0
  276. package/build/cjs/pbkdf2/index.js +5 -0
  277. package/build/cjs/random/asNumber.d.ts +15 -0
  278. package/build/cjs/random/asNumber.js +23 -0
  279. package/build/cjs/random/asU8a.d.ts +20 -0
  280. package/build/cjs/random/asU8a.js +28 -0
  281. package/build/cjs/random/index.d.ts +5 -0
  282. package/build/cjs/random/index.js +11 -0
  283. package/build/cjs/scrypt/defaults.d.ts +3 -0
  284. package/build/cjs/scrypt/defaults.js +16 -0
  285. package/build/cjs/scrypt/encode.d.ts +8 -0
  286. package/build/cjs/scrypt/encode.js +18 -0
  287. package/build/cjs/scrypt/fromU8a.d.ts +7 -0
  288. package/build/cjs/scrypt/fromU8a.js +27 -0
  289. package/build/cjs/scrypt/index.d.ts +3 -0
  290. package/build/cjs/scrypt/index.js +9 -0
  291. package/build/cjs/scrypt/toU8a.d.ts +2 -0
  292. package/build/cjs/scrypt/toU8a.js +8 -0
  293. package/build/cjs/scrypt/types.d.ts +6 -0
  294. package/build/cjs/scrypt/types.js +2 -0
  295. package/build/cjs/secp256k1/compress.d.ts +1 -0
  296. package/build/cjs/secp256k1/compress.js +17 -0
  297. package/build/cjs/secp256k1/deriveHard.d.ts +1 -0
  298. package/build/cjs/secp256k1/deriveHard.js +13 -0
  299. package/build/cjs/secp256k1/expand.d.ts +1 -0
  300. package/build/cjs/secp256k1/expand.js +20 -0
  301. package/build/cjs/secp256k1/hasher.d.ts +2 -0
  302. package/build/cjs/secp256k1/hasher.js +10 -0
  303. package/build/cjs/secp256k1/index.d.ts +7 -0
  304. package/build/cjs/secp256k1/index.js +17 -0
  305. package/build/cjs/secp256k1/pair/fromSeed.d.ts +6 -0
  306. package/build/cjs/secp256k1/pair/fromSeed.js +34 -0
  307. package/build/cjs/secp256k1/recover.d.ts +6 -0
  308. package/build/cjs/secp256k1/recover.js +29 -0
  309. package/build/cjs/secp256k1/sign.d.ts +7 -0
  310. package/build/cjs/secp256k1/sign.js +23 -0
  311. package/build/cjs/secp256k1/tweakAdd.d.ts +1 -0
  312. package/build/cjs/secp256k1/tweakAdd.js +48 -0
  313. package/build/cjs/secp256k1/types.d.ts +1 -0
  314. package/build/cjs/secp256k1/types.js +2 -0
  315. package/build/cjs/secp256k1/verify.d.ts +6 -0
  316. package/build/cjs/secp256k1/verify.js +23 -0
  317. package/build/cjs/sha/asU8a.d.ts +15 -0
  318. package/build/cjs/sha/asU8a.js +22 -0
  319. package/build/cjs/sha/index.d.ts +4 -0
  320. package/build/cjs/sha/index.js +10 -0
  321. package/build/cjs/signature/index.d.ts +4 -0
  322. package/build/cjs/signature/index.js +8 -0
  323. package/build/cjs/signature/verify.d.ts +2 -0
  324. package/build/cjs/signature/verify.js +81 -0
  325. package/build/cjs/sr25519/agreement.d.ts +5 -0
  326. package/build/cjs/sr25519/agreement.js +20 -0
  327. package/build/cjs/sr25519/derive.d.ts +2 -0
  328. package/build/cjs/sr25519/derive.js +16 -0
  329. package/build/cjs/sr25519/deriveHard.d.ts +1 -0
  330. package/build/cjs/sr25519/deriveHard.js +7 -0
  331. package/build/cjs/sr25519/derivePublic.d.ts +1 -0
  332. package/build/cjs/sr25519/derivePublic.js +16 -0
  333. package/build/cjs/sr25519/deriveSoft.d.ts +1 -0
  334. package/build/cjs/sr25519/deriveSoft.js +7 -0
  335. package/build/cjs/sr25519/index.d.ts +9 -0
  336. package/build/cjs/sr25519/index.js +21 -0
  337. package/build/cjs/sr25519/pair/fromSeed.d.ts +6 -0
  338. package/build/cjs/sr25519/pair/fromSeed.js +22 -0
  339. package/build/cjs/sr25519/pair/fromU8a.d.ts +2 -0
  340. package/build/cjs/sr25519/pair/fromU8a.js +17 -0
  341. package/build/cjs/sr25519/pair/toU8a.d.ts +2 -0
  342. package/build/cjs/sr25519/pair/toU8a.js +7 -0
  343. package/build/cjs/sr25519/sign.d.ts +6 -0
  344. package/build/cjs/sr25519/sign.js +19 -0
  345. package/build/cjs/sr25519/verify.d.ts +5 -0
  346. package/build/cjs/sr25519/verify.js +21 -0
  347. package/build/cjs/sr25519/vrfSign.d.ts +6 -0
  348. package/build/cjs/sr25519/vrfSign.js +19 -0
  349. package/build/cjs/sr25519/vrfVerify.d.ts +5 -0
  350. package/build/cjs/sr25519/vrfVerify.js +22 -0
  351. package/build/cjs/types.d.ts +26 -0
  352. package/build/cjs/types.js +5 -0
  353. package/build/cjs/xxhash/asU8a.d.ts +20 -0
  354. package/build/cjs/xxhash/asU8a.js +39 -0
  355. package/build/cjs/xxhash/index.d.ts +4 -0
  356. package/build/cjs/xxhash/index.js +9 -0
  357. package/build/cjs/xxhash/xxhash64.d.ts +1 -0
  358. package/build/cjs/xxhash/xxhash64.js +103 -0
  359. package/build/crypto.d.ts +3 -0
  360. package/build/crypto.js +12 -0
  361. package/build/ed25519/deriveHard.d.ts +1 -0
  362. package/build/ed25519/deriveHard.js +9 -0
  363. package/build/ed25519/index.d.ts +10 -0
  364. package/build/ed25519/index.js +10 -0
  365. package/build/ed25519/pair/fromRandom.d.ts +16 -0
  366. package/build/ed25519/pair/fromRandom.js +19 -0
  367. package/build/ed25519/pair/fromSecret.d.ts +16 -0
  368. package/build/ed25519/pair/fromSecret.js +23 -0
  369. package/build/ed25519/pair/fromSeed.d.ts +16 -0
  370. package/build/ed25519/pair/fromSeed.js +31 -0
  371. package/build/ed25519/pair/fromString.d.ts +16 -0
  372. package/build/ed25519/pair/fromString.js +20 -0
  373. package/build/ed25519/sign.d.ts +16 -0
  374. package/build/ed25519/sign.js +30 -0
  375. package/build/ed25519/verify.d.ts +15 -0
  376. package/build/ed25519/verify.js +36 -0
  377. package/build/ethereum/encode.d.ts +2 -0
  378. package/build/ethereum/encode.js +25 -0
  379. package/build/ethereum/index.d.ts +3 -0
  380. package/build/ethereum/index.js +3 -0
  381. package/build/ethereum/isAddress.d.ts +1 -0
  382. package/build/ethereum/isAddress.js +11 -0
  383. package/build/ethereum/isChecksum.d.ts +1 -0
  384. package/build/ethereum/isChecksum.js +17 -0
  385. package/build/hd/ethereum/index.d.ts +2 -0
  386. package/build/hd/ethereum/index.js +44 -0
  387. package/build/hd/index.d.ts +3 -0
  388. package/build/hd/index.js +3 -0
  389. package/build/hd/ledger/derivePrivate.d.ts +1 -0
  390. package/build/hd/ledger/derivePrivate.js +12 -0
  391. package/build/hd/ledger/index.d.ts +2 -0
  392. package/build/hd/ledger/index.js +30 -0
  393. package/build/hd/ledger/master.d.ts +1 -0
  394. package/build/hd/ledger/master.js +16 -0
  395. package/build/hd/validatePath.d.ts +2 -0
  396. package/build/hd/validatePath.js +16 -0
  397. package/build/helpers.d.ts +12 -0
  398. package/build/helpers.js +19 -0
  399. package/build/hmac/index.d.ts +1 -0
  400. package/build/hmac/index.js +1 -0
  401. package/build/hmac/shaAsU8a.d.ts +15 -0
  402. package/build/hmac/shaAsU8a.js +36 -0
  403. package/build/index.d.ts +2 -0
  404. package/build/index.js +2 -0
  405. package/build/json/constants.d.ts +6 -0
  406. package/build/json/constants.js +5 -0
  407. package/build/json/decrypt.d.ts +2 -0
  408. package/build/json/decrypt.js +13 -0
  409. package/build/json/decryptData.d.ts +2 -0
  410. package/build/json/decryptData.js +29 -0
  411. package/build/json/encrypt.d.ts +2 -0
  412. package/build/json/encrypt.js +15 -0
  413. package/build/json/encryptFormat.d.ts +2 -0
  414. package/build/json/encryptFormat.js +14 -0
  415. package/build/json/index.d.ts +4 -0
  416. package/build/json/index.js +4 -0
  417. package/build/json/types.d.ts +16 -0
  418. package/build/json/types.js +1 -0
  419. package/build/keccak/asU8a.d.ts +30 -0
  420. package/build/keccak/asU8a.js +33 -0
  421. package/build/keccak/index.d.ts +4 -0
  422. package/build/keccak/index.js +4 -0
  423. package/build/key/DeriveJunction.d.ts +12 -0
  424. package/build/key/DeriveJunction.js +58 -0
  425. package/build/key/extractPath.d.ts +9 -0
  426. package/build/key/extractPath.js +23 -0
  427. package/build/key/extractSuri.d.ts +11 -0
  428. package/build/key/extractSuri.js +22 -0
  429. package/build/key/fromPath.d.ts +3 -0
  430. package/build/key/fromPath.js +18 -0
  431. package/build/key/hdkdDerive.d.ts +3 -0
  432. package/build/key/hdkdDerive.js +8 -0
  433. package/build/key/hdkdEcdsa.d.ts +1 -0
  434. package/build/key/hdkdEcdsa.js +4 -0
  435. package/build/key/hdkdEd25519.d.ts +1 -0
  436. package/build/key/hdkdEd25519.js +3 -0
  437. package/build/key/hdkdSr25519.d.ts +3 -0
  438. package/build/key/hdkdSr25519.js +7 -0
  439. package/build/key/index.d.ts +9 -0
  440. package/build/key/index.js +9 -0
  441. package/build/mnemonic/bip39.d.ts +5 -0
  442. package/build/mnemonic/bip39.js +82 -0
  443. package/build/mnemonic/generate.d.ts +13 -0
  444. package/build/mnemonic/generate.js +20 -0
  445. package/build/mnemonic/index.d.ts +8 -0
  446. package/build/mnemonic/index.js +8 -0
  447. package/build/mnemonic/toEntropy.d.ts +1 -0
  448. package/build/mnemonic/toEntropy.js +8 -0
  449. package/build/mnemonic/toLegacySeed.d.ts +18 -0
  450. package/build/mnemonic/toLegacySeed.js +34 -0
  451. package/build/mnemonic/toMiniSecret.d.ts +1 -0
  452. package/build/mnemonic/toMiniSecret.js +17 -0
  453. package/build/mnemonic/validate.d.ts +14 -0
  454. package/build/mnemonic/validate.js +21 -0
  455. package/build/mnemonic/wordlists/en.d.ts +2 -0
  456. package/build/mnemonic/wordlists/en.js +1 -0
  457. package/build/mnemonic/wordlists/es.d.ts +2 -0
  458. package/build/mnemonic/wordlists/es.js +1 -0
  459. package/build/mnemonic/wordlists/fr.d.ts +2 -0
  460. package/build/mnemonic/wordlists/fr.js +1 -0
  461. package/build/mnemonic/wordlists/index.d.ts +8 -0
  462. package/build/mnemonic/wordlists/index.js +8 -0
  463. package/build/mnemonic/wordlists/it.d.ts +2 -0
  464. package/build/mnemonic/wordlists/it.js +1 -0
  465. package/build/mnemonic/wordlists/jp.d.ts +2 -0
  466. package/build/mnemonic/wordlists/jp.js +1 -0
  467. package/build/mnemonic/wordlists/ko.d.ts +2 -0
  468. package/build/mnemonic/wordlists/ko.js +1 -0
  469. package/build/mnemonic/wordlists/zh-s.d.ts +2 -0
  470. package/build/mnemonic/wordlists/zh-s.js +1 -0
  471. package/build/mnemonic/wordlists/zh-t.d.ts +2 -0
  472. package/build/mnemonic/wordlists/zh-t.js +1 -0
  473. package/build/nacl/decrypt.d.ts +15 -0
  474. package/build/nacl/decrypt.js +18 -0
  475. package/build/nacl/encrypt.d.ts +20 -0
  476. package/build/nacl/encrypt.js +22 -0
  477. package/build/nacl/index.d.ts +5 -0
  478. package/build/nacl/index.js +5 -0
  479. package/build/nacl/tweetnacl.d.ts +2 -0
  480. package/build/nacl/tweetnacl.js +234 -0
  481. package/build/networks.d.ts +1 -0
  482. package/build/networks.js +1 -0
  483. package/build/package.json +2057 -0
  484. package/build/packageDetect.d.ts +1 -0
  485. package/build/packageDetect.js +6 -0
  486. package/build/packageInfo.d.ts +6 -0
  487. package/build/packageInfo.js +1 -0
  488. package/build/pbkdf2/encode.d.ts +7 -0
  489. package/build/pbkdf2/encode.js +16 -0
  490. package/build/pbkdf2/index.d.ts +1 -0
  491. package/build/pbkdf2/index.js +1 -0
  492. package/build/random/asNumber.d.ts +15 -0
  493. package/build/random/asNumber.js +20 -0
  494. package/build/random/asU8a.d.ts +20 -0
  495. package/build/random/asU8a.js +24 -0
  496. package/build/random/index.d.ts +5 -0
  497. package/build/random/index.js +5 -0
  498. package/build/scrypt/defaults.d.ts +3 -0
  499. package/build/scrypt/defaults.js +13 -0
  500. package/build/scrypt/encode.d.ts +8 -0
  501. package/build/scrypt/encode.js +15 -0
  502. package/build/scrypt/fromU8a.d.ts +7 -0
  503. package/build/scrypt/fromU8a.js +24 -0
  504. package/build/scrypt/index.d.ts +3 -0
  505. package/build/scrypt/index.js +3 -0
  506. package/build/scrypt/toU8a.d.ts +2 -0
  507. package/build/scrypt/toU8a.js +5 -0
  508. package/build/scrypt/types.d.ts +6 -0
  509. package/build/scrypt/types.js +1 -0
  510. package/build/secp256k1/compress.d.ts +1 -0
  511. package/build/secp256k1/compress.js +14 -0
  512. package/build/secp256k1/deriveHard.d.ts +1 -0
  513. package/build/secp256k1/deriveHard.js +10 -0
  514. package/build/secp256k1/expand.d.ts +1 -0
  515. package/build/secp256k1/expand.js +17 -0
  516. package/build/secp256k1/hasher.d.ts +2 -0
  517. package/build/secp256k1/hasher.js +7 -0
  518. package/build/secp256k1/index.d.ts +7 -0
  519. package/build/secp256k1/index.js +7 -0
  520. package/build/secp256k1/pair/fromSeed.d.ts +6 -0
  521. package/build/secp256k1/pair/fromSeed.js +31 -0
  522. package/build/secp256k1/recover.d.ts +6 -0
  523. package/build/secp256k1/recover.js +26 -0
  524. package/build/secp256k1/sign.d.ts +7 -0
  525. package/build/secp256k1/sign.js +20 -0
  526. package/build/secp256k1/tweakAdd.d.ts +1 -0
  527. package/build/secp256k1/tweakAdd.js +45 -0
  528. package/build/secp256k1/types.d.ts +1 -0
  529. package/build/secp256k1/types.js +1 -0
  530. package/build/secp256k1/verify.d.ts +6 -0
  531. package/build/secp256k1/verify.js +20 -0
  532. package/build/sha/asU8a.d.ts +15 -0
  533. package/build/sha/asU8a.js +19 -0
  534. package/build/sha/index.d.ts +4 -0
  535. package/build/sha/index.js +4 -0
  536. package/build/signature/index.d.ts +4 -0
  537. package/build/signature/index.js +4 -0
  538. package/build/signature/verify.d.ts +2 -0
  539. package/build/signature/verify.js +78 -0
  540. package/build/sr25519/agreement.d.ts +5 -0
  541. package/build/sr25519/agreement.js +17 -0
  542. package/build/sr25519/derive.d.ts +2 -0
  543. package/build/sr25519/derive.js +12 -0
  544. package/build/sr25519/deriveHard.d.ts +1 -0
  545. package/build/sr25519/deriveHard.js +3 -0
  546. package/build/sr25519/derivePublic.d.ts +1 -0
  547. package/build/sr25519/derivePublic.js +12 -0
  548. package/build/sr25519/deriveSoft.d.ts +1 -0
  549. package/build/sr25519/deriveSoft.js +3 -0
  550. package/build/sr25519/index.d.ts +9 -0
  551. package/build/sr25519/index.js +9 -0
  552. package/build/sr25519/pair/fromSeed.d.ts +6 -0
  553. package/build/sr25519/pair/fromSeed.js +18 -0
  554. package/build/sr25519/pair/fromU8a.d.ts +2 -0
  555. package/build/sr25519/pair/fromU8a.js +14 -0
  556. package/build/sr25519/pair/toU8a.d.ts +2 -0
  557. package/build/sr25519/pair/toU8a.js +4 -0
  558. package/build/sr25519/sign.d.ts +6 -0
  559. package/build/sr25519/sign.js +15 -0
  560. package/build/sr25519/verify.d.ts +5 -0
  561. package/build/sr25519/verify.js +17 -0
  562. package/build/sr25519/vrfSign.d.ts +6 -0
  563. package/build/sr25519/vrfSign.js +15 -0
  564. package/build/sr25519/vrfVerify.d.ts +5 -0
  565. package/build/sr25519/vrfVerify.js +18 -0
  566. package/build/types.d.ts +26 -0
  567. package/build/types.js +2 -0
  568. package/build/xxhash/asU8a.d.ts +20 -0
  569. package/build/xxhash/asU8a.js +35 -0
  570. package/build/xxhash/index.d.ts +4 -0
  571. package/build/xxhash/index.js +4 -0
  572. package/build/xxhash/xxhash64.d.ts +1 -0
  573. package/build/xxhash/xxhash64.js +100 -0
  574. package/build-deno/README.md +17 -0
  575. package/build-deno/address/addressToEvm.ts +10 -0
  576. package/build-deno/address/check.ts +32 -0
  577. package/build-deno/address/checksum.ts +23 -0
  578. package/build-deno/address/decode.ts +38 -0
  579. package/build-deno/address/defaults.ts +10 -0
  580. package/build-deno/address/derive.ts +34 -0
  581. package/build-deno/address/encode.ts +39 -0
  582. package/build-deno/address/encodeDerived.ts +17 -0
  583. package/build-deno/address/encodeMulti.ts +16 -0
  584. package/build-deno/address/eq.ts +22 -0
  585. package/build-deno/address/evmToAddress.ts +22 -0
  586. package/build-deno/address/index.ts +18 -0
  587. package/build-deno/address/is.ts +12 -0
  588. package/build-deno/address/keyDerived.ts +20 -0
  589. package/build-deno/address/keyMulti.ts +21 -0
  590. package/build-deno/address/setSS58Format.ts +18 -0
  591. package/build-deno/address/sort.ts +15 -0
  592. package/build-deno/address/sshash.ts +10 -0
  593. package/build-deno/address/types.ts +2 -0
  594. package/build-deno/address/util.ts +6 -0
  595. package/build-deno/address/validate.ts +8 -0
  596. package/build-deno/base32/bs32.ts +51 -0
  597. package/build-deno/base32/helpers.ts +90 -0
  598. package/build-deno/base32/index.ts +6 -0
  599. package/build-deno/base58/bs58.ts +41 -0
  600. package/build-deno/base58/index.ts +6 -0
  601. package/build-deno/base64/bs64.ts +41 -0
  602. package/build-deno/base64/index.ts +8 -0
  603. package/build-deno/base64/pad.ts +8 -0
  604. package/build-deno/base64/trim.ts +12 -0
  605. package/build-deno/blake2/asU8a.ts +38 -0
  606. package/build-deno/blake2/index.ts +6 -0
  607. package/build-deno/bn.ts +13 -0
  608. package/build-deno/bundle.ts +29 -0
  609. package/build-deno/bundleInit.ts +8 -0
  610. package/build-deno/crypto.ts +16 -0
  611. package/build-deno/ed25519/deriveHard.ts +16 -0
  612. package/build-deno/ed25519/index.ts +11 -0
  613. package/build-deno/ed25519/pair/fromRandom.ts +23 -0
  614. package/build-deno/ed25519/pair/fromSecret.ts +27 -0
  615. package/build-deno/ed25519/pair/fromSeed.ts +39 -0
  616. package/build-deno/ed25519/pair/fromString.ts +29 -0
  617. package/build-deno/ed25519/sign.ts +36 -0
  618. package/build-deno/ed25519/verify.ts +39 -0
  619. package/build-deno/ethereum/encode.ts +37 -0
  620. package/build-deno/ethereum/index.ts +4 -0
  621. package/build-deno/ethereum/isAddress.ts +14 -0
  622. package/build-deno/ethereum/isChecksum.ts +25 -0
  623. package/build-deno/hd/ethereum/index.ts +69 -0
  624. package/build-deno/hd/index.ts +4 -0
  625. package/build-deno/hd/ledger/derivePrivate.ts +31 -0
  626. package/build-deno/hd/ledger/index.ts +40 -0
  627. package/build-deno/hd/ledger/master.ts +23 -0
  628. package/build-deno/hd/validatePath.ts +22 -0
  629. package/build-deno/helpers.ts +35 -0
  630. package/build-deno/hmac/index.ts +2 -0
  631. package/build-deno/hmac/shaAsU8a.ts +46 -0
  632. package/build-deno/index.ts +4 -0
  633. package/build-deno/json/constants.ts +9 -0
  634. package/build-deno/json/decrypt.ts +23 -0
  635. package/build-deno/json/decryptData.ts +43 -0
  636. package/build-deno/json/encrypt.ts +23 -0
  637. package/build-deno/json/encryptFormat.ts +18 -0
  638. package/build-deno/json/index.ts +5 -0
  639. package/build-deno/json/types.ts +20 -0
  640. package/build-deno/keccak/asU8a.ts +45 -0
  641. package/build-deno/keccak/index.ts +6 -0
  642. package/build-deno/key/DeriveJunction.ts +77 -0
  643. package/build-deno/key/extractPath.ts +35 -0
  644. package/build-deno/key/extractSuri.ts +38 -0
  645. package/build-deno/key/fromPath.ts +26 -0
  646. package/build-deno/key/hdkdDerive.ts +15 -0
  647. package/build-deno/key/hdkdEcdsa.ts +6 -0
  648. package/build-deno/key/hdkdEd25519.ts +5 -0
  649. package/build-deno/key/hdkdSr25519.ts +12 -0
  650. package/build-deno/key/index.ts +10 -0
  651. package/build-deno/mnemonic/bip39.ts +115 -0
  652. package/build-deno/mnemonic/generate.ts +23 -0
  653. package/build-deno/mnemonic/index.ts +9 -0
  654. package/build-deno/mnemonic/toEntropy.ts +11 -0
  655. package/build-deno/mnemonic/toLegacySeed.ts +37 -0
  656. package/build-deno/mnemonic/toMiniSecret.ts +21 -0
  657. package/build-deno/mnemonic/validate.ts +24 -0
  658. package/build-deno/mnemonic/wordlists/en.ts +3 -0
  659. package/build-deno/mnemonic/wordlists/es.ts +3 -0
  660. package/build-deno/mnemonic/wordlists/fr.ts +3 -0
  661. package/build-deno/mnemonic/wordlists/index.ts +9 -0
  662. package/build-deno/mnemonic/wordlists/it.ts +3 -0
  663. package/build-deno/mnemonic/wordlists/jp.ts +3 -0
  664. package/build-deno/mnemonic/wordlists/ko.ts +3 -0
  665. package/build-deno/mnemonic/wordlists/zh-s.ts +3 -0
  666. package/build-deno/mnemonic/wordlists/zh-t.ts +3 -0
  667. package/build-deno/mod.ts +2 -0
  668. package/build-deno/nacl/decrypt.ts +20 -0
  669. package/build-deno/nacl/encrypt.ts +29 -0
  670. package/build-deno/nacl/index.ts +6 -0
  671. package/build-deno/nacl/tweetnacl.ts +344 -0
  672. package/build-deno/networks.ts +2 -0
  673. package/build-deno/packageDetect.ts +10 -0
  674. package/build-deno/packageInfo.ts +3 -0
  675. package/build-deno/pbkdf2/encode.ts +27 -0
  676. package/build-deno/pbkdf2/index.ts +2 -0
  677. package/build-deno/random/asNumber.ts +26 -0
  678. package/build-deno/random/asU8a.ts +28 -0
  679. package/build-deno/random/index.ts +7 -0
  680. package/build-deno/scrypt/defaults.ts +17 -0
  681. package/build-deno/scrypt/encode.ts +28 -0
  682. package/build-deno/scrypt/fromU8a.ts +42 -0
  683. package/build-deno/scrypt/index.ts +4 -0
  684. package/build-deno/scrypt/toU8a.ts +15 -0
  685. package/build-deno/scrypt/types.ts +7 -0
  686. package/build-deno/secp256k1/compress.ts +19 -0
  687. package/build-deno/secp256k1/deriveHard.ts +15 -0
  688. package/build-deno/secp256k1/expand.ts +28 -0
  689. package/build-deno/secp256k1/hasher.ts +11 -0
  690. package/build-deno/secp256k1/index.ts +8 -0
  691. package/build-deno/secp256k1/pair/fromSeed.ts +40 -0
  692. package/build-deno/secp256k1/recover.ts +34 -0
  693. package/build-deno/secp256k1/sign.ts +35 -0
  694. package/build-deno/secp256k1/tweakAdd.ts +61 -0
  695. package/build-deno/secp256k1/types.ts +2 -0
  696. package/build-deno/secp256k1/verify.ts +30 -0
  697. package/build-deno/sha/asU8a.ts +28 -0
  698. package/build-deno/sha/index.ts +6 -0
  699. package/build-deno/signature/index.ts +6 -0
  700. package/build-deno/signature/verify.ts +112 -0
  701. package/build-deno/sr25519/agreement.ts +21 -0
  702. package/build-deno/sr25519/derive.ts +19 -0
  703. package/build-deno/sr25519/deriveHard.ts +6 -0
  704. package/build-deno/sr25519/derivePublic.ts +16 -0
  705. package/build-deno/sr25519/deriveSoft.ts +6 -0
  706. package/build-deno/sr25519/index.ts +10 -0
  707. package/build-deno/sr25519/pair/fromSeed.ts +26 -0
  708. package/build-deno/sr25519/pair/fromU8a.ts +21 -0
  709. package/build-deno/sr25519/pair/toU8a.ts +8 -0
  710. package/build-deno/sr25519/sign.ts +20 -0
  711. package/build-deno/sr25519/verify.ts +21 -0
  712. package/build-deno/sr25519/vrfSign.ts +22 -0
  713. package/build-deno/sr25519/vrfVerify.ts +23 -0
  714. package/build-deno/test/index.ts +4 -0
  715. package/build-deno/test/performance.ts +15 -0
  716. package/build-deno/types.ts +31 -0
  717. package/build-deno/xxhash/asU8a.ts +45 -0
  718. package/build-deno/xxhash/index.ts +6 -0
  719. package/build-deno/xxhash/xxhash64.ts +138 -0
  720. package/build-tsc/address/addressToEvm.d.ts +5 -0
  721. package/build-tsc/address/check.d.ts +8 -0
  722. package/build-tsc/address/checksum.d.ts +1 -0
  723. package/build-tsc/address/decode.d.ts +2 -0
  724. package/build-tsc/address/defaults.d.ts +6 -0
  725. package/build-tsc/address/derive.d.ts +8 -0
  726. package/build-tsc/address/encode.d.ts +2 -0
  727. package/build-tsc/address/encodeDerived.d.ts +9 -0
  728. package/build-tsc/address/encodeMulti.d.ts +9 -0
  729. package/build-tsc/address/eq.d.ts +15 -0
  730. package/build-tsc/address/evmToAddress.d.ts +7 -0
  731. package/build-tsc/address/index.d.ts +16 -0
  732. package/build-tsc/address/is.d.ts +2 -0
  733. package/build-tsc/address/keyDerived.d.ts +2 -0
  734. package/build-tsc/address/keyMulti.d.ts +2 -0
  735. package/build-tsc/address/setSS58Format.d.ts +6 -0
  736. package/build-tsc/address/sort.d.ts +2 -0
  737. package/build-tsc/address/sshash.d.ts +1 -0
  738. package/build-tsc/address/types.d.ts +1 -0
  739. package/build-tsc/address/util.d.ts +1 -0
  740. package/build-tsc/address/validate.d.ts +2 -0
  741. package/build-tsc/base32/bs32.d.ts +26 -0
  742. package/build-tsc/base32/helpers.d.ts +25 -0
  743. package/build-tsc/base32/index.d.ts +4 -0
  744. package/build-tsc/base58/bs58.d.ts +26 -0
  745. package/build-tsc/base58/index.d.ts +4 -0
  746. package/build-tsc/base64/bs64.d.ts +26 -0
  747. package/build-tsc/base64/index.d.ts +6 -0
  748. package/build-tsc/base64/pad.d.ts +5 -0
  749. package/build-tsc/base64/trim.d.ts +5 -0
  750. package/build-tsc/blake2/asU8a.d.ts +20 -0
  751. package/build-tsc/blake2/index.d.ts +4 -0
  752. package/build-tsc/bn.d.ts +30 -0
  753. package/build-tsc/bundle.d.ts +26 -0
  754. package/build-tsc/bundleInit.d.ts +1 -0
  755. package/build-tsc/crypto.d.ts +3 -0
  756. package/build-tsc/ed25519/deriveHard.d.ts +1 -0
  757. package/build-tsc/ed25519/index.d.ts +10 -0
  758. package/build-tsc/ed25519/pair/fromRandom.d.ts +16 -0
  759. package/build-tsc/ed25519/pair/fromSecret.d.ts +16 -0
  760. package/build-tsc/ed25519/pair/fromSeed.d.ts +16 -0
  761. package/build-tsc/ed25519/pair/fromString.d.ts +16 -0
  762. package/build-tsc/ed25519/sign.d.ts +16 -0
  763. package/build-tsc/ed25519/verify.d.ts +15 -0
  764. package/build-tsc/ethereum/encode.d.ts +2 -0
  765. package/build-tsc/ethereum/index.d.ts +3 -0
  766. package/build-tsc/ethereum/isAddress.d.ts +1 -0
  767. package/build-tsc/ethereum/isChecksum.d.ts +1 -0
  768. package/build-tsc/hd/ethereum/index.d.ts +2 -0
  769. package/build-tsc/hd/index.d.ts +3 -0
  770. package/build-tsc/hd/ledger/derivePrivate.d.ts +1 -0
  771. package/build-tsc/hd/ledger/index.d.ts +2 -0
  772. package/build-tsc/hd/ledger/master.d.ts +1 -0
  773. package/build-tsc/hd/validatePath.d.ts +2 -0
  774. package/build-tsc/helpers.d.ts +12 -0
  775. package/build-tsc/hmac/index.d.ts +1 -0
  776. package/build-tsc/hmac/shaAsU8a.d.ts +15 -0
  777. package/build-tsc/index.d.ts +2 -0
  778. package/build-tsc/json/constants.d.ts +6 -0
  779. package/build-tsc/json/decrypt.d.ts +2 -0
  780. package/build-tsc/json/decryptData.d.ts +2 -0
  781. package/build-tsc/json/encrypt.d.ts +2 -0
  782. package/build-tsc/json/encryptFormat.d.ts +2 -0
  783. package/build-tsc/json/index.d.ts +4 -0
  784. package/build-tsc/json/types.d.ts +16 -0
  785. package/build-tsc/keccak/asU8a.d.ts +30 -0
  786. package/build-tsc/keccak/index.d.ts +4 -0
  787. package/build-tsc/key/DeriveJunction.d.ts +12 -0
  788. package/build-tsc/key/extractPath.d.ts +9 -0
  789. package/build-tsc/key/extractSuri.d.ts +11 -0
  790. package/build-tsc/key/fromPath.d.ts +3 -0
  791. package/build-tsc/key/hdkdDerive.d.ts +3 -0
  792. package/build-tsc/key/hdkdEcdsa.d.ts +1 -0
  793. package/build-tsc/key/hdkdEd25519.d.ts +1 -0
  794. package/build-tsc/key/hdkdSr25519.d.ts +3 -0
  795. package/build-tsc/key/index.d.ts +9 -0
  796. package/build-tsc/mnemonic/bip39.d.ts +5 -0
  797. package/build-tsc/mnemonic/generate.d.ts +13 -0
  798. package/build-tsc/mnemonic/index.d.ts +8 -0
  799. package/build-tsc/mnemonic/toEntropy.d.ts +1 -0
  800. package/build-tsc/mnemonic/toLegacySeed.d.ts +18 -0
  801. package/build-tsc/mnemonic/toMiniSecret.d.ts +1 -0
  802. package/build-tsc/mnemonic/validate.d.ts +14 -0
  803. package/build-tsc/mnemonic/wordlists/en.d.ts +2 -0
  804. package/build-tsc/mnemonic/wordlists/es.d.ts +2 -0
  805. package/build-tsc/mnemonic/wordlists/fr.d.ts +2 -0
  806. package/build-tsc/mnemonic/wordlists/index.d.ts +8 -0
  807. package/build-tsc/mnemonic/wordlists/it.d.ts +2 -0
  808. package/build-tsc/mnemonic/wordlists/jp.d.ts +2 -0
  809. package/build-tsc/mnemonic/wordlists/ko.d.ts +2 -0
  810. package/build-tsc/mnemonic/wordlists/zh-s.d.ts +2 -0
  811. package/build-tsc/mnemonic/wordlists/zh-t.d.ts +2 -0
  812. package/build-tsc/nacl/decrypt.d.ts +15 -0
  813. package/build-tsc/nacl/encrypt.d.ts +20 -0
  814. package/build-tsc/nacl/index.d.ts +5 -0
  815. package/build-tsc/nacl/tweetnacl.d.ts +2 -0
  816. package/build-tsc/networks.d.ts +1 -0
  817. package/build-tsc/packageDetect.d.ts +1 -0
  818. package/build-tsc/packageInfo.d.ts +6 -0
  819. package/build-tsc/pbkdf2/encode.d.ts +7 -0
  820. package/build-tsc/pbkdf2/index.d.ts +1 -0
  821. package/build-tsc/random/asNumber.d.ts +15 -0
  822. package/build-tsc/random/asU8a.d.ts +20 -0
  823. package/build-tsc/random/index.d.ts +5 -0
  824. package/build-tsc/scrypt/defaults.d.ts +3 -0
  825. package/build-tsc/scrypt/encode.d.ts +8 -0
  826. package/build-tsc/scrypt/fromU8a.d.ts +7 -0
  827. package/build-tsc/scrypt/index.d.ts +3 -0
  828. package/build-tsc/scrypt/toU8a.d.ts +2 -0
  829. package/build-tsc/scrypt/types.d.ts +6 -0
  830. package/build-tsc/secp256k1/compress.d.ts +1 -0
  831. package/build-tsc/secp256k1/deriveHard.d.ts +1 -0
  832. package/build-tsc/secp256k1/expand.d.ts +1 -0
  833. package/build-tsc/secp256k1/hasher.d.ts +2 -0
  834. package/build-tsc/secp256k1/index.d.ts +7 -0
  835. package/build-tsc/secp256k1/pair/fromSeed.d.ts +6 -0
  836. package/build-tsc/secp256k1/recover.d.ts +6 -0
  837. package/build-tsc/secp256k1/sign.d.ts +7 -0
  838. package/build-tsc/secp256k1/tweakAdd.d.ts +1 -0
  839. package/build-tsc/secp256k1/types.d.ts +1 -0
  840. package/build-tsc/secp256k1/verify.d.ts +6 -0
  841. package/build-tsc/sha/asU8a.d.ts +15 -0
  842. package/build-tsc/sha/index.d.ts +4 -0
  843. package/build-tsc/signature/index.d.ts +4 -0
  844. package/build-tsc/signature/verify.d.ts +2 -0
  845. package/build-tsc/sr25519/agreement.d.ts +5 -0
  846. package/build-tsc/sr25519/derive.d.ts +2 -0
  847. package/build-tsc/sr25519/deriveHard.d.ts +1 -0
  848. package/build-tsc/sr25519/derivePublic.d.ts +1 -0
  849. package/build-tsc/sr25519/deriveSoft.d.ts +1 -0
  850. package/build-tsc/sr25519/index.d.ts +9 -0
  851. package/build-tsc/sr25519/pair/fromSeed.d.ts +6 -0
  852. package/build-tsc/sr25519/pair/fromU8a.d.ts +2 -0
  853. package/build-tsc/sr25519/pair/toU8a.d.ts +2 -0
  854. package/build-tsc/sr25519/sign.d.ts +6 -0
  855. package/build-tsc/sr25519/verify.d.ts +5 -0
  856. package/build-tsc/sr25519/vrfSign.d.ts +6 -0
  857. package/build-tsc/sr25519/vrfVerify.d.ts +5 -0
  858. package/build-tsc/types.d.ts +26 -0
  859. package/build-tsc/xxhash/asU8a.d.ts +20 -0
  860. package/build-tsc/xxhash/index.d.ts +4 -0
  861. package/build-tsc/xxhash/xxhash64.d.ts +1 -0
  862. package/build-tsc-cjs/address/addressToEvm.js +11 -0
  863. package/build-tsc-cjs/address/check.js +29 -0
  864. package/build-tsc-cjs/address/checksum.js +19 -0
  865. package/build-tsc-cjs/address/decode.js +32 -0
  866. package/build-tsc-cjs/address/defaults.js +11 -0
  867. package/build-tsc-cjs/address/derive.js +27 -0
  868. package/build-tsc-cjs/address/encode.js +26 -0
  869. package/build-tsc-cjs/address/encodeDerived.js +15 -0
  870. package/build-tsc-cjs/address/encodeMulti.js +14 -0
  871. package/build-tsc-cjs/address/eq.js +22 -0
  872. package/build-tsc-cjs/address/evmToAddress.js +17 -0
  873. package/build-tsc-cjs/address/index.js +35 -0
  874. package/build-tsc-cjs/address/is.js +12 -0
  875. package/build-tsc-cjs/address/keyDerived.js +11 -0
  876. package/build-tsc-cjs/address/keyMulti.js +11 -0
  877. package/build-tsc-cjs/address/setSS58Format.js +14 -0
  878. package/build-tsc-cjs/address/sort.js +10 -0
  879. package/build-tsc-cjs/address/sshash.js +9 -0
  880. package/build-tsc-cjs/address/types.js +2 -0
  881. package/build-tsc-cjs/address/util.js +7 -0
  882. package/build-tsc-cjs/address/validate.js +7 -0
  883. package/build-tsc-cjs/base32/bs32.js +43 -0
  884. package/build-tsc-cjs/base32/helpers.js +67 -0
  885. package/build-tsc-cjs/base32/index.js +11 -0
  886. package/build-tsc-cjs/base58/bs58.js +37 -0
  887. package/build-tsc-cjs/base58/index.js +11 -0
  888. package/build-tsc-cjs/base64/bs64.js +37 -0
  889. package/build-tsc-cjs/base64/index.js +15 -0
  890. package/build-tsc-cjs/base64/pad.js +10 -0
  891. package/build-tsc-cjs/base64/trim.js +13 -0
  892. package/build-tsc-cjs/blake2/asU8a.js +36 -0
  893. package/build-tsc-cjs/blake2/index.js +9 -0
  894. package/build-tsc-cjs/bn.js +11 -0
  895. package/build-tsc-cjs/bundle.js +31 -0
  896. package/build-tsc-cjs/bundleInit.js +7 -0
  897. package/build-tsc-cjs/crypto.js +16 -0
  898. package/build-tsc-cjs/ed25519/deriveHard.js +12 -0
  899. package/build-tsc-cjs/ed25519/index.js +20 -0
  900. package/build-tsc-cjs/ed25519/pair/fromRandom.js +22 -0
  901. package/build-tsc-cjs/ed25519/pair/fromSecret.js +26 -0
  902. package/build-tsc-cjs/ed25519/pair/fromSeed.js +34 -0
  903. package/build-tsc-cjs/ed25519/pair/fromString.js +23 -0
  904. package/build-tsc-cjs/ed25519/sign.js +33 -0
  905. package/build-tsc-cjs/ed25519/verify.js +39 -0
  906. package/build-tsc-cjs/ethereum/encode.js +28 -0
  907. package/build-tsc-cjs/ethereum/index.js +9 -0
  908. package/build-tsc-cjs/ethereum/isAddress.js +14 -0
  909. package/build-tsc-cjs/ethereum/isChecksum.js +20 -0
  910. package/build-tsc-cjs/hd/ethereum/index.js +47 -0
  911. package/build-tsc-cjs/hd/index.js +9 -0
  912. package/build-tsc-cjs/hd/ledger/derivePrivate.js +15 -0
  913. package/build-tsc-cjs/hd/ledger/index.js +33 -0
  914. package/build-tsc-cjs/hd/ledger/master.js +19 -0
  915. package/build-tsc-cjs/hd/validatePath.js +20 -0
  916. package/build-tsc-cjs/helpers.js +24 -0
  917. package/build-tsc-cjs/hmac/index.js +7 -0
  918. package/build-tsc-cjs/hmac/shaAsU8a.js +40 -0
  919. package/build-tsc-cjs/index.js +5 -0
  920. package/build-tsc-cjs/json/constants.js +8 -0
  921. package/build-tsc-cjs/json/decrypt.js +16 -0
  922. package/build-tsc-cjs/json/decryptData.js +32 -0
  923. package/build-tsc-cjs/json/encrypt.js +18 -0
  924. package/build-tsc-cjs/json/encryptFormat.js +17 -0
  925. package/build-tsc-cjs/json/index.js +11 -0
  926. package/build-tsc-cjs/json/types.js +2 -0
  927. package/build-tsc-cjs/keccak/asU8a.js +36 -0
  928. package/build-tsc-cjs/keccak/index.js +11 -0
  929. package/build-tsc-cjs/key/DeriveJunction.js +62 -0
  930. package/build-tsc-cjs/key/extractPath.js +26 -0
  931. package/build-tsc-cjs/key/extractSuri.js +25 -0
  932. package/build-tsc-cjs/key/fromPath.js +21 -0
  933. package/build-tsc-cjs/key/hdkdDerive.js +11 -0
  934. package/build-tsc-cjs/key/hdkdEcdsa.js +7 -0
  935. package/build-tsc-cjs/key/hdkdEd25519.js +6 -0
  936. package/build-tsc-cjs/key/hdkdSr25519.js +10 -0
  937. package/build-tsc-cjs/key/index.js +18 -0
  938. package/build-tsc-cjs/mnemonic/bip39.js +90 -0
  939. package/build-tsc-cjs/mnemonic/generate.js +23 -0
  940. package/build-tsc-cjs/mnemonic/index.js +16 -0
  941. package/build-tsc-cjs/mnemonic/toEntropy.js +11 -0
  942. package/build-tsc-cjs/mnemonic/toLegacySeed.js +37 -0
  943. package/build-tsc-cjs/mnemonic/toMiniSecret.js +20 -0
  944. package/build-tsc-cjs/mnemonic/validate.js +24 -0
  945. package/build-tsc-cjs/mnemonic/wordlists/en.js +3 -0
  946. package/build-tsc-cjs/mnemonic/wordlists/es.js +3 -0
  947. package/build-tsc-cjs/mnemonic/wordlists/fr.js +3 -0
  948. package/build-tsc-cjs/mnemonic/wordlists/index.js +20 -0
  949. package/build-tsc-cjs/mnemonic/wordlists/it.js +3 -0
  950. package/build-tsc-cjs/mnemonic/wordlists/jp.js +3 -0
  951. package/build-tsc-cjs/mnemonic/wordlists/ko.js +3 -0
  952. package/build-tsc-cjs/mnemonic/wordlists/zh-s.js +3 -0
  953. package/build-tsc-cjs/mnemonic/wordlists/zh-t.js +3 -0
  954. package/build-tsc-cjs/nacl/decrypt.js +21 -0
  955. package/build-tsc-cjs/nacl/encrypt.js +25 -0
  956. package/build-tsc-cjs/nacl/index.js +10 -0
  957. package/build-tsc-cjs/nacl/tweetnacl.js +238 -0
  958. package/build-tsc-cjs/networks.js +7 -0
  959. package/build-tsc-cjs/packageDetect.js +8 -0
  960. package/build-tsc-cjs/packageInfo.js +4 -0
  961. package/build-tsc-cjs/pbkdf2/encode.js +19 -0
  962. package/build-tsc-cjs/pbkdf2/index.js +5 -0
  963. package/build-tsc-cjs/random/asNumber.js +23 -0
  964. package/build-tsc-cjs/random/asU8a.js +28 -0
  965. package/build-tsc-cjs/random/index.js +11 -0
  966. package/build-tsc-cjs/scrypt/defaults.js +16 -0
  967. package/build-tsc-cjs/scrypt/encode.js +18 -0
  968. package/build-tsc-cjs/scrypt/fromU8a.js +27 -0
  969. package/build-tsc-cjs/scrypt/index.js +9 -0
  970. package/build-tsc-cjs/scrypt/toU8a.js +8 -0
  971. package/build-tsc-cjs/scrypt/types.js +2 -0
  972. package/build-tsc-cjs/secp256k1/compress.js +17 -0
  973. package/build-tsc-cjs/secp256k1/deriveHard.js +13 -0
  974. package/build-tsc-cjs/secp256k1/expand.js +20 -0
  975. package/build-tsc-cjs/secp256k1/hasher.js +10 -0
  976. package/build-tsc-cjs/secp256k1/index.js +17 -0
  977. package/build-tsc-cjs/secp256k1/pair/fromSeed.js +34 -0
  978. package/build-tsc-cjs/secp256k1/recover.js +29 -0
  979. package/build-tsc-cjs/secp256k1/sign.js +23 -0
  980. package/build-tsc-cjs/secp256k1/tweakAdd.js +48 -0
  981. package/build-tsc-cjs/secp256k1/types.js +2 -0
  982. package/build-tsc-cjs/secp256k1/verify.js +23 -0
  983. package/build-tsc-cjs/sha/asU8a.js +22 -0
  984. package/build-tsc-cjs/sha/index.js +10 -0
  985. package/build-tsc-cjs/signature/index.js +8 -0
  986. package/build-tsc-cjs/signature/verify.js +81 -0
  987. package/build-tsc-cjs/sr25519/agreement.js +20 -0
  988. package/build-tsc-cjs/sr25519/derive.js +16 -0
  989. package/build-tsc-cjs/sr25519/deriveHard.js +7 -0
  990. package/build-tsc-cjs/sr25519/derivePublic.js +16 -0
  991. package/build-tsc-cjs/sr25519/deriveSoft.js +7 -0
  992. package/build-tsc-cjs/sr25519/index.js +21 -0
  993. package/build-tsc-cjs/sr25519/pair/fromSeed.js +22 -0
  994. package/build-tsc-cjs/sr25519/pair/fromU8a.js +17 -0
  995. package/build-tsc-cjs/sr25519/pair/toU8a.js +7 -0
  996. package/build-tsc-cjs/sr25519/sign.js +19 -0
  997. package/build-tsc-cjs/sr25519/verify.js +21 -0
  998. package/build-tsc-cjs/sr25519/vrfSign.js +19 -0
  999. package/build-tsc-cjs/sr25519/vrfVerify.js +22 -0
  1000. package/build-tsc-cjs/types.js +5 -0
  1001. package/build-tsc-cjs/xxhash/asU8a.js +39 -0
  1002. package/build-tsc-cjs/xxhash/index.js +9 -0
  1003. package/build-tsc-cjs/xxhash/xxhash64.js +103 -0
  1004. package/build-tsc-esm/address/addressToEvm.js +8 -0
  1005. package/build-tsc-esm/address/check.js +26 -0
  1006. package/build-tsc-esm/address/checksum.js +16 -0
  1007. package/build-tsc-esm/address/decode.js +29 -0
  1008. package/build-tsc-esm/address/defaults.js +8 -0
  1009. package/build-tsc-esm/address/derive.js +24 -0
  1010. package/build-tsc-esm/address/encode.js +23 -0
  1011. package/build-tsc-esm/address/encodeDerived.js +12 -0
  1012. package/build-tsc-esm/address/encodeMulti.js +11 -0
  1013. package/build-tsc-esm/address/eq.js +19 -0
  1014. package/build-tsc-esm/address/evmToAddress.js +14 -0
  1015. package/build-tsc-esm/address/index.js +16 -0
  1016. package/build-tsc-esm/address/is.js +9 -0
  1017. package/build-tsc-esm/address/keyDerived.js +8 -0
  1018. package/build-tsc-esm/address/keyMulti.js +8 -0
  1019. package/build-tsc-esm/address/setSS58Format.js +11 -0
  1020. package/build-tsc-esm/address/sort.js +7 -0
  1021. package/build-tsc-esm/address/sshash.js +6 -0
  1022. package/build-tsc-esm/address/types.js +1 -0
  1023. package/build-tsc-esm/address/util.js +4 -0
  1024. package/build-tsc-esm/address/validate.js +4 -0
  1025. package/build-tsc-esm/base32/bs32.js +40 -0
  1026. package/build-tsc-esm/base32/helpers.js +61 -0
  1027. package/build-tsc-esm/base32/index.js +4 -0
  1028. package/build-tsc-esm/base58/bs58.js +34 -0
  1029. package/build-tsc-esm/base58/index.js +4 -0
  1030. package/build-tsc-esm/base64/bs64.js +34 -0
  1031. package/build-tsc-esm/base64/index.js +6 -0
  1032. package/build-tsc-esm/base64/pad.js +7 -0
  1033. package/build-tsc-esm/base64/trim.js +10 -0
  1034. package/build-tsc-esm/blake2/asU8a.js +32 -0
  1035. package/build-tsc-esm/blake2/index.js +4 -0
  1036. package/build-tsc-esm/bn.js +8 -0
  1037. package/build-tsc-esm/bundle.js +26 -0
  1038. package/build-tsc-esm/bundleInit.js +5 -0
  1039. package/build-tsc-esm/crypto.js +12 -0
  1040. package/build-tsc-esm/ed25519/deriveHard.js +9 -0
  1041. package/build-tsc-esm/ed25519/index.js +10 -0
  1042. package/build-tsc-esm/ed25519/pair/fromRandom.js +19 -0
  1043. package/build-tsc-esm/ed25519/pair/fromSecret.js +23 -0
  1044. package/build-tsc-esm/ed25519/pair/fromSeed.js +31 -0
  1045. package/build-tsc-esm/ed25519/pair/fromString.js +20 -0
  1046. package/build-tsc-esm/ed25519/sign.js +30 -0
  1047. package/build-tsc-esm/ed25519/verify.js +36 -0
  1048. package/build-tsc-esm/ethereum/encode.js +25 -0
  1049. package/build-tsc-esm/ethereum/index.js +3 -0
  1050. package/build-tsc-esm/ethereum/isAddress.js +11 -0
  1051. package/build-tsc-esm/ethereum/isChecksum.js +17 -0
  1052. package/build-tsc-esm/hd/ethereum/index.js +44 -0
  1053. package/build-tsc-esm/hd/index.js +3 -0
  1054. package/build-tsc-esm/hd/ledger/derivePrivate.js +12 -0
  1055. package/build-tsc-esm/hd/ledger/index.js +30 -0
  1056. package/build-tsc-esm/hd/ledger/master.js +16 -0
  1057. package/build-tsc-esm/hd/validatePath.js +16 -0
  1058. package/build-tsc-esm/helpers.js +19 -0
  1059. package/build-tsc-esm/hmac/index.js +1 -0
  1060. package/build-tsc-esm/hmac/shaAsU8a.js +36 -0
  1061. package/build-tsc-esm/index.js +2 -0
  1062. package/build-tsc-esm/json/constants.js +5 -0
  1063. package/build-tsc-esm/json/decrypt.js +13 -0
  1064. package/build-tsc-esm/json/decryptData.js +29 -0
  1065. package/build-tsc-esm/json/encrypt.js +15 -0
  1066. package/build-tsc-esm/json/encryptFormat.js +14 -0
  1067. package/build-tsc-esm/json/index.js +4 -0
  1068. package/build-tsc-esm/json/types.js +1 -0
  1069. package/build-tsc-esm/keccak/asU8a.js +33 -0
  1070. package/build-tsc-esm/keccak/index.js +4 -0
  1071. package/build-tsc-esm/key/DeriveJunction.js +58 -0
  1072. package/build-tsc-esm/key/extractPath.js +23 -0
  1073. package/build-tsc-esm/key/extractSuri.js +22 -0
  1074. package/build-tsc-esm/key/fromPath.js +18 -0
  1075. package/build-tsc-esm/key/hdkdDerive.js +8 -0
  1076. package/build-tsc-esm/key/hdkdEcdsa.js +4 -0
  1077. package/build-tsc-esm/key/hdkdEd25519.js +3 -0
  1078. package/build-tsc-esm/key/hdkdSr25519.js +7 -0
  1079. package/build-tsc-esm/key/index.js +9 -0
  1080. package/build-tsc-esm/mnemonic/bip39.js +82 -0
  1081. package/build-tsc-esm/mnemonic/generate.js +20 -0
  1082. package/build-tsc-esm/mnemonic/index.js +8 -0
  1083. package/build-tsc-esm/mnemonic/toEntropy.js +8 -0
  1084. package/build-tsc-esm/mnemonic/toLegacySeed.js +34 -0
  1085. package/build-tsc-esm/mnemonic/toMiniSecret.js +17 -0
  1086. package/build-tsc-esm/mnemonic/validate.js +21 -0
  1087. package/build-tsc-esm/mnemonic/wordlists/en.js +1 -0
  1088. package/build-tsc-esm/mnemonic/wordlists/es.js +1 -0
  1089. package/build-tsc-esm/mnemonic/wordlists/fr.js +1 -0
  1090. package/build-tsc-esm/mnemonic/wordlists/index.js +8 -0
  1091. package/build-tsc-esm/mnemonic/wordlists/it.js +1 -0
  1092. package/build-tsc-esm/mnemonic/wordlists/jp.js +1 -0
  1093. package/build-tsc-esm/mnemonic/wordlists/ko.js +1 -0
  1094. package/build-tsc-esm/mnemonic/wordlists/zh-s.js +1 -0
  1095. package/build-tsc-esm/mnemonic/wordlists/zh-t.js +1 -0
  1096. package/build-tsc-esm/nacl/decrypt.js +18 -0
  1097. package/build-tsc-esm/nacl/encrypt.js +22 -0
  1098. package/build-tsc-esm/nacl/index.js +5 -0
  1099. package/build-tsc-esm/nacl/tweetnacl.js +234 -0
  1100. package/build-tsc-esm/networks.js +1 -0
  1101. package/build-tsc-esm/packageDetect.js +6 -0
  1102. package/build-tsc-esm/packageInfo.js +1 -0
  1103. package/build-tsc-esm/pbkdf2/encode.js +16 -0
  1104. package/build-tsc-esm/pbkdf2/index.js +1 -0
  1105. package/build-tsc-esm/random/asNumber.js +20 -0
  1106. package/build-tsc-esm/random/asU8a.js +24 -0
  1107. package/build-tsc-esm/random/index.js +5 -0
  1108. package/build-tsc-esm/scrypt/defaults.js +13 -0
  1109. package/build-tsc-esm/scrypt/encode.js +15 -0
  1110. package/build-tsc-esm/scrypt/fromU8a.js +24 -0
  1111. package/build-tsc-esm/scrypt/index.js +3 -0
  1112. package/build-tsc-esm/scrypt/toU8a.js +5 -0
  1113. package/build-tsc-esm/scrypt/types.js +1 -0
  1114. package/build-tsc-esm/secp256k1/compress.js +14 -0
  1115. package/build-tsc-esm/secp256k1/deriveHard.js +10 -0
  1116. package/build-tsc-esm/secp256k1/expand.js +17 -0
  1117. package/build-tsc-esm/secp256k1/hasher.js +7 -0
  1118. package/build-tsc-esm/secp256k1/index.js +7 -0
  1119. package/build-tsc-esm/secp256k1/pair/fromSeed.js +31 -0
  1120. package/build-tsc-esm/secp256k1/recover.js +26 -0
  1121. package/build-tsc-esm/secp256k1/sign.js +20 -0
  1122. package/build-tsc-esm/secp256k1/tweakAdd.js +45 -0
  1123. package/build-tsc-esm/secp256k1/types.js +1 -0
  1124. package/build-tsc-esm/secp256k1/verify.js +20 -0
  1125. package/build-tsc-esm/sha/asU8a.js +19 -0
  1126. package/build-tsc-esm/sha/index.js +4 -0
  1127. package/build-tsc-esm/signature/index.js +4 -0
  1128. package/build-tsc-esm/signature/verify.js +78 -0
  1129. package/build-tsc-esm/sr25519/agreement.js +17 -0
  1130. package/build-tsc-esm/sr25519/derive.js +12 -0
  1131. package/build-tsc-esm/sr25519/deriveHard.js +3 -0
  1132. package/build-tsc-esm/sr25519/derivePublic.js +12 -0
  1133. package/build-tsc-esm/sr25519/deriveSoft.js +3 -0
  1134. package/build-tsc-esm/sr25519/index.js +9 -0
  1135. package/build-tsc-esm/sr25519/pair/fromSeed.js +18 -0
  1136. package/build-tsc-esm/sr25519/pair/fromU8a.js +14 -0
  1137. package/build-tsc-esm/sr25519/pair/toU8a.js +4 -0
  1138. package/build-tsc-esm/sr25519/sign.js +15 -0
  1139. package/build-tsc-esm/sr25519/verify.js +17 -0
  1140. package/build-tsc-esm/sr25519/vrfSign.js +15 -0
  1141. package/build-tsc-esm/sr25519/vrfVerify.js +18 -0
  1142. package/build-tsc-esm/types.js +2 -0
  1143. package/build-tsc-esm/xxhash/asU8a.js +35 -0
  1144. package/build-tsc-esm/xxhash/index.js +4 -0
  1145. package/build-tsc-esm/xxhash/xxhash64.js +100 -0
  1146. package/bundle-pezkuwi-util-crypto.js +8246 -8797
  1147. package/cjs/blake2/asU8a.d.ts +1 -1
  1148. package/cjs/keccak/asU8a.d.ts +1 -1
  1149. package/cjs/packageInfo.js +1 -1
  1150. package/cjs/scrypt/encode.d.ts +1 -1
  1151. package/cjs/sr25519/agreement.js +2 -2
  1152. package/cjs/xxhash/asU8a.d.ts +1 -1
  1153. package/keccak/asU8a.d.ts +1 -1
  1154. package/package.json +14 -14
  1155. package/packageInfo.js +1 -1
  1156. package/scrypt/encode.d.ts +1 -1
  1157. package/src/address/addressToEvm.spec.ts +16 -0
  1158. package/src/address/addressToEvm.ts +12 -0
  1159. package/src/address/check.spec.ts +44 -0
  1160. package/src/address/check.ts +34 -0
  1161. package/src/address/checksum.spec.ts +45 -0
  1162. package/src/address/checksum.ts +25 -0
  1163. package/src/address/decode.spec.ts +138 -0
  1164. package/src/address/decode.ts +41 -0
  1165. package/src/address/defaults.ts +12 -0
  1166. package/src/address/derive.spec.ts +26 -0
  1167. package/src/address/derive.ts +36 -0
  1168. package/src/address/encode.spec.ts +177 -0
  1169. package/src/address/encode.ts +43 -0
  1170. package/src/address/encodeDerived.spec.ts +14 -0
  1171. package/src/address/encodeDerived.ts +19 -0
  1172. package/src/address/encodeMulti.spec.ts +18 -0
  1173. package/src/address/encodeMulti.ts +18 -0
  1174. package/src/address/eq.spec.ts +45 -0
  1175. package/src/address/eq.ts +24 -0
  1176. package/src/address/evmToAddress.spec.ts +20 -0
  1177. package/src/address/evmToAddress.ts +24 -0
  1178. package/src/address/index.ts +21 -0
  1179. package/src/address/is.spec.ts +113 -0
  1180. package/src/address/is.ts +14 -0
  1181. package/src/address/keyDerived.spec.ts +24 -0
  1182. package/src/address/keyDerived.ts +22 -0
  1183. package/src/address/keyMulti.spec.ts +20 -0
  1184. package/src/address/keyMulti.ts +23 -0
  1185. package/src/address/setSS58Format.spec.ts +21 -0
  1186. package/src/address/setSS58Format.ts +20 -0
  1187. package/src/address/sort.spec.ts +22 -0
  1188. package/src/address/sort.ts +17 -0
  1189. package/src/address/sshash.ts +12 -0
  1190. package/src/address/types.ts +6 -0
  1191. package/src/address/util.ts +8 -0
  1192. package/src/address/validate.spec.ts +113 -0
  1193. package/src/address/validate.ts +10 -0
  1194. package/src/base32/bs32.ts +53 -0
  1195. package/src/base32/decode.spec.ts +34 -0
  1196. package/src/base32/encode.spec.ts +30 -0
  1197. package/src/base32/helpers.ts +93 -0
  1198. package/src/base32/index.ts +8 -0
  1199. package/src/base32/is.spec.ts +32 -0
  1200. package/src/base32/validate.spec.ts +44 -0
  1201. package/src/base58/bs58.ts +43 -0
  1202. package/src/base58/decode.spec.ts +31 -0
  1203. package/src/base58/encode.spec.ts +26 -0
  1204. package/src/base58/index.ts +8 -0
  1205. package/src/base58/validate.spec.ts +20 -0
  1206. package/src/base64/bs64.ts +43 -0
  1207. package/src/base64/decode.spec.ts +42 -0
  1208. package/src/base64/encode.spec.ts +14 -0
  1209. package/src/base64/index.ts +10 -0
  1210. package/src/base64/pad.spec.ts +14 -0
  1211. package/src/base64/pad.ts +10 -0
  1212. package/src/base64/trim.spec.ts +14 -0
  1213. package/src/base64/trim.ts +14 -0
  1214. package/src/base64/validate.spec.ts +32 -0
  1215. package/src/blake2/asHex.spec.ts +57 -0
  1216. package/src/blake2/asU8a.spec.ts +74 -0
  1217. package/src/blake2/asU8a.ts +40 -0
  1218. package/src/blake2/index.ts +8 -0
  1219. package/src/bn.ts +15 -0
  1220. package/src/bundle.ts +33 -0
  1221. package/src/bundleInit.ts +11 -0
  1222. package/src/crypto.spec.ts +18 -0
  1223. package/src/crypto.ts +18 -0
  1224. package/src/ed25519/deriveHard.ts +18 -0
  1225. package/src/ed25519/index.ts +13 -0
  1226. package/src/ed25519/pair/fromRandom.spec.ts +28 -0
  1227. package/src/ed25519/pair/fromRandom.ts +25 -0
  1228. package/src/ed25519/pair/fromSecret.spec.ts +33 -0
  1229. package/src/ed25519/pair/fromSecret.ts +29 -0
  1230. package/src/ed25519/pair/fromSeed.spec.ts +42 -0
  1231. package/src/ed25519/pair/fromSeed.ts +41 -0
  1232. package/src/ed25519/pair/fromString.spec.ts +17 -0
  1233. package/src/ed25519/pair/fromString.ts +31 -0
  1234. package/src/ed25519/sign.spec.ts +40 -0
  1235. package/src/ed25519/sign.ts +38 -0
  1236. package/src/ed25519/verify.spec.ts +84 -0
  1237. package/src/ed25519/verify.ts +41 -0
  1238. package/src/ethereum/encode.spec.ts +59 -0
  1239. package/src/ethereum/encode.ts +39 -0
  1240. package/src/ethereum/index.ts +6 -0
  1241. package/src/ethereum/isAddress.spec.ts +34 -0
  1242. package/src/ethereum/isAddress.ts +16 -0
  1243. package/src/ethereum/isChecksum.ts +27 -0
  1244. package/src/ethereum/isCheksum.spec.ts +30 -0
  1245. package/src/hd/ethereum/index.spec.ts +54 -0
  1246. package/src/hd/ethereum/index.ts +69 -0
  1247. package/src/hd/index.ts +6 -0
  1248. package/src/hd/ledger/derivePrivate.ts +34 -0
  1249. package/src/hd/ledger/index.spec.ts +64 -0
  1250. package/src/hd/ledger/index.ts +42 -0
  1251. package/src/hd/ledger/master.spec.ts +19 -0
  1252. package/src/hd/ledger/master.ts +26 -0
  1253. package/src/hd/validatePath.spec.ts +30 -0
  1254. package/src/hd/validatePath.ts +24 -0
  1255. package/src/helpers.ts +38 -0
  1256. package/src/hmac/index.ts +4 -0
  1257. package/src/hmac/shaAsU8a.spec.ts +45 -0
  1258. package/src/hmac/shaAsU8a.ts +48 -0
  1259. package/src/index.ts +6 -0
  1260. package/src/json/constants.ts +11 -0
  1261. package/src/json/decrypt.ts +25 -0
  1262. package/src/json/decryptData.ts +45 -0
  1263. package/src/json/encrypt.ts +25 -0
  1264. package/src/json/encryptFormat.ts +20 -0
  1265. package/src/json/index.ts +7 -0
  1266. package/src/json/types.ts +22 -0
  1267. package/src/keccak/asHex.spec.ts +30 -0
  1268. package/src/keccak/asU8a.spec.ts +56 -0
  1269. package/src/keccak/asU8a.ts +45 -0
  1270. package/src/keccak/index.ts +8 -0
  1271. package/src/key/DeriveJunction.ts +79 -0
  1272. package/src/key/extractPath.spec.ts +51 -0
  1273. package/src/key/extractPath.ts +37 -0
  1274. package/src/key/extractSuri.spec.ts +147 -0
  1275. package/src/key/extractSuri.ts +40 -0
  1276. package/src/key/fromPath.ts +28 -0
  1277. package/src/key/hdkdDerive.ts +17 -0
  1278. package/src/key/hdkdEcdsa.ts +8 -0
  1279. package/src/key/hdkdEd25519.ts +7 -0
  1280. package/src/key/hdkdSr25519.ts +14 -0
  1281. package/src/key/index.ts +12 -0
  1282. package/src/mnemonic/bip39.spec.ts +80 -0
  1283. package/src/mnemonic/bip39.ts +127 -0
  1284. package/src/mnemonic/generate.spec.ts +58 -0
  1285. package/src/mnemonic/generate.ts +25 -0
  1286. package/src/mnemonic/index.ts +11 -0
  1287. package/src/mnemonic/toEntropy.spec.ts +36 -0
  1288. package/src/mnemonic/toEntropy.ts +13 -0
  1289. package/src/mnemonic/toLegacySeed.spec.ts +52 -0
  1290. package/src/mnemonic/toLegacySeed.ts +39 -0
  1291. package/src/mnemonic/toMiniSecret.spec.ts +67 -0
  1292. package/src/mnemonic/toMiniSecret.ts +23 -0
  1293. package/src/mnemonic/toMiniSecretCmp.spec.ts +64 -0
  1294. package/src/mnemonic/validate.spec.ts +39 -0
  1295. package/src/mnemonic/validate.ts +26 -0
  1296. package/src/mnemonic/wordlists/en.ts +7 -0
  1297. package/src/mnemonic/wordlists/es.ts +7 -0
  1298. package/src/mnemonic/wordlists/fr.ts +7 -0
  1299. package/src/mnemonic/wordlists/index.ts +11 -0
  1300. package/src/mnemonic/wordlists/it.ts +7 -0
  1301. package/src/mnemonic/wordlists/jp.ts +7 -0
  1302. package/src/mnemonic/wordlists/ko.ts +7 -0
  1303. package/src/mnemonic/wordlists/zh-s.ts +7 -0
  1304. package/src/mnemonic/wordlists/zh-t.ts +7 -0
  1305. package/src/mod.ts +4 -0
  1306. package/src/nacl/decrypt.spec.ts +26 -0
  1307. package/src/nacl/decrypt.ts +22 -0
  1308. package/src/nacl/encrypt.spec.ts +20 -0
  1309. package/src/nacl/encrypt.ts +31 -0
  1310. package/src/nacl/index.ts +8 -0
  1311. package/src/nacl/tweetnacl-secretbox-data.spec.ts +4629 -0
  1312. package/src/nacl/tweetnacl-secretbox.spec.ts +161 -0
  1313. package/src/nacl/tweetnacl.ts +1159 -0
  1314. package/src/networks.ts +5 -0
  1315. package/src/packageDetect.ts +14 -0
  1316. package/src/packageInfo.ts +6 -0
  1317. package/src/pbkdf2/encode.spec.ts +54 -0
  1318. package/src/pbkdf2/encode.ts +29 -0
  1319. package/src/pbkdf2/index.ts +4 -0
  1320. package/src/random/asHex.spec.ts +38 -0
  1321. package/src/random/asNumber.spec.ts +16 -0
  1322. package/src/random/asNumber.ts +28 -0
  1323. package/src/random/asU8a.spec.ts +36 -0
  1324. package/src/random/asU8a.ts +30 -0
  1325. package/src/random/index.ts +9 -0
  1326. package/src/scrypt/defaults.ts +19 -0
  1327. package/src/scrypt/encode.spec.ts +43 -0
  1328. package/src/scrypt/encode.ts +30 -0
  1329. package/src/scrypt/fromU8a.ts +44 -0
  1330. package/src/scrypt/index.ts +6 -0
  1331. package/src/scrypt/toU8a.ts +17 -0
  1332. package/src/scrypt/types.ts +9 -0
  1333. package/src/secp256k1/compress.spec.ts +47 -0
  1334. package/src/secp256k1/compress.ts +21 -0
  1335. package/src/secp256k1/deriveHard.ts +17 -0
  1336. package/src/secp256k1/expand.spec.ts +47 -0
  1337. package/src/secp256k1/expand.ts +30 -0
  1338. package/src/secp256k1/hasher.spec.ts +24 -0
  1339. package/src/secp256k1/hasher.ts +13 -0
  1340. package/src/secp256k1/index.ts +10 -0
  1341. package/src/secp256k1/pair/fromSeed.spec.ts +75 -0
  1342. package/src/secp256k1/pair/fromSeed.ts +42 -0
  1343. package/src/secp256k1/recover.spec.ts +35 -0
  1344. package/src/secp256k1/recover.ts +36 -0
  1345. package/src/secp256k1/sign.spec.ts +39 -0
  1346. package/src/secp256k1/sign.ts +37 -0
  1347. package/src/secp256k1/signVerify.spec.ts +94 -0
  1348. package/src/secp256k1/tweakAdd.spec.ts +35 -0
  1349. package/src/secp256k1/tweakAdd.ts +65 -0
  1350. package/src/secp256k1/types.ts +4 -0
  1351. package/src/secp256k1/verify.spec.ts +81 -0
  1352. package/src/secp256k1/verify.ts +32 -0
  1353. package/src/sha/asU8a.ts +30 -0
  1354. package/src/sha/asU8a256.spec.ts +55 -0
  1355. package/src/sha/asU8a512.spec.ts +33 -0
  1356. package/src/sha/index.ts +8 -0
  1357. package/src/signature/index.ts +8 -0
  1358. package/src/signature/verify.spec.ts +230 -0
  1359. package/src/signature/verify.ts +114 -0
  1360. package/src/sr25519/agreement.spec.ts +31 -0
  1361. package/src/sr25519/agreement.ts +23 -0
  1362. package/src/sr25519/derive.ts +21 -0
  1363. package/src/sr25519/deriveHard.ts +9 -0
  1364. package/src/sr25519/derivePublic.ts +18 -0
  1365. package/src/sr25519/deriveSoft.ts +9 -0
  1366. package/src/sr25519/index.ts +12 -0
  1367. package/src/sr25519/pair/fromSeed.spec.ts +35 -0
  1368. package/src/sr25519/pair/fromSeed.ts +28 -0
  1369. package/src/sr25519/pair/fromU8a.ts +23 -0
  1370. package/src/sr25519/pair/testing.spec.ts +161 -0
  1371. package/src/sr25519/pair/toU8a.ts +10 -0
  1372. package/src/sr25519/sign.spec.ts +28 -0
  1373. package/src/sr25519/sign.ts +22 -0
  1374. package/src/sr25519/verify.spec.ts +42 -0
  1375. package/src/sr25519/verify.ts +23 -0
  1376. package/src/sr25519/vrfSign.ts +24 -0
  1377. package/src/sr25519/vrfSignVerify.spec.ts +73 -0
  1378. package/src/sr25519/vrfVerify.ts +25 -0
  1379. package/src/test/index.ts +8 -0
  1380. package/src/test/performance.ts +17 -0
  1381. package/src/types.ts +33 -0
  1382. package/src/xxhash/asHex.spec.ts +36 -0
  1383. package/src/xxhash/asU8a.spec.ts +48 -0
  1384. package/src/xxhash/asU8a.ts +45 -0
  1385. package/src/xxhash/index.ts +8 -0
  1386. package/src/xxhash/xxhash64.ts +155 -0
  1387. package/tsconfig.build.json +18 -0
  1388. package/tsconfig.build.tsbuildinfo +1 -0
  1389. package/tsconfig.spec.json +20 -0
  1390. package/tsconfig.spec.tsbuildinfo +1 -0
  1391. package/xxhash/asU8a.d.ts +1 -1
@@ -0,0 +1,56 @@
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 } from '@pezkuwi/util';
7
+ import { waitReady } from '@pezkuwi/wasm-crypto';
8
+
9
+ import { perfWasm } from '../test/index.js';
10
+ import { keccakAsU8a } from './index.js';
11
+
12
+ describe('keccakAsU8a', (): void => {
13
+ beforeEach(async (): Promise<void> => {
14
+ await waitReady();
15
+ });
16
+
17
+ const input = 'test value';
18
+ const output = {
19
+ 256: hexToU8a(
20
+ '0x2d07364b5c231c56ce63d49430e085ea3033c750688ba532b24029124c26ca5e'
21
+ ),
22
+ 512: hexToU8a(
23
+ '0xc1b50cc57f85ccd968a9d7c7a809dcebd140a548c8e0b67f3afcdd6fc14cca2b1d04187aef24ba0081b74f2ec362431e425760febe94a5607790854cafe5b197'
24
+ )
25
+ };
26
+
27
+ for (const bitLength of [256, 512] as const) {
28
+ describe(`bitLength=${bitLength}`, (): void => {
29
+ for (const onlyJs of [false, true]) {
30
+ describe(`onlyJs=${(onlyJs && 'true') || 'false'}`, (): void => {
31
+ it('returns an hex representation (string)', (): void => {
32
+ expect(
33
+ keccakAsU8a(input, bitLength, onlyJs)
34
+ ).toEqual(output[bitLength]);
35
+ });
36
+
37
+ it('returns an hex representation (Buffer)', (): void => {
38
+ expect(
39
+ keccakAsU8a(Buffer.from(input), bitLength, onlyJs)
40
+ ).toEqual(output[bitLength]);
41
+ });
42
+
43
+ it('returns an hex representation (Uint8Array)', (): void => {
44
+ expect(
45
+ keccakAsU8a(stringToU8a(input), bitLength, onlyJs)
46
+ ).toEqual(output[bitLength]);
47
+ });
48
+ });
49
+ }
50
+
51
+ perfWasm(`keccakAsU8a, bitLength=${bitLength}`, 128000, (input, onlyJs) =>
52
+ keccakAsU8a(input, bitLength, onlyJs)
53
+ );
54
+ });
55
+ }
56
+ });
@@ -0,0 +1,45 @@
1
+ // Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+
4
+ import { keccak_256 as keccak256Js, keccak_512 as keccak512Js } from '@noble/hashes/sha3';
5
+
6
+ import { keccak256, keccak512 } from '@pezkuwi/wasm-crypto';
7
+
8
+ import { createAsHex, createBitHasher, createDualHasher } from '../helpers.js';
9
+
10
+ /**
11
+ * @name keccakAsU8a
12
+ * @summary Creates a keccak Uint8Array from the input.
13
+ * @description
14
+ * From either a `string` or a `Buffer` input, create the keccak and return the result as a `Uint8Array`.
15
+ * @example
16
+ * <BR>
17
+ *
18
+ * ```javascript
19
+ * import { keccakAsU8a } from '@pezkuwi/util-crypto';
20
+ *
21
+ * keccakAsU8a('123'); // => Uint8Array
22
+ * ```
23
+ */
24
+ export const keccakAsU8a = /*#__PURE__*/ createDualHasher(
25
+ { 256: keccak256, 512: keccak512 },
26
+ { 256: keccak256Js, 512: keccak512Js }
27
+ );
28
+
29
+ /**
30
+ * @name keccak256AsU8a
31
+ * @description Creates a keccak256 Uint8Array from the input.
32
+ */
33
+ export const keccak256AsU8a = /*#__PURE__*/ createBitHasher(256, keccakAsU8a);
34
+
35
+ /**
36
+ * @name keccak512AsU8a
37
+ * @description Creates a keccak512 Uint8Array from the input.
38
+ */
39
+ export const keccak512AsU8a = /*#__PURE__*/ createBitHasher(512, keccakAsU8a);
40
+
41
+ /**
42
+ * @name keccakAsHex
43
+ * @description Creates a keccak hex string from the input.
44
+ */
45
+ export const keccakAsHex = /*#__PURE__*/ createAsHex(keccakAsU8a);
@@ -0,0 +1,8 @@
1
+ // Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+
4
+ /**
5
+ * @summary Create Keccak256/512 values as hex & Uint8Array output
6
+ */
7
+
8
+ export { keccak256AsU8a, keccak512AsU8a, keccakAsHex, keccakAsU8a } from './asU8a.js';
@@ -0,0 +1,79 @@
1
+ // Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+
4
+ import { BN, bnToU8a, compactAddLength, hexToU8a, isBigInt, isBn, isHex, isNumber, isString, stringToU8a } from '@pezkuwi/util';
5
+
6
+ import { blake2AsU8a } from '../blake2/asU8a.js';
7
+ import { BN_LE_256_OPTS } from '../bn.js';
8
+
9
+ const RE_NUMBER = /^\d+$/;
10
+
11
+ const JUNCTION_ID_LEN = 32;
12
+
13
+ export class DeriveJunction {
14
+ readonly #chainCode: Uint8Array = new Uint8Array(32);
15
+
16
+ #isHard = false;
17
+
18
+ public static from (value: string): DeriveJunction {
19
+ const result = new DeriveJunction();
20
+ const [code, isHard] = value.startsWith('/')
21
+ ? [value.substring(1), true]
22
+ : [value, false];
23
+
24
+ result.soft(
25
+ RE_NUMBER.test(code)
26
+ ? new BN(code, 10)
27
+ : code
28
+ );
29
+
30
+ return isHard
31
+ ? result.harden()
32
+ : result;
33
+ }
34
+
35
+ public get chainCode (): Uint8Array {
36
+ return this.#chainCode;
37
+ }
38
+
39
+ public get isHard (): boolean {
40
+ return this.#isHard;
41
+ }
42
+
43
+ public get isSoft (): boolean {
44
+ return !this.#isHard;
45
+ }
46
+
47
+ public hard (value: number | string | bigint | BN | Uint8Array): DeriveJunction {
48
+ return this.soft(value).harden();
49
+ }
50
+
51
+ public harden (): DeriveJunction {
52
+ this.#isHard = true;
53
+
54
+ return this;
55
+ }
56
+
57
+ public soft (value: number | string | bigint | BN | Uint8Array): DeriveJunction {
58
+ if (isNumber(value) || isBn(value) || isBigInt(value)) {
59
+ return this.soft(bnToU8a(value, BN_LE_256_OPTS));
60
+ } else if (isHex(value)) {
61
+ return this.soft(hexToU8a(value));
62
+ } else if (isString(value)) {
63
+ return this.soft(compactAddLength(stringToU8a(value)));
64
+ } else if (value.length > JUNCTION_ID_LEN) {
65
+ return this.soft(blake2AsU8a(value));
66
+ }
67
+
68
+ this.#chainCode.fill(0);
69
+ this.#chainCode.set(value, 0);
70
+
71
+ return this;
72
+ }
73
+
74
+ public soften (): DeriveJunction {
75
+ this.#isHard = false;
76
+
77
+ return this;
78
+ }
79
+ }
@@ -0,0 +1,51 @@
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 './extractPath.js';
7
+
8
+ import { keyExtractPath } from './extractPath.js';
9
+
10
+ describe('keyExtractPath', (): void => {
11
+ it('extracts properly from soft', (): void => {
12
+ const test = keyExtractPath('/1');
13
+
14
+ expect(test.parts).toEqual(['/1']);
15
+ expect(test.path.length).toEqual(1);
16
+ expect(test.path[0].isHard).toEqual(false);
17
+ 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]));
18
+ });
19
+
20
+ it('extracts properly from hard', (): void => {
21
+ const test = keyExtractPath('//1');
22
+
23
+ expect(test.parts).toEqual(['//1']);
24
+ expect(test.path.length).toEqual(1);
25
+ expect(test.path[0].isHard).toEqual(true);
26
+ 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]));
27
+ });
28
+
29
+ it('extracts properly from hard/soft', (): void => {
30
+ const test = keyExtractPath('//1/2');
31
+
32
+ expect(test.parts).toEqual(['//1', '/2']);
33
+ expect(test.path.length).toEqual(2);
34
+ expect(test.path[0].isHard).toEqual(true);
35
+ 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]));
36
+ expect(test.path[1].isHard).toEqual(false);
37
+ expect(test.path[1].chainCode).toEqual(Uint8Array.from([2, 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]));
38
+ });
39
+
40
+ it('does not extract from invalid paths (1)', (): void => {
41
+ expect(
42
+ (): ExtractResult => keyExtractPath('1/2')
43
+ ).toThrow(/does not match input/);
44
+ });
45
+
46
+ it('does not extract from invalid paths (2)', (): void => {
47
+ expect(
48
+ (): ExtractResult => keyExtractPath('hello')
49
+ ).toThrow(/does not match input/);
50
+ });
51
+ });
@@ -0,0 +1,37 @@
1
+ // Copyright 2017-2025 @pezkuwi/util-crypto authors & contributors
2
+ // SPDX-License-Identifier: Apache-2.0
3
+
4
+ import { DeriveJunction } from './DeriveJunction.js';
5
+
6
+ const RE_JUNCTION = /\/(\/?)([^/]+)/g;
7
+
8
+ export interface ExtractResult {
9
+ parts: string[] | null;
10
+ path: DeriveJunction[];
11
+ }
12
+
13
+ /**
14
+ * @description Extract derivation junctions from the supplied path
15
+ */
16
+ export function keyExtractPath (derivePath: string): ExtractResult {
17
+ const parts = derivePath.match(RE_JUNCTION);
18
+ const path: DeriveJunction[] = [];
19
+ let constructed = '';
20
+
21
+ if (parts) {
22
+ constructed = parts.join('');
23
+
24
+ for (const p of parts) {
25
+ path.push(DeriveJunction.from(p.substring(1)));
26
+ }
27
+ }
28
+
29
+ if (constructed !== derivePath) {
30
+ throw new Error(`Re-constructed path "${constructed}" does not match input`);
31
+ }
32
+
33
+ return {
34
+ parts,
35
+ path
36
+ };
37
+ }
@@ -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
+ }
@@ -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
+ });