@bitgo-beta/sdk-core 8.2.1-beta.99 → 8.2.1-beta.991

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 (536) hide show
  1. package/CHANGELOG.md +2797 -0
  2. package/dist/src/account-lib/baseCoin/baseTransaction.d.ts +0 -1
  3. package/dist/src/account-lib/baseCoin/baseTransaction.d.ts.map +1 -1
  4. package/dist/src/account-lib/baseCoin/baseTransactionBuilder.d.ts +3 -3
  5. package/dist/src/account-lib/baseCoin/baseTransactionBuilder.d.ts.map +1 -1
  6. package/dist/src/account-lib/baseCoin/baseTransactionBuilder.js +4 -3
  7. package/dist/src/account-lib/baseCoin/ed25519KeyPair.d.ts +1 -0
  8. package/dist/src/account-lib/baseCoin/ed25519KeyPair.d.ts.map +1 -1
  9. package/dist/src/account-lib/baseCoin/ed25519KeyPair.js +41 -29
  10. package/dist/src/account-lib/baseCoin/enum.d.ts +17 -3
  11. package/dist/src/account-lib/baseCoin/enum.d.ts.map +1 -1
  12. package/dist/src/account-lib/baseCoin/enum.js +32 -7
  13. package/dist/src/account-lib/baseCoin/errors.d.ts +3 -0
  14. package/dist/src/account-lib/baseCoin/errors.d.ts.map +1 -1
  15. package/dist/src/account-lib/baseCoin/errors.js +8 -2
  16. package/dist/src/account-lib/baseCoin/iface.d.ts +19 -35
  17. package/dist/src/account-lib/baseCoin/iface.d.ts.map +1 -1
  18. package/dist/src/account-lib/baseCoin/iface.js +26 -18
  19. package/dist/src/account-lib/baseCoin/index.d.ts +1 -1
  20. package/dist/src/account-lib/baseCoin/index.d.ts.map +1 -1
  21. package/dist/src/account-lib/baseCoin/index.js +8 -5
  22. package/dist/src/account-lib/baseCoin/messages/baseMessage.d.ts +81 -0
  23. package/dist/src/account-lib/baseCoin/messages/baseMessage.d.ts.map +1 -0
  24. package/dist/src/account-lib/baseCoin/messages/baseMessage.js +136 -0
  25. package/dist/src/account-lib/baseCoin/messages/baseMessageBuilder.d.ts +67 -0
  26. package/dist/src/account-lib/baseCoin/messages/baseMessageBuilder.d.ts.map +1 -0
  27. package/dist/src/account-lib/baseCoin/messages/baseMessageBuilder.js +144 -0
  28. package/dist/src/account-lib/baseCoin/messages/baseMessageBuilderFactory.d.ts +33 -0
  29. package/dist/src/account-lib/baseCoin/messages/baseMessageBuilderFactory.d.ts.map +1 -0
  30. package/dist/src/account-lib/baseCoin/messages/baseMessageBuilderFactory.js +44 -0
  31. package/dist/src/account-lib/baseCoin/messages/iface.d.ts +157 -0
  32. package/dist/src/account-lib/baseCoin/messages/iface.d.ts.map +1 -0
  33. package/dist/src/account-lib/baseCoin/messages/iface.js +3 -0
  34. package/dist/src/account-lib/baseCoin/messages/index.d.ts +6 -0
  35. package/dist/src/account-lib/baseCoin/messages/index.d.ts.map +1 -0
  36. package/dist/src/account-lib/baseCoin/messages/index.js +22 -0
  37. package/dist/src/account-lib/baseCoin/messages/simple/index.d.ts +3 -0
  38. package/dist/src/account-lib/baseCoin/messages/simple/index.d.ts.map +1 -0
  39. package/dist/src/account-lib/baseCoin/messages/simple/index.js +19 -0
  40. package/dist/src/account-lib/baseCoin/messages/simple/simpleMessage.d.ts +13 -0
  41. package/dist/src/account-lib/baseCoin/messages/simple/simpleMessage.d.ts.map +1 -0
  42. package/dist/src/account-lib/baseCoin/messages/simple/simpleMessage.js +31 -0
  43. package/dist/src/account-lib/baseCoin/messages/simple/simpleMessageBuilder.d.ts +21 -0
  44. package/dist/src/account-lib/baseCoin/messages/simple/simpleMessageBuilder.d.ts.map +1 -0
  45. package/dist/src/account-lib/baseCoin/messages/simple/simpleMessageBuilder.js +28 -0
  46. package/dist/src/account-lib/baseCoin/secp256k1ExtendedKeyPair.d.ts +1 -2
  47. package/dist/src/account-lib/baseCoin/secp256k1ExtendedKeyPair.d.ts.map +1 -1
  48. package/dist/src/account-lib/baseCoin/secp256k1ExtendedKeyPair.js +38 -26
  49. package/dist/src/account-lib/index.js +23 -9
  50. package/dist/src/account-lib/mpc/curves/ed25519.d.ts +4 -18
  51. package/dist/src/account-lib/mpc/curves/ed25519.d.ts.map +1 -1
  52. package/dist/src/account-lib/mpc/curves/ed25519.js +6 -60
  53. package/dist/src/account-lib/mpc/index.d.ts +4 -4
  54. package/dist/src/account-lib/mpc/index.d.ts.map +1 -1
  55. package/dist/src/account-lib/mpc/index.js +11 -7
  56. package/dist/src/account-lib/mpc/shamir.d.ts +5 -37
  57. package/dist/src/account-lib/mpc/shamir.d.ts.map +1 -1
  58. package/dist/src/account-lib/mpc/shamir.js +6 -130
  59. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts +38 -9
  60. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -1
  61. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.js +497 -349
  62. package/dist/src/account-lib/mpc/tss/ecdsa/index.js +23 -9
  63. package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.d.ts +2 -2
  64. package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.d.ts.map +1 -1
  65. package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.js +3 -3
  66. package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts +73 -52
  67. package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts.map +1 -1
  68. package/dist/src/account-lib/mpc/tss/ecdsa/types.js +1 -1
  69. package/dist/src/account-lib/mpc/tss/eddsa/eddsa.d.ts +1 -2
  70. package/dist/src/account-lib/mpc/tss/eddsa/eddsa.d.ts.map +1 -1
  71. package/dist/src/account-lib/mpc/tss/eddsa/eddsa.js +66 -69
  72. package/dist/src/account-lib/mpc/tss/eddsa/index.js +23 -9
  73. package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts +1 -1
  74. package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts.map +1 -1
  75. package/dist/src/account-lib/mpc/tss/eddsa/types.js +1 -1
  76. package/dist/src/account-lib/mpc/tss/index.js +23 -9
  77. package/dist/src/account-lib/mpc/util.d.ts +7 -1
  78. package/dist/src/account-lib/mpc/util.d.ts.map +1 -1
  79. package/dist/src/account-lib/mpc/util.js +19 -1
  80. package/dist/src/account-lib/staking/index.js +6 -2
  81. package/dist/src/account-lib/staking/utils.js +3 -3
  82. package/dist/src/account-lib/util/crypto.d.ts +8 -2
  83. package/dist/src/account-lib/util/crypto.d.ts.map +1 -1
  84. package/dist/src/account-lib/util/crypto.js +69 -38
  85. package/dist/src/account-lib/util/ed25519KeyDeriver.d.ts +2 -1
  86. package/dist/src/account-lib/util/ed25519KeyDeriver.d.ts.map +1 -1
  87. package/dist/src/account-lib/util/ed25519KeyDeriver.js +5 -3
  88. package/dist/src/api/bip32path.js +2 -3
  89. package/dist/src/api/index.js +6 -2
  90. package/dist/src/api/types.d.ts +8 -0
  91. package/dist/src/api/types.d.ts.map +1 -1
  92. package/dist/src/api/types.js +1 -1
  93. package/dist/src/bitgo/address-book/address-book.d.ts +61 -0
  94. package/dist/src/bitgo/address-book/address-book.d.ts.map +1 -0
  95. package/dist/src/bitgo/address-book/address-book.js +139 -0
  96. package/dist/src/bitgo/address-book/index.d.ts +3 -0
  97. package/dist/src/bitgo/address-book/index.d.ts.map +1 -0
  98. package/dist/src/bitgo/address-book/index.js +19 -0
  99. package/dist/src/bitgo/address-book/types.d.ts +170 -0
  100. package/dist/src/bitgo/address-book/types.d.ts.map +1 -0
  101. package/dist/src/bitgo/address-book/types.js +3 -0
  102. package/dist/src/bitgo/baseCoin/baseCoin.d.ts +90 -10
  103. package/dist/src/bitgo/baseCoin/baseCoin.d.ts.map +1 -1
  104. package/dist/src/bitgo/baseCoin/baseCoin.js +142 -16
  105. package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts +113 -19
  106. package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts.map +1 -1
  107. package/dist/src/bitgo/baseCoin/iBaseCoin.js +7 -3
  108. package/dist/src/bitgo/baseCoin/index.js +6 -2
  109. package/dist/src/bitgo/bip32util.d.ts +3 -16
  110. package/dist/src/bitgo/bip32util.d.ts.map +1 -1
  111. package/dist/src/bitgo/bip32util.js +4 -56
  112. package/dist/src/bitgo/bitcoin.d.ts +0 -1
  113. package/dist/src/bitgo/bitcoin.d.ts.map +1 -1
  114. package/dist/src/bitgo/bitcoin.js +26 -13
  115. package/dist/src/bitgo/bitgoBase.d.ts +6 -2
  116. package/dist/src/bitgo/bitgoBase.d.ts.map +1 -1
  117. package/dist/src/bitgo/bitgoBase.js +1 -1
  118. package/dist/src/bitgo/coinFactory.d.ts +17 -3
  119. package/dist/src/bitgo/coinFactory.d.ts.map +1 -1
  120. package/dist/src/bitgo/coinFactory.js +26 -3
  121. package/dist/src/bitgo/config.d.ts +94 -20
  122. package/dist/src/bitgo/config.d.ts.map +1 -1
  123. package/dist/src/bitgo/config.js +26 -15
  124. package/dist/src/bitgo/ecdh.d.ts +0 -1
  125. package/dist/src/bitgo/ecdh.d.ts.map +1 -1
  126. package/dist/src/bitgo/ecdh.js +26 -13
  127. package/dist/src/bitgo/enterprise/enterprise.d.ts +16 -14
  128. package/dist/src/bitgo/enterprise/enterprise.d.ts.map +1 -1
  129. package/dist/src/bitgo/enterprise/enterprise.js +64 -31
  130. package/dist/src/bitgo/enterprise/enterprises.d.ts +6 -0
  131. package/dist/src/bitgo/enterprise/enterprises.d.ts.map +1 -1
  132. package/dist/src/bitgo/enterprise/enterprises.js +48 -9
  133. package/dist/src/bitgo/enterprise/iEnterprise.d.ts +6 -7
  134. package/dist/src/bitgo/enterprise/iEnterprise.d.ts.map +1 -1
  135. package/dist/src/bitgo/enterprise/iEnterprise.js +1 -1
  136. package/dist/src/bitgo/enterprise/iEnterprises.d.ts +2 -0
  137. package/dist/src/bitgo/enterprise/iEnterprises.d.ts.map +1 -1
  138. package/dist/src/bitgo/enterprise/iEnterprises.js +1 -1
  139. package/dist/src/bitgo/enterprise/index.js +6 -2
  140. package/dist/src/bitgo/environments.d.ts +60 -5
  141. package/dist/src/bitgo/environments.d.ts.map +1 -1
  142. package/dist/src/bitgo/environments.js +96 -32
  143. package/dist/src/bitgo/errors.d.ts +6 -0
  144. package/dist/src/bitgo/errors.d.ts.map +1 -1
  145. package/dist/src/bitgo/errors.js +14 -2
  146. package/dist/src/bitgo/index.d.ts +1 -1
  147. package/dist/src/bitgo/index.d.ts.map +1 -1
  148. package/dist/src/bitgo/index.js +26 -11
  149. package/dist/src/bitgo/inscriptionBuilder/iInscriptionBuilder.d.ts +3 -3
  150. package/dist/src/bitgo/inscriptionBuilder/iInscriptionBuilder.d.ts.map +1 -1
  151. package/dist/src/bitgo/inscriptionBuilder/iInscriptionBuilder.js +1 -1
  152. package/dist/src/bitgo/inscriptionBuilder/index.js +6 -2
  153. package/dist/src/bitgo/internal/index.js +6 -2
  154. package/dist/src/bitgo/internal/internal.js +5 -6
  155. package/dist/src/bitgo/internal/keycard.js +6 -7
  156. package/dist/src/bitgo/keychain/decryptKeychain.d.ts +13 -0
  157. package/dist/src/bitgo/keychain/decryptKeychain.d.ts.map +1 -0
  158. package/dist/src/bitgo/keychain/decryptKeychain.js +35 -0
  159. package/dist/src/bitgo/keychain/iKeychains.d.ts +63 -7
  160. package/dist/src/bitgo/keychain/iKeychains.d.ts.map +1 -1
  161. package/dist/src/bitgo/keychain/iKeychains.js +2 -2
  162. package/dist/src/bitgo/keychain/index.d.ts +1 -0
  163. package/dist/src/bitgo/keychain/index.d.ts.map +1 -1
  164. package/dist/src/bitgo/keychain/index.js +7 -2
  165. package/dist/src/bitgo/keychain/keychains.d.ts +13 -3
  166. package/dist/src/bitgo/keychain/keychains.d.ts.map +1 -1
  167. package/dist/src/bitgo/keychain/keychains.js +128 -37
  168. package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts +3 -3
  169. package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts.map +1 -1
  170. package/dist/src/bitgo/keychain/ovcJsonCodec.js +23 -9
  171. package/dist/src/bitgo/legacyBitcoin.d.ts +0 -1
  172. package/dist/src/bitgo/legacyBitcoin.d.ts.map +1 -1
  173. package/dist/src/bitgo/legacyBitcoin.js +27 -13
  174. package/dist/src/bitgo/lightning/lightningWalletUtil.d.ts +7 -0
  175. package/dist/src/bitgo/lightning/lightningWalletUtil.d.ts.map +1 -0
  176. package/dist/src/bitgo/lightning/lightningWalletUtil.js +25 -0
  177. package/dist/src/bitgo/market/iMarkets.d.ts +2 -2
  178. package/dist/src/bitgo/market/iMarkets.d.ts.map +1 -1
  179. package/dist/src/bitgo/market/index.js +6 -2
  180. package/dist/src/bitgo/market/markets.js +23 -9
  181. package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts +1 -0
  182. package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts.map +1 -1
  183. package/dist/src/bitgo/pendingApproval/iPendingApproval.js +4 -4
  184. package/dist/src/bitgo/pendingApproval/index.js +6 -2
  185. package/dist/src/bitgo/pendingApproval/pendingApproval.d.ts +20 -8
  186. package/dist/src/bitgo/pendingApproval/pendingApproval.d.ts.map +1 -1
  187. package/dist/src/bitgo/pendingApproval/pendingApproval.js +221 -107
  188. package/dist/src/bitgo/pendingApproval/pendingApprovals.js +23 -9
  189. package/dist/src/bitgo/recovery/index.js +6 -2
  190. package/dist/src/bitgo/recovery/initiate.d.ts +8 -2
  191. package/dist/src/bitgo/recovery/initiate.d.ts.map +1 -1
  192. package/dist/src/bitgo/recovery/initiate.js +7 -8
  193. package/dist/src/bitgo/staking/goStakingInterfaces.d.ts +129 -0
  194. package/dist/src/bitgo/staking/goStakingInterfaces.d.ts.map +1 -0
  195. package/dist/src/bitgo/staking/goStakingInterfaces.js +3 -0
  196. package/dist/src/bitgo/staking/goStakingWallet.d.ts +62 -0
  197. package/dist/src/bitgo/staking/goStakingWallet.d.ts.map +1 -0
  198. package/dist/src/bitgo/staking/goStakingWallet.js +143 -0
  199. package/dist/src/bitgo/staking/iGoStakingWallet.d.ts +17 -0
  200. package/dist/src/bitgo/staking/iGoStakingWallet.d.ts.map +1 -0
  201. package/dist/src/bitgo/staking/iGoStakingWallet.js +3 -0
  202. package/dist/src/bitgo/staking/iStakingWallet.d.ts +120 -4
  203. package/dist/src/bitgo/staking/iStakingWallet.d.ts.map +1 -1
  204. package/dist/src/bitgo/staking/iStakingWallet.js +2 -2
  205. package/dist/src/bitgo/staking/index.d.ts +3 -0
  206. package/dist/src/bitgo/staking/index.d.ts.map +1 -1
  207. package/dist/src/bitgo/staking/index.js +9 -2
  208. package/dist/src/bitgo/staking/stakingWallet.d.ts +13 -2
  209. package/dist/src/bitgo/staking/stakingWallet.d.ts.map +1 -1
  210. package/dist/src/bitgo/staking/stakingWallet.js +45 -4
  211. package/dist/src/bitgo/trading/iTradingAccount.d.ts +2 -32
  212. package/dist/src/bitgo/trading/iTradingAccount.d.ts.map +1 -1
  213. package/dist/src/bitgo/trading/iTradingAccount.js +1 -1
  214. package/dist/src/bitgo/trading/index.d.ts +1 -15
  215. package/dist/src/bitgo/trading/index.d.ts.map +1 -1
  216. package/dist/src/bitgo/trading/index.js +7 -17
  217. package/dist/src/bitgo/trading/network/decrypt-aes-gcm.d.ts +8 -0
  218. package/dist/src/bitgo/trading/network/decrypt-aes-gcm.d.ts.map +1 -0
  219. package/dist/src/bitgo/trading/network/decrypt-aes-gcm.js +31 -0
  220. package/dist/src/bitgo/trading/network/decrypt-rsa.d.ts +8 -0
  221. package/dist/src/bitgo/trading/network/decrypt-rsa.d.ts.map +1 -0
  222. package/dist/src/bitgo/trading/network/decrypt-rsa.js +23 -0
  223. package/dist/src/bitgo/trading/network/decrypt.d.ts +14 -0
  224. package/dist/src/bitgo/trading/network/decrypt.d.ts.map +1 -0
  225. package/dist/src/bitgo/trading/network/decrypt.js +23 -0
  226. package/dist/src/bitgo/trading/network/encrypt-aes-gcm.d.ts +8 -0
  227. package/dist/src/bitgo/trading/network/encrypt-aes-gcm.d.ts.map +1 -0
  228. package/dist/src/bitgo/trading/network/encrypt-aes-gcm.js +25 -0
  229. package/dist/src/bitgo/trading/network/encrypt-rsa-browser.d.ts +8 -0
  230. package/dist/src/bitgo/trading/network/encrypt-rsa-browser.d.ts.map +1 -0
  231. package/dist/src/bitgo/trading/network/encrypt-rsa-browser.js +65 -0
  232. package/dist/src/bitgo/trading/network/encrypt-rsa.d.ts +8 -0
  233. package/dist/src/bitgo/trading/network/encrypt-rsa.d.ts.map +1 -0
  234. package/dist/src/bitgo/trading/network/encrypt-rsa.js +23 -0
  235. package/dist/src/bitgo/trading/network/encrypt.d.ts +37 -0
  236. package/dist/src/bitgo/trading/network/encrypt.d.ts.map +1 -0
  237. package/dist/src/bitgo/trading/network/encrypt.js +58 -0
  238. package/dist/src/bitgo/trading/network/index.d.ts +5 -0
  239. package/dist/src/bitgo/trading/network/index.d.ts.map +1 -0
  240. package/dist/src/bitgo/trading/network/index.js +21 -0
  241. package/dist/src/bitgo/trading/network/network.d.ts +36 -0
  242. package/dist/src/bitgo/trading/network/network.d.ts.map +1 -0
  243. package/dist/src/bitgo/trading/network/network.js +101 -0
  244. package/dist/src/bitgo/trading/network/types.d.ts +277 -0
  245. package/dist/src/bitgo/trading/network/types.d.ts.map +1 -0
  246. package/dist/src/bitgo/trading/network/types.js +3 -0
  247. package/dist/src/bitgo/trading/network/utils.d.ts +20 -0
  248. package/dist/src/bitgo/trading/network/utils.d.ts.map +1 -0
  249. package/dist/src/bitgo/trading/network/utils.js +54 -0
  250. package/dist/src/bitgo/trading/tradingAccount.d.ts +11 -35
  251. package/dist/src/bitgo/trading/tradingAccount.d.ts.map +1 -1
  252. package/dist/src/bitgo/trading/tradingAccount.js +9 -96
  253. package/dist/src/bitgo/tss/bitgoPubKeys.d.ts +27 -0
  254. package/dist/src/bitgo/tss/bitgoPubKeys.d.ts.map +1 -0
  255. package/dist/src/bitgo/tss/bitgoPubKeys.js +61 -0
  256. package/dist/src/bitgo/tss/common.d.ts +37 -5
  257. package/dist/src/bitgo/tss/common.d.ts.map +1 -1
  258. package/dist/src/bitgo/tss/common.js +103 -17
  259. package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts +6 -4
  260. package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts.map +1 -1
  261. package/dist/src/bitgo/tss/ecdsa/ecdsa.js +78 -66
  262. package/dist/src/bitgo/tss/ecdsa/ecdsaMPCv2.d.ts +15 -0
  263. package/dist/src/bitgo/tss/ecdsa/ecdsaMPCv2.d.ts.map +1 -0
  264. package/dist/src/bitgo/tss/ecdsa/ecdsaMPCv2.js +162 -0
  265. package/dist/src/bitgo/tss/ecdsa/index.d.ts +1 -0
  266. package/dist/src/bitgo/tss/ecdsa/index.d.ts.map +1 -1
  267. package/dist/src/bitgo/tss/ecdsa/index.js +25 -10
  268. package/dist/src/bitgo/tss/ecdsa/types.d.ts +27 -27
  269. package/dist/src/bitgo/tss/ecdsa/types.d.ts.map +1 -1
  270. package/dist/src/bitgo/tss/ecdsa/types.js +3 -3
  271. package/dist/src/bitgo/tss/eddsa/eddsa.d.ts +11 -8
  272. package/dist/src/bitgo/tss/eddsa/eddsa.d.ts.map +1 -1
  273. package/dist/src/bitgo/tss/eddsa/eddsa.js +38 -41
  274. package/dist/src/bitgo/tss/eddsa/index.js +23 -9
  275. package/dist/src/bitgo/tss/eddsa/types.d.ts +4 -4
  276. package/dist/src/bitgo/tss/eddsa/types.d.ts.map +1 -1
  277. package/dist/src/bitgo/tss/index.d.ts +3 -2
  278. package/dist/src/bitgo/tss/index.d.ts.map +1 -1
  279. package/dist/src/bitgo/tss/index.js +26 -10
  280. package/dist/src/bitgo/tss/types.d.ts +3 -3
  281. package/dist/src/bitgo/tss/types.d.ts.map +1 -1
  282. package/dist/src/bitgo/tss/types.js +2 -2
  283. package/dist/src/bitgo/types.d.ts +3 -3
  284. package/dist/src/bitgo/types.d.ts.map +1 -1
  285. package/dist/src/bitgo/utils/abstractUtxoCoinUtil.d.ts +11 -0
  286. package/dist/src/bitgo/utils/abstractUtxoCoinUtil.d.ts.map +1 -1
  287. package/dist/src/bitgo/utils/abstractUtxoCoinUtil.js +66 -10
  288. package/dist/src/bitgo/utils/codecProps.js +24 -11
  289. package/dist/src/bitgo/utils/decode.d.ts.map +1 -1
  290. package/dist/src/bitgo/utils/decode.js +30 -16
  291. package/dist/src/bitgo/utils/index.d.ts +3 -2
  292. package/dist/src/bitgo/utils/index.d.ts.map +1 -1
  293. package/dist/src/bitgo/utils/index.js +26 -11
  294. package/dist/src/bitgo/utils/messageTypes.d.ts +37 -0
  295. package/dist/src/bitgo/utils/messageTypes.d.ts.map +1 -0
  296. package/dist/src/bitgo/utils/messageTypes.js +14 -0
  297. package/dist/src/bitgo/utils/mpcUtils.d.ts +2 -3
  298. package/dist/src/bitgo/utils/mpcUtils.d.ts.map +1 -1
  299. package/dist/src/bitgo/utils/mpcUtils.js +34 -12
  300. package/dist/src/bitgo/utils/notEmpty.d.ts +2 -0
  301. package/dist/src/bitgo/utils/notEmpty.d.ts.map +1 -0
  302. package/dist/src/bitgo/utils/notEmpty.js +7 -0
  303. package/dist/src/bitgo/utils/opengpgUtils.d.ts +11 -9
  304. package/dist/src/bitgo/utils/opengpgUtils.d.ts.map +1 -1
  305. package/dist/src/bitgo/utils/opengpgUtils.js +74 -73
  306. package/dist/src/bitgo/utils/postWithCodec.d.ts.map +1 -1
  307. package/dist/src/bitgo/utils/postWithCodec.js +4 -38
  308. package/dist/src/bitgo/utils/promise-utils.d.ts +1 -1
  309. package/dist/src/bitgo/utils/promise-utils.d.ts.map +1 -1
  310. package/dist/src/bitgo/utils/promise-utils.js +2 -3
  311. package/dist/src/bitgo/utils/triple.d.ts +1 -1
  312. package/dist/src/bitgo/utils/triple.d.ts.map +1 -1
  313. package/dist/src/bitgo/utils/triple.js +2 -3
  314. package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts +52 -14
  315. package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts.map +1 -1
  316. package/dist/src/bitgo/utils/tss/baseTSSUtils.js +186 -44
  317. package/dist/src/bitgo/utils/tss/baseTypes.d.ts +205 -34
  318. package/dist/src/bitgo/utils/tss/baseTypes.d.ts.map +1 -1
  319. package/dist/src/bitgo/utils/tss/baseTypes.js +22 -20
  320. package/dist/src/bitgo/utils/tss/ecdsa/SMC/utils.d.ts +23 -0
  321. package/dist/src/bitgo/utils/tss/ecdsa/SMC/utils.d.ts.map +1 -0
  322. package/dist/src/bitgo/utils/tss/ecdsa/SMC/utils.js +157 -0
  323. package/dist/src/bitgo/utils/tss/ecdsa/base.d.ts +28 -0
  324. package/dist/src/bitgo/utils/tss/ecdsa/base.d.ts.map +1 -0
  325. package/dist/src/bitgo/utils/tss/ecdsa/base.js +53 -0
  326. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts +20 -52
  327. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts.map +1 -1
  328. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.js +145 -280
  329. package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.d.ts +199 -0
  330. package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.d.ts.map +1 -0
  331. package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.js +950 -0
  332. package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2KeyGenSender.d.ts +8 -0
  333. package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2KeyGenSender.d.ts.map +1 -0
  334. package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2KeyGenSender.js +13 -0
  335. package/dist/src/bitgo/utils/tss/ecdsa/index.d.ts +4 -0
  336. package/dist/src/bitgo/utils/tss/ecdsa/index.d.ts.map +1 -1
  337. package/dist/src/bitgo/utils/tss/ecdsa/index.js +10 -2
  338. package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts +15 -9
  339. package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts.map +1 -1
  340. package/dist/src/bitgo/utils/tss/ecdsa/types.js +1 -1
  341. package/dist/src/bitgo/utils/tss/ecdsa/typesMPCv2.d.ts +107 -0
  342. package/dist/src/bitgo/utils/tss/ecdsa/typesMPCv2.d.ts.map +1 -0
  343. package/dist/src/bitgo/utils/tss/ecdsa/typesMPCv2.js +55 -0
  344. package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts +5 -3
  345. package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts.map +1 -1
  346. package/dist/src/bitgo/utils/tss/eddsa/eddsa.js +75 -58
  347. package/dist/src/bitgo/utils/tss/eddsa/index.js +23 -9
  348. package/dist/src/bitgo/utils/tss/eddsa/types.d.ts +7 -7
  349. package/dist/src/bitgo/utils/tss/eddsa/types.d.ts.map +1 -1
  350. package/dist/src/bitgo/utils/tss/index.js +23 -9
  351. package/dist/src/bitgo/utils/txRequest.d.ts +10 -0
  352. package/dist/src/bitgo/utils/txRequest.d.ts.map +1 -0
  353. package/dist/src/bitgo/utils/txRequest.js +47 -0
  354. package/dist/src/bitgo/utils/util.js +24 -10
  355. package/dist/src/bitgo/utils/wallet.d.ts +7 -0
  356. package/dist/src/bitgo/utils/wallet.d.ts.map +1 -0
  357. package/dist/src/bitgo/utils/wallet.js +48 -0
  358. package/dist/src/bitgo/wallet/BuildParams.d.ts +52 -8
  359. package/dist/src/bitgo/wallet/BuildParams.d.ts.map +1 -1
  360. package/dist/src/bitgo/wallet/BuildParams.js +65 -19
  361. package/dist/src/bitgo/wallet/iWallet.d.ts +204 -19
  362. package/dist/src/bitgo/wallet/iWallet.d.ts.map +1 -1
  363. package/dist/src/bitgo/wallet/iWallet.js +1 -1
  364. package/dist/src/bitgo/wallet/iWallets.d.ts +91 -16
  365. package/dist/src/bitgo/wallet/iWallets.d.ts.map +1 -1
  366. package/dist/src/bitgo/wallet/iWallets.js +43 -3
  367. package/dist/src/bitgo/wallet/index.js +6 -2
  368. package/dist/src/bitgo/wallet/wallet.d.ts +198 -25
  369. package/dist/src/bitgo/wallet/wallet.d.ts.map +1 -1
  370. package/dist/src/bitgo/wallet/wallet.js +983 -309
  371. package/dist/src/bitgo/wallet/wallets.d.ts +96 -9
  372. package/dist/src/bitgo/wallet/wallets.d.ts.map +1 -1
  373. package/dist/src/bitgo/wallet/wallets.js +816 -193
  374. package/dist/src/bitgo/webhook/index.js +6 -2
  375. package/dist/src/bitgo/webhook/webhooks.js +23 -9
  376. package/dist/src/coins/fiataed.d.ts +32 -0
  377. package/dist/src/coins/fiataed.d.ts.map +1 -0
  378. package/dist/src/coins/fiataed.js +61 -0
  379. package/dist/src/coins/fiateur.d.ts +3 -2
  380. package/dist/src/coins/fiateur.d.ts.map +1 -1
  381. package/dist/src/coins/fiateur.js +5 -1
  382. package/dist/src/coins/fiatgbp.d.ts +3 -2
  383. package/dist/src/coins/fiatgbp.d.ts.map +1 -1
  384. package/dist/src/coins/fiatgbp.js +5 -1
  385. package/dist/src/coins/fiatsgd.d.ts +32 -0
  386. package/dist/src/coins/fiatsgd.d.ts.map +1 -0
  387. package/dist/src/coins/fiatsgd.js +61 -0
  388. package/dist/src/coins/fiatusd.d.ts +3 -2
  389. package/dist/src/coins/fiatusd.d.ts.map +1 -1
  390. package/dist/src/coins/fiatusd.js +5 -1
  391. package/dist/src/coins/index.d.ts +4 -0
  392. package/dist/src/coins/index.d.ts.map +1 -1
  393. package/dist/src/coins/index.js +10 -2
  394. package/dist/src/coins/ofc.d.ts +3 -2
  395. package/dist/src/coins/ofc.d.ts.map +1 -1
  396. package/dist/src/coins/ofc.js +6 -2
  397. package/dist/src/coins/ofcToken.js +2 -2
  398. package/dist/src/coins/susd.d.ts +3 -2
  399. package/dist/src/coins/susd.d.ts.map +1 -1
  400. package/dist/src/coins/susd.js +5 -1
  401. package/dist/src/coins/tfiataed.d.ts +11 -0
  402. package/dist/src/coins/tfiataed.d.ts.map +1 -0
  403. package/dist/src/coins/tfiataed.js +17 -0
  404. package/dist/src/coins/tfiatsgd.d.ts +11 -0
  405. package/dist/src/coins/tfiatsgd.d.ts.map +1 -0
  406. package/dist/src/coins/tfiatsgd.js +17 -0
  407. package/dist/src/common.js +27 -13
  408. package/dist/src/index.d.ts +2 -1
  409. package/dist/src/index.d.ts.map +1 -1
  410. package/dist/src/index.js +26 -11
  411. package/dist/src/units.js +5 -6
  412. package/dist/test/unit/account-lib/baseCoin/messages/baseMessage.d.ts +2 -0
  413. package/dist/test/unit/account-lib/baseCoin/messages/baseMessage.d.ts.map +1 -0
  414. package/dist/test/unit/account-lib/baseCoin/messages/baseMessage.js +218 -0
  415. package/dist/test/unit/account-lib/baseCoin/messages/baseMessageBuilder.d.ts +2 -0
  416. package/dist/test/unit/account-lib/baseCoin/messages/baseMessageBuilder.d.ts.map +1 -0
  417. package/dist/test/unit/account-lib/baseCoin/messages/baseMessageBuilder.js +173 -0
  418. package/dist/test/unit/account-lib/baseCoin/messages/baseMessageBuilderFactory.d.ts +2 -0
  419. package/dist/test/unit/account-lib/baseCoin/messages/baseMessageBuilderFactory.d.ts.map +1 -0
  420. package/dist/test/unit/account-lib/baseCoin/messages/baseMessageBuilderFactory.js +105 -0
  421. package/dist/test/unit/account-lib/baseCoin/messages/fixtures.d.ts +46 -0
  422. package/dist/test/unit/account-lib/baseCoin/messages/fixtures.d.ts.map +1 -0
  423. package/dist/test/unit/account-lib/baseCoin/messages/fixtures.js +71 -0
  424. package/dist/test/unit/account-lib/mpc/tss/ecdsa/ecdsa.d.ts +2 -0
  425. package/dist/test/unit/account-lib/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -0
  426. package/dist/test/unit/account-lib/mpc/tss/ecdsa/ecdsa.js +233 -0
  427. package/dist/test/unit/account-lib/mpc/tss/ecdsa/fixtures.d.ts +3 -0
  428. package/dist/test/unit/account-lib/mpc/tss/ecdsa/fixtures.d.ts.map +1 -0
  429. package/dist/test/unit/account-lib/mpc/tss/ecdsa/fixtures.js +24 -0
  430. package/dist/test/unit/bitgo/trading/network/encrypt.d.ts +2 -0
  431. package/dist/test/unit/bitgo/trading/network/encrypt.d.ts.map +1 -0
  432. package/dist/test/unit/bitgo/trading/network/encrypt.js +71 -0
  433. package/dist/test/unit/bitgo/utils/abstractUtxoCoinUtil.d.ts +2 -0
  434. package/dist/test/unit/bitgo/utils/abstractUtxoCoinUtil.d.ts.map +1 -0
  435. package/dist/test/unit/bitgo/utils/abstractUtxoCoinUtil.js +45 -0
  436. package/dist/test/unit/bitgo/utils/messageTypes.d.ts +2 -0
  437. package/dist/test/unit/bitgo/utils/messageTypes.d.ts.map +1 -0
  438. package/dist/test/unit/bitgo/utils/messageTypes.js +64 -0
  439. package/dist/test/unit/bitgo/utils/notEmpty.d.ts +2 -0
  440. package/dist/test/unit/bitgo/utils/notEmpty.d.ts.map +1 -0
  441. package/dist/test/unit/bitgo/utils/notEmpty.js +15 -0
  442. package/dist/test/unit/bitgo/utils/postWithCodec.js +32 -38
  443. package/dist/test/unit/bitgo/utils/txRequest.d.ts +2 -0
  444. package/dist/test/unit/bitgo/utils/txRequest.d.ts.map +1 -0
  445. package/dist/test/unit/bitgo/utils/txRequest.js +105 -0
  446. package/dist/test/unit/bitgo/wallet/BuildParams.d.ts +2 -0
  447. package/dist/test/unit/bitgo/wallet/BuildParams.d.ts.map +1 -0
  448. package/dist/test/unit/bitgo/wallet/BuildParams.js +68 -0
  449. package/dist/test/unit/bitgo/wallet/SendTransactionRequest.js +37 -17
  450. package/dist/test/unit/units.js +63 -63
  451. package/dist/tsconfig.tsbuildinfo +1 -1
  452. package/package.json +24 -21
  453. package/dist/src/account-lib/baseCoin/blsKeyPair.d.ts +0 -77
  454. package/dist/src/account-lib/baseCoin/blsKeyPair.d.ts.map +0 -1
  455. package/dist/src/account-lib/baseCoin/blsKeyPair.js +0 -209
  456. package/dist/src/account-lib/mpc/hdTree.d.ts +0 -31
  457. package/dist/src/account-lib/mpc/hdTree.d.ts.map +0 -1
  458. package/dist/src/account-lib/mpc/hdTree.js +0 -141
  459. package/dist/src/account-lib/mpc/types.d.ts +0 -5
  460. package/dist/src/account-lib/mpc/types.d.ts.map +0 -1
  461. package/dist/src/account-lib/mpc/types.js +0 -3
  462. package/dist/src/bitgo/lightning/iLightning.d.ts +0 -186
  463. package/dist/src/bitgo/lightning/iLightning.d.ts.map +0 -1
  464. package/dist/src/bitgo/lightning/iLightning.js +0 -106
  465. package/dist/src/bitgo/lightning/index.d.ts +0 -5
  466. package/dist/src/bitgo/lightning/index.d.ts.map +0 -1
  467. package/dist/src/bitgo/lightning/index.js +0 -17
  468. package/dist/src/bitgo/lightning/lightning.d.ts +0 -25
  469. package/dist/src/bitgo/lightning/lightning.d.ts.map +0 -1
  470. package/dist/src/bitgo/lightning/lightning.js +0 -111
  471. package/dist/src/bitgo/lightning/lightningUtils.d.ts +0 -46
  472. package/dist/src/bitgo/lightning/lightningUtils.d.ts.map +0 -1
  473. package/dist/src/bitgo/lightning/lightningUtils.js +0 -133
  474. package/dist/src/bitgo/lightning/lnurlCodec.d.ts +0 -3
  475. package/dist/src/bitgo/lightning/lnurlCodec.d.ts.map +0 -1
  476. package/dist/src/bitgo/lightning/lnurlCodec.js +0 -28
  477. package/dist/src/bitgo/trading/affirmation.d.ts +0 -35
  478. package/dist/src/bitgo/trading/affirmation.d.ts.map +0 -1
  479. package/dist/src/bitgo/trading/affirmation.js +0 -53
  480. package/dist/src/bitgo/trading/affirmations.d.ts +0 -23
  481. package/dist/src/bitgo/trading/affirmations.d.ts.map +0 -1
  482. package/dist/src/bitgo/trading/affirmations.js +0 -45
  483. package/dist/src/bitgo/trading/iAffirmation.d.ts +0 -15
  484. package/dist/src/bitgo/trading/iAffirmation.d.ts.map +0 -1
  485. package/dist/src/bitgo/trading/iAffirmation.js +0 -13
  486. package/dist/src/bitgo/trading/iAffirmations.d.ts +0 -10
  487. package/dist/src/bitgo/trading/iAffirmations.d.ts.map +0 -1
  488. package/dist/src/bitgo/trading/iAffirmations.js +0 -3
  489. package/dist/src/bitgo/trading/iSettlement.d.ts +0 -25
  490. package/dist/src/bitgo/trading/iSettlement.d.ts.map +0 -1
  491. package/dist/src/bitgo/trading/iSettlement.js +0 -17
  492. package/dist/src/bitgo/trading/iSettlements.d.ts +0 -19
  493. package/dist/src/bitgo/trading/iSettlements.d.ts.map +0 -1
  494. package/dist/src/bitgo/trading/iSettlements.js +0 -3
  495. package/dist/src/bitgo/trading/iTradingPartner.d.ts +0 -14
  496. package/dist/src/bitgo/trading/iTradingPartner.d.ts.map +0 -1
  497. package/dist/src/bitgo/trading/iTradingPartner.js +0 -17
  498. package/dist/src/bitgo/trading/iTradingPartners.d.ts +0 -15
  499. package/dist/src/bitgo/trading/iTradingPartners.d.ts.map +0 -1
  500. package/dist/src/bitgo/trading/iTradingPartners.js +0 -9
  501. package/dist/src/bitgo/trading/lock.d.ts +0 -16
  502. package/dist/src/bitgo/trading/lock.d.ts.map +0 -1
  503. package/dist/src/bitgo/trading/lock.js +0 -12
  504. package/dist/src/bitgo/trading/payload.d.ts +0 -22
  505. package/dist/src/bitgo/trading/payload.d.ts.map +0 -1
  506. package/dist/src/bitgo/trading/payload.js +0 -3
  507. package/dist/src/bitgo/trading/settlement.d.ts +0 -16
  508. package/dist/src/bitgo/trading/settlement.d.ts.map +0 -1
  509. package/dist/src/bitgo/trading/settlement.js +0 -21
  510. package/dist/src/bitgo/trading/settlements.d.ts +0 -32
  511. package/dist/src/bitgo/trading/settlements.d.ts.map +0 -1
  512. package/dist/src/bitgo/trading/settlements.js +0 -61
  513. package/dist/src/bitgo/trading/trade.d.ts +0 -29
  514. package/dist/src/bitgo/trading/trade.d.ts.map +0 -1
  515. package/dist/src/bitgo/trading/trade.js +0 -11
  516. package/dist/src/bitgo/trading/tradingPartner.d.ts +0 -26
  517. package/dist/src/bitgo/trading/tradingPartner.d.ts.map +0 -1
  518. package/dist/src/bitgo/trading/tradingPartner.js +0 -31
  519. package/dist/src/bitgo/trading/tradingPartners.d.ts +0 -24
  520. package/dist/src/bitgo/trading/tradingPartners.d.ts.map +0 -1
  521. package/dist/src/bitgo/trading/tradingPartners.js +0 -32
  522. package/dist/src/bitgo/utils/blsUtils.d.ts +0 -52
  523. package/dist/src/bitgo/utils/blsUtils.d.ts.map +0 -1
  524. package/dist/src/bitgo/utils/blsUtils.js +0 -237
  525. package/dist/src/bitgo/utils/iBlsUtils.d.ts +0 -14
  526. package/dist/src/bitgo/utils/iBlsUtils.d.ts.map +0 -1
  527. package/dist/src/bitgo/utils/iBlsUtils.js +0 -3
  528. package/dist/src/bitgo/wallet/SendTransactionRequest.d.ts +0 -71
  529. package/dist/src/bitgo/wallet/SendTransactionRequest.d.ts.map +0 -1
  530. package/dist/src/bitgo/wallet/SendTransactionRequest.js +0 -41
  531. package/dist/src/openssl/index.d.ts +0 -5
  532. package/dist/src/openssl/index.d.ts.map +0 -1
  533. package/dist/src/openssl/index.js +0 -9
  534. package/dist/test/unit/openssl.d.ts +0 -2
  535. package/dist/test/unit/openssl.d.ts.map +0 -1
  536. package/dist/test/unit/openssl.js +0 -39
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bitgo-beta/sdk-core",
3
- "version": "8.2.1-beta.99",
3
+ "version": "8.2.1-beta.991",
4
4
  "description": "core library functions for BitGoJS",
5
5
  "main": "./dist/src/index.js",
6
6
  "types": "./dist/src/index.d.ts",
@@ -12,7 +12,8 @@
12
12
  "check-fmt": "prettier --check .",
13
13
  "clean": "rm -r ./dist",
14
14
  "lint": "eslint --quiet .",
15
- "prepare": "npm run build"
15
+ "prepare": "npm run build",
16
+ "test:watch": " mocha -r ts-node/register --watch --watch-files test/**/*.ts"
16
17
  },
17
18
  "author": "BitGo SDK Team <sdkteam@bitgo.com>",
18
19
  "license": "MIT",
@@ -36,42 +37,44 @@
36
37
  ]
37
38
  },
38
39
  "dependencies": {
39
- "@bitgo-beta/bls-dkg": "1.1.1-beta.338",
40
- "@bitgo-beta/sdk-lib-mpc": "8.2.0-beta.90",
41
- "@bitgo-beta/statics": "15.1.1-beta.101",
42
- "@bitgo-beta/utxo-lib": "8.0.3-beta.99",
43
- "@noble/secp256k1": "1.6.3",
40
+ "@bitgo-beta/sdk-lib-mpc": "8.2.0-beta.983",
41
+ "@bitgo-beta/secp256k1": "1.0.2-beta.1018",
42
+ "@bitgo-beta/sjcl": "1.0.2-beta.1230",
43
+ "@bitgo-beta/statics": "15.1.1-beta.994",
44
+ "@bitgo-beta/utxo-core": "1.8.1-beta.108",
45
+ "@bitgo-beta/utxo-lib": "8.0.3-beta.992",
46
+ "@bitgo/public-types": "5.1.0",
47
+ "@noble/curves": "1.8.1",
44
48
  "@stablelib/hex": "^1.0.0",
45
- "@types/elliptic": "^6.4.12",
46
- "@types/keccak": "^3.0.1",
47
49
  "@types/superagent": "4.1.15",
48
- "bech32": "^2.0.0",
49
50
  "big.js": "^3.1.3",
50
51
  "bigint-crypto-utils": "3.1.4",
51
- "bignumber.js": "^9.0.0",
52
- "bitcoinjs-message": "^2.0.0",
53
- "bolt11": "^1.4.0",
52
+ "bignumber.js": "^9.1.1",
54
53
  "bs58": "^4.0.1",
55
54
  "create-hmac": "^1.1.7",
56
55
  "debug": "^3.1.0",
57
- "elliptic": "^6.5.2",
58
56
  "ethereumjs-util": "7.1.5",
59
57
  "fp-ts": "^2.12.2",
60
- "io-ts": "^2.2.17",
61
- "keccak": "3.0.2",
58
+ "io-ts": "npm:@bitgo-forks/io-ts@2.1.4",
59
+ "io-ts-types": "^0.5.16",
60
+ "keccak": "3.0.3",
62
61
  "libsodium-wrappers-sumo": "^0.7.9",
63
62
  "lodash": "^4.17.15",
64
63
  "noble-bls12-381": "0.7.2",
65
- "openpgp": "5.1.0",
64
+ "openpgp": "5.11.3",
66
65
  "paillier-bigint": "3.3.0",
67
- "secp256k1": "^4.0.2",
66
+ "secp256k1": "5.0.1",
68
67
  "strip-hex-prefix": "^1.0.0",
69
- "superagent": "^3.8.3",
70
- "tweetnacl": "^1.0.3"
68
+ "superagent": "^9.0.1",
69
+ "tweetnacl": "^1.0.3",
70
+ "uuid": "^8.3.2"
71
71
  },
72
72
  "devDependencies": {
73
+ "@bitgo-beta/sdk-opensslbytes": "1.0.0-beta.544",
74
+ "@openpgp/web-stream-tools": "0.0.14",
75
+ "@types/keccak": "^3.0.5",
73
76
  "@types/lodash": "^4.14.151",
74
77
  "nyc": "^15.0.0"
75
78
  },
76
- "gitHead": "38f96b7f29a3d50a63bb6e884549cbf4e1a84cb1"
79
+ "gitHead": "ae90c82a4b3aab397aca13d62739eaadc595b2bd"
77
80
  }
@@ -1,77 +0,0 @@
1
- /// <reference types="node" />
2
- import { BaseKeyPair } from './baseKeyPair';
3
- import { AddressFormat } from './enum';
4
- import { BlsKeys, KeyPairOptions } from './iface';
5
- /**
6
- * Base class for BLS keypairs.
7
- */
8
- export declare abstract class BlsKeyPair implements BaseKeyPair {
9
- protected keyPair: BlsKeys;
10
- /**
11
- * Public constructor. By default, creates a key pair with a random polynomial.
12
- *
13
- * @param {KeyPairOptions} source Either a dkg options, a public and secret shares, or a private key
14
- */
15
- protected constructor(source?: KeyPairOptions);
16
- createShares(threshold: number, participants: number): void;
17
- /**
18
- * Note - this is not possible using BLS. BLS does not support prvkey derived key gen
19
- *
20
- * @param {string[]} prv a hexadecimal private key
21
- */
22
- recordKeysFromPrivateKey(prv: string): void;
23
- /**
24
- * Note - this is not possible using BLS. BLS does not support pubkey derived key gen
25
- *
26
- * @param {string} pub - An extended, compressed, or uncompressed public key
27
- */
28
- recordKeysFromPublicKey(pub: string): void;
29
- getAddress(format?: AddressFormat): string;
30
- getKeys(): any;
31
- /**
32
- * Signs bytes using the key pair
33
- *
34
- * @param msg The message bytes to sign
35
- * @return signature of the bytes using this keypair
36
- */
37
- sign(msg: Buffer): Promise<string>;
38
- static keyDerive(seed: string, pk: string, chaincode: string, path: string): BlsKeys;
39
- /**
40
- * Aggregates the secret shares of different key pairs into one private key
41
- *
42
- * @param prvKeys an array of secret shares
43
- * @returns a private key
44
- */
45
- static aggregatePrvkeys(prvKeys: string[]): string;
46
- /**
47
- * Aggregates the public shares of different key pairs into a common public key
48
- *
49
- * @param pubKeys an array of public shares
50
- * @returns a common public key
51
- */
52
- static aggregatePubkeys(pubKeys: string[]): string;
53
- static aggregateChaincodes(chaincodeContributions: string[]): string;
54
- /**
55
- * Aggregates the message signed by different key pairs into one sign
56
- *
57
- * @param signatures the message signed by different key pairs. The signer id is relevant to ensure a valid signature.
58
- * @example <caption> E.g., the message is signed by user and wallet, then signatures would be:</caption>
59
- * {
60
- * 1: BigInt(messageSignedWithUserPrv),
61
- * 3: BigInt(messageSignedWithWalletPrv),
62
- * }
63
- * @returns a signature combining all the provided signed messages
64
- */
65
- static aggregateSignatures(signatures: {
66
- [n: number]: bigint;
67
- }): string;
68
- /**
69
- * Verifies the signature for this key pair
70
- * @param pub The public key with which to verify the signature
71
- * @param msg The message to verify the signature with
72
- * @param signature the signature to verify
73
- * @return true if the signature is valid, else false
74
- */
75
- static verifySignature(pub: string, msg: Buffer, signature: string): Promise<boolean>;
76
- }
77
- //# sourceMappingURL=blsKeyPair.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"blsKeyPair.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/blsKeyPair.ts"],"names":[],"mappings":";AAGA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAEvC,OAAO,EAAE,OAAO,EAAE,cAAc,EAAiC,MAAM,SAAS,CAAC;AAMjF;;GAEG;AACH,8BAAsB,UAAW,YAAW,WAAW;IACrD,SAAS,CAAC,OAAO,EAAE,OAAO,CAAC;IAE3B;;;;OAIG;IACH,SAAS,aAAa,MAAM,CAAC,EAAE,cAAc;IAsB7C,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,IAAI;IAe3D;;;;OAIG;IACH,wBAAwB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAI3C;;;;OAIG;IACH,uBAAuB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAI1C,UAAU,CAAC,MAAM,CAAC,EAAE,aAAa,GAAG,MAAM;IAI1C,OAAO,IAAI,GAAG;IAId;;;;;OAKG;IACG,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;WAQ1B,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO;IAiB3F;;;;;OAKG;WACW,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM;IAWzD;;;;;OAKG;WACW,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM;WAU3C,mBAAmB,CAAC,sBAAsB,EAAE,MAAM,EAAE,GAAG,MAAM;IAU3E;;;;;;;;;;OAUG;WACW,mBAAmB,CAAC,UAAU,EAAE;QAAE,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,GAAG,MAAM;IAS9E;;;;;;OAMG;WACiB,eAAe,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;CAInG"}
@@ -1,209 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
- }) : (function(o, m, k, k2) {
6
- if (k2 === undefined) k2 = k;
7
- o[k2] = m[k];
8
- }));
9
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
- Object.defineProperty(o, "default", { enumerable: true, value: v });
11
- }) : function(o, v) {
12
- o["default"] = v;
13
- });
14
- var __importStar = (this && this.__importStar) || function (mod) {
15
- if (mod && mod.__esModule) return mod;
16
- var result = {};
17
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
- __setModuleDefault(result, mod);
19
- return result;
20
- };
21
- var __importDefault = (this && this.__importDefault) || function (mod) {
22
- return (mod && mod.__esModule) ? mod : { "default": mod };
23
- };
24
- Object.defineProperty(exports, "__esModule", { value: true });
25
- exports.BlsKeyPair = void 0;
26
- const assert_1 = __importDefault(require("assert"));
27
- const crypto_1 = require("crypto");
28
- const BLS = __importStar(require("@bitgo-beta/bls-dkg"));
29
- const errors_1 = require("./errors");
30
- const iface_1 = require("./iface");
31
- const crypto_2 = require("../util/crypto");
32
- const DEFAULT_SIGNATURE_THRESHOLD = 2;
33
- const DEFAULT_SIGNATURE_PARTICIPANTS = 3;
34
- /**
35
- * Base class for BLS keypairs.
36
- */
37
- class BlsKeyPair {
38
- /**
39
- * Public constructor. By default, creates a key pair with a random polynomial.
40
- *
41
- * @param {KeyPairOptions} source Either a dkg options, a public and secret shares, or a private key
42
- */
43
- constructor(source) {
44
- if (!source) {
45
- this.createShares(DEFAULT_SIGNATURE_THRESHOLD, DEFAULT_SIGNATURE_PARTICIPANTS);
46
- }
47
- else if (iface_1.isDkg(source)) {
48
- this.createShares(source.threshold, source.participants);
49
- }
50
- else if (iface_1.isBlsKey(source)) {
51
- assert_1.default(source.secretShares.every(crypto_2.isValidBLSPrivateKey), 'Invalid private keys');
52
- assert_1.default(crypto_2.isValidBLSPublicKey(source.publicShare), 'Invalid public key');
53
- this.keyPair = source;
54
- }
55
- else if (iface_1.isPrivateKey(source)) {
56
- this.keyPair = {
57
- prv: source.prv,
58
- publicShare: '',
59
- secretShares: [],
60
- seed: '',
61
- chaincode: '',
62
- };
63
- }
64
- else {
65
- throw new Error('Invalid key pair options');
66
- }
67
- }
68
- createShares(threshold, participants) {
69
- if (participants < threshold) {
70
- throw new Error('Participants should be greater than threshold');
71
- }
72
- const polynomial = BLS.generatePolynomial(threshold);
73
- const keySecretShares = BLS.secretShares(polynomial, participants);
74
- const keyPublicShare = BLS.publicShare(polynomial);
75
- this.keyPair = {
76
- seed: crypto_2.bigIntToHex(polynomial[0], 64),
77
- chaincode: crypto_1.randomBytes(32).toString('hex'),
78
- secretShares: keySecretShares.map((secretShare) => crypto_2.bigIntToHex(secretShare, 64)),
79
- publicShare: crypto_2.bigIntToHex(keyPublicShare),
80
- };
81
- }
82
- /**
83
- * Note - this is not possible using BLS. BLS does not support prvkey derived key gen
84
- *
85
- * @param {string[]} prv a hexadecimal private key
86
- */
87
- recordKeysFromPrivateKey(prv) {
88
- throw new errors_1.NotImplementedError('Private key derivation is not supported in bls');
89
- }
90
- /**
91
- * Note - this is not possible using BLS. BLS does not support pubkey derived key gen
92
- *
93
- * @param {string} pub - An extended, compressed, or uncompressed public key
94
- */
95
- recordKeysFromPublicKey(pub) {
96
- throw new errors_1.NotImplementedError('Public key derivation is not supported in bls');
97
- }
98
- getAddress(format) {
99
- throw new errors_1.NotImplementedError('getAddress not implemented');
100
- }
101
- getKeys() {
102
- throw new errors_1.NotImplementedError('getKeys not implemented');
103
- }
104
- /**
105
- * Signs bytes using the key pair
106
- *
107
- * @param msg The message bytes to sign
108
- * @return signature of the bytes using this keypair
109
- */
110
- async sign(msg) {
111
- if (this.keyPair.prv) {
112
- const signedMessage = await BLS.sign(msg, BigInt('0x' + this.keyPair.prv));
113
- return '0x' + crypto_2.bigIntToHex(signedMessage);
114
- }
115
- throw new Error('Missing private key');
116
- }
117
- static keyDerive(seed, pk, chaincode, path) {
118
- const seedBI = BigInt('0x' + seed);
119
- const pkBI = BigInt('0x' + pk);
120
- const chaincodeBI = BigInt('0x' + chaincode);
121
- const childKey = BLS.privateDerive(seedBI, pkBI, chaincodeBI, path);
122
- const childChaincode = crypto_2.bigIntToHex(childKey.chaincode);
123
- const entropy = BigInt('0x' + crypto_1.randomBytes(32).toString('hex'));
124
- const secretShares = BLS.secretShares([childKey.sk, entropy], DEFAULT_SIGNATURE_PARTICIPANTS);
125
- const publicShare = BLS.publicShare([childKey.sk]);
126
- return {
127
- seed,
128
- chaincode: childChaincode,
129
- secretShares: secretShares.map((secretShare) => crypto_2.bigIntToHex(secretShare)),
130
- publicShare: crypto_2.bigIntToHex(publicShare),
131
- };
132
- }
133
- /**
134
- * Aggregates the secret shares of different key pairs into one private key
135
- *
136
- * @param prvKeys an array of secret shares
137
- * @returns a private key
138
- */
139
- static aggregatePrvkeys(prvKeys) {
140
- assert_1.default(prvKeys.every(crypto_2.isValidBLSPrivateKey), 'Invalid private keys');
141
- try {
142
- const secretShares = prvKeys.map((secretShare) => BigInt('0x' + secretShare));
143
- const prv = BLS.mergeSecretShares(secretShares);
144
- return crypto_2.bigIntToHex(prv);
145
- }
146
- catch (e) {
147
- throw new Error('Error aggregating prvkeys: ' + e);
148
- }
149
- }
150
- /**
151
- * Aggregates the public shares of different key pairs into a common public key
152
- *
153
- * @param pubKeys an array of public shares
154
- * @returns a common public key
155
- */
156
- static aggregatePubkeys(pubKeys) {
157
- try {
158
- const publicShares = pubKeys.map((publicShare) => BigInt('0x' + publicShare));
159
- const commonPubKey = BLS.mergePublicShares(publicShares);
160
- return crypto_2.bigIntToHex(commonPubKey);
161
- }
162
- catch (e) {
163
- throw new Error('Error aggregating pubkeys: ' + e);
164
- }
165
- }
166
- static aggregateChaincodes(chaincodeContributions) {
167
- try {
168
- const chaincodes = chaincodeContributions.map((chaincode) => BigInt('0x' + chaincode));
169
- const commonChaincode = BLS.mergeChaincodes(chaincodes);
170
- return crypto_2.bigIntToHex(commonChaincode, 64);
171
- }
172
- catch (e) {
173
- throw new Error('Error aggregating chaincodes: ' + e);
174
- }
175
- }
176
- /**
177
- * Aggregates the message signed by different key pairs into one sign
178
- *
179
- * @param signatures the message signed by different key pairs. The signer id is relevant to ensure a valid signature.
180
- * @example <caption> E.g., the message is signed by user and wallet, then signatures would be:</caption>
181
- * {
182
- * 1: BigInt(messageSignedWithUserPrv),
183
- * 3: BigInt(messageSignedWithWalletPrv),
184
- * }
185
- * @returns a signature combining all the provided signed messages
186
- */
187
- static aggregateSignatures(signatures) {
188
- try {
189
- const signature = BLS.mergeSignatures(signatures);
190
- return '0x' + crypto_2.bigIntToHex(signature);
191
- }
192
- catch (e) {
193
- throw new Error('Error aggregating signatures: ' + e);
194
- }
195
- }
196
- /**
197
- * Verifies the signature for this key pair
198
- * @param pub The public key with which to verify the signature
199
- * @param msg The message to verify the signature with
200
- * @param signature the signature to verify
201
- * @return true if the signature is valid, else false
202
- */
203
- static async verifySignature(pub, msg, signature) {
204
- assert_1.default(crypto_2.isValidBLSPublicKey(pub), `Invalid public key: ${pub}`);
205
- return await BLS.verify(BigInt(signature), msg, BigInt('0x' + pub));
206
- }
207
- }
208
- exports.BlsKeyPair = BlsKeyPair;
209
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxzS2V5UGFpci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hY2NvdW50LWxpYi9iYXNlQ29pbi9ibHNLZXlQYWlyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxvREFBNEI7QUFDNUIsbUNBQXFDO0FBQ3JDLHlEQUEyQztBQUczQyxxQ0FBK0M7QUFDL0MsbUNBQWlGO0FBQ2pGLDJDQUF3RjtBQUV4RixNQUFNLDJCQUEyQixHQUFHLENBQUMsQ0FBQztBQUN0QyxNQUFNLDhCQUE4QixHQUFHLENBQUMsQ0FBQztBQUV6Qzs7R0FFRztBQUNILE1BQXNCLFVBQVU7SUFHOUI7Ozs7T0FJRztJQUNILFlBQXNCLE1BQXVCO1FBQzNDLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDWCxJQUFJLENBQUMsWUFBWSxDQUFDLDJCQUEyQixFQUFFLDhCQUE4QixDQUFDLENBQUM7U0FDaEY7YUFBTSxJQUFJLGFBQUssQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUN4QixJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1NBQzFEO2FBQU0sSUFBSSxnQkFBUSxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQzNCLGdCQUFNLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsNkJBQW9CLENBQUMsRUFBRSxzQkFBc0IsQ0FBQyxDQUFDO1lBQ2hGLGdCQUFNLENBQUMsNEJBQW1CLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxFQUFFLG9CQUFvQixDQUFDLENBQUM7WUFDdEUsSUFBSSxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUM7U0FDdkI7YUFBTSxJQUFJLG9CQUFZLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDL0IsSUFBSSxDQUFDLE9BQU8sR0FBRztnQkFDYixHQUFHLEVBQUUsTUFBTSxDQUFDLEdBQUc7Z0JBQ2YsV0FBVyxF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QU1HO0lBQ0ksTUFBTSxDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUMsR0FBVyxFQUFFLEdBQVcsRUFBRSxTQUFpQjtRQUM3RSxnQkFBTSxDQUFDLDRCQUFtQixDQUFDLEdBQUcsQ0FBQyxFQUFFLHVCQUF1QixHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQy9ELE9BQU8sTUFBTSxHQUFHLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsRUFBRSxHQUFHLEVBQUUsTUFBTSxDQUFDLElBQUksR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQ3RFLENBQUM7Q0FDRjtBQWhMRCxnQ0FnTEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5pbXBvcnQgeyByYW5kb21CeXRlcyB9IGZyb20gJ2NyeXB0byc7XG5pbXBvcnQgKiBhcyBCTFMgZnJvbSAnQGJpdGdvLWJldGEvYmxzLWRrZyc7XG5pbXBvcnQgeyBCYXNlS2V5UGFpciB9IGZyb20gJy4vYmFzZUtleVBhaXInO1xuaW1wb3J0IHsgQWRkcmVzc0Zvcm1hdCB9IGZyb20gJy4vZW51bSc7XG5pbXBvcnQgeyBOb3RJbXBsZW1lbnRlZEVycm9yIH0gZnJvbSAnLi9lcnJvcnMnO1xuaW1wb3J0IHsgQmxzS2V5cywgS2V5UGFpck9wdGlvbnMsIGlzRGtnLCBpc0Jsc0tleSwgaXNQcml2YXRlS2V5IH0gZnJvbSAnLi9pZmFjZSc7XG5pbXBvcnQgeyBpc1ZhbGlkQkxTUHVibGljS2V5LCBpc1ZhbGlkQkxTUHJpdmF0ZUtleSwgYmlnSW50VG9IZXggfSBmcm9tICcuLi91dGlsL2NyeXB0byc7XG5cbmNvbnN0IERFRkFVTFRfU0lHTkFUVVJFX1RIUkVTSE9MRCA9IDI7XG5jb25zdCBERUZBVUxUX1NJR05BVFVSRV9QQVJUSUNJUEFOVFMgPSAzO1xuXG4vKipcbiAqIEJhc2UgY2xhc3MgZm9yIEJMUyBrZXlwYWlycy5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJsc0tleVBhaXIgaW1wbGVtZW50cyBCYXNlS2V5UGFpciB7XG4gIHByb3RlY3RlZCBrZXlQYWlyOiBCbHNLZXlzO1xuXG4gIC8qKlxuICAgKiBQdWJsaWMgY29uc3RydWN0b3IuIEJ5IGRlZmF1bHQsIGNyZWF0ZXMgYSBrZXkgcGFpciB3aXRoIGEgcmFuZG9tIHBvbHlub21pYWwuXG4gICAqXG4gICAqIEBwYXJhbSB7S2V5UGFpck9wdGlvbnN9IHNvdXJjZSBFaXRoZXIgYSBka2cgb3B0aW9ucywgYSBwdWJsaWMgYW5kIHNlY3JldCBzaGFyZXMsIG9yIGEgcHJpdmF0ZSBrZXlcbiAgICovXG4gIHByb3RlY3RlZCBjb25zdHJ1Y3Rvcihzb3VyY2U/OiBLZXlQYWlyT3B0aW9ucykge1xuICAgIGlmICghc291cmNlKSB7XG4gICAgICB0aGlzLmNyZWF0ZVNoYXJlcyhERUZBVUxUX1NJR05BVFVSRV9USFJFU0hPTEQsIERFRkFVTFRfU0lHTkFUVVJFX1BBUlRJQ0lQQU5UUyk7XG4gICAgfSBlbHNlIGlmIChpc0RrZyhzb3VyY2UpKSB7XG4gICAgICB0aGlzLmNyZWF0ZVNoYXJlcyhzb3VyY2UudGhyZXNob2xkLCBzb3VyY2UucGFydGljaXBhbnRzKTtcbiAgICB9IGVsc2UgaWYgKGlzQmxzS2V5KHNvdXJjZSkpIHtcbiAgICAgIGFzc2VydChzb3VyY2Uuc2VjcmV0U2hhcmVzLmV2ZXJ5KGlzVmFsaWRCTFNQcml2YXRlS2V5KSwgJ0ludmFsaWQgcHJpdmF0ZSBrZXlzJyk7XG4gICAgICBhc3NlcnQoaXNWYWxpZEJMU1B1YmxpY0tleShzb3VyY2UucHVibGljU2hhcmUpLCAnSW52YWxpZCBwdWJsaWMga2V5Jyk7XG4gICAgICB0aGlzLmtleVBhaXIgPSBzb3VyY2U7XG4gICAgfSBlbHNlIGlmIChpc1ByaXZhdGVLZXkoc291cmNlKSkge1xuICAgICAgdGhpcy5rZXlQYWlyID0ge1xuICAgICAgICBwcnY6IHNvdXJjZS5wcnYsXG4gICAgICAgIHB1YmxpY1NoYXJlOiAnJyxcbiAgICAgICAgc2VjcmV0U2hhcmVzOiBbXSxcbiAgICAgICAgc2VlZDogJycsXG4gICAgICAgIGNoYWluY29kZTogJycsXG4gICAgICB9O1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQga2V5IHBhaXIgb3B0aW9ucycpO1xuICAgIH1cbiAgfVxuXG4gIGNyZWF0ZVNoYXJlcyh0aHJlc2hvbGQ6IG51bWJlciwgcGFydGljaXBhbnRzOiBudW1iZXIpOiB2b2lkIHtcbiAgICBpZiAocGFydGljaXBhbnRzIDwgdGhyZXNob2xkKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ1BhcnRpY2lwYW50cyBzaG91bGQgYmUgZ3JlYXRlciB0aGFuIHRocmVzaG9sZCcpO1xuICAgIH1cbiAgICBjb25zdCBwb2x5bm9taWFsID0gQkxTLmdlbmVyYXRlUG9seW5vbWlhbCh0aHJlc2hvbGQpO1xuICAgIGNvbnN0IGtleVNlY3JldFNoYXJlcyA9IEJMUy5zZWNyZXRTaGFyZXMocG9seW5vbWlhbCwgcGFydGljaXBhbnRzKTtcbiAgICBjb25zdCBrZXlQdWJsaWNTaGFyZSA9IEJMUy5wdWJsaWNTaGFyZShwb2x5bm9taWFsKTtcbiAgICB0aGlzLmtleVBhaXIgPSB7XG4gICAgICBzZWVkOiBiaWdJbnRUb0hleChwb2x5bm9taWFsWzBdLCA2NCksXG4gICAgICBjaGFpbmNvZGU6IHJhbmRvbUJ5dGVzKDMyKS50b1N0cmluZygnaGV4JyksXG4gICAgICBzZWNyZXRTaGFyZXM6IGtleVNlY3JldFNoYXJlcy5tYXAoKHNlY3JldFNoYXJlKSA9PiBiaWdJbnRUb0hleChzZWNyZXRTaGFyZSwgNjQpKSxcbiAgICAgIHB1YmxpY1NoYXJlOiBiaWdJbnRUb0hleChrZXlQdWJsaWNTaGFyZSksXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBOb3RlIC0gdGhpcyBpcyBub3QgcG9zc2libGUgdXNpbmcgQkxTLiBCTFMgZG9lcyBub3Qgc3VwcG9ydCBwcnZrZXkgZGVyaXZlZCBrZXkgZ2VuXG4gICAqXG4gICAqIEBwYXJhbSB7c3RyaW5nW119IHBydiBhIGhleGFkZWNpbWFsIHByaXZhdGUga2V5XG4gICAqL1xuICByZWNvcmRLZXlzRnJvbVByaXZhdGVLZXkocHJ2OiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aHJvdyBuZXcgTm90SW1wbGVtZW50ZWRFcnJvcignUHJpdmF0ZSBrZXkgZGVyaXZhdGlvbiBpcyBub3Qgc3VwcG9ydGVkIGluIGJscycpO1xuICB9XG5cbiAgLyoqXG4gICAqIE5vdGUgLSB0aGlzIGlzIG5vdCBwb3NzaWJsZSB1c2luZyBCTFMuIEJMUyBkb2VzIG5vdCBzdXBwb3J0IHB1YmtleSBkZXJpdmVkIGtleSBnZW5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IHB1YiAtIEFuIGV4dGVuZGVkLCBjb21wcmVzc2VkLCBvciB1bmNvbXByZXNzZWQgcHVibGljIGtleVxuICAgKi9cbiAgcmVjb3JkS2V5c0Zyb21QdWJsaWNLZXkocHViOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aHJvdyBuZXcgTm90SW1wbGVtZW50ZWRFcnJvcignUHVibGljIGtleSBkZXJpdmF0aW9uIGlzIG5vdCBzdXBwb3J0ZWQgaW4gYmxzJyk7XG4gIH1cblxuICBnZXRBZGRyZXNzKGZvcm1hdD86IEFkZHJlc3NGb3JtYXQpOiBzdHJpbmcge1xuICAgIHRocm93IG5ldyBOb3RJbXBsZW1lbnRlZEVycm9yKCdnZXRBZGRyZXNzIG5vdCBpbXBsZW1lbnRlZCcpO1xuICB9XG5cbiAgZ2V0S2V5cygpOiBhbnkge1xuICAgIHRocm93IG5ldyBOb3RJbXBsZW1lbnRlZEVycm9yKCdnZXRLZXlzIG5vdCBpbXBsZW1lbnRlZCcpO1xuICB9XG5cbiAgLyoqXG4gICAqIFNpZ25zIGJ5dGVzIHVzaW5nIHRoZSBrZXkgcGFpclxuICAgKlxuICAgKiBAcGFyYW0gbXNnIFRoZSBtZXNzYWdlIGJ5dGVzIHRvIHNpZ25cbiAgICogQHJldHVybiBzaWduYXR1cmUgb2YgdGhlIGJ5dGVzIHVzaW5nIHRoaXMga2V5cGFpclxuICAgKi9cbiAgYXN5bmMgc2lnbihtc2c6IEJ1ZmZlcik6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgaWYgKHRoaXMua2V5UGFpci5wcnYpIHtcbiAgICAgIGNvbnN0IHNpZ25lZE1lc3NhZ2UgPSBhd2FpdCBCTFMuc2lnbihtc2csIEJpZ0ludCgnMHgnICsgdGhpcy5rZXlQYWlyLnBydikpO1xuICAgICAgcmV0dXJuICcweCcgKyBiaWdJbnRUb0hleChzaWduZWRNZXNzYWdlKTtcbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNaXNzaW5nIHByaXZhdGUga2V5Jyk7XG4gIH1cblxuICBwdWJsaWMgc3RhdGljIGtleURlcml2ZShzZWVkOiBzdHJpbmcsIHBrOiBzdHJpbmcsIGNoYWluY29kZTogc3RyaW5nLCBwYXRoOiBzdHJpbmcpOiBCbHNLZXlzIHtcbiAgICBjb25zdCBzZWVkQkkgPSBCaWdJbnQoJzB4JyArIHNlZWQpO1xuICAgIGNvbnN0IHBrQkkgPSBCaWdJbnQoJzB4JyArIHBrKTtcbiAgICBjb25zdCBjaGFpbmNvZGVCSSA9IEJpZ0ludCgnMHgnICsgY2hhaW5jb2RlKTtcbiAgICBjb25zdCBjaGlsZEtleSA9IEJMUy5wcml2YXRlRGVyaXZlKHNlZWRCSSwgcGtCSSwgY2hhaW5jb2RlQkksIHBhdGgpO1xuICAgIGNvbnN0IGNoaWxkQ2hhaW5jb2RlID0gYmlnSW50VG9IZXgoY2hpbGRLZXkuY2hhaW5jb2RlKTtcbiAgICBjb25zdCBlbnRyb3B5ID0gQmlnSW50KCcweCcgKyByYW5kb21CeXRlcygzMikudG9TdHJpbmcoJ2hleCcpKTtcbiAgICBjb25zdCBzZWNyZXRTaGFyZXMgPSBCTFMuc2VjcmV0U2hhcmVzKFtjaGlsZEtleS5zaywgZW50cm9weV0sIERFRkFVTFRfU0lHTkFUVVJFX1BBUlRJQ0lQQU5UUyk7XG4gICAgY29uc3QgcHVibGljU2hhcmUgPSBCTFMucHVibGljU2hhcmUoW2NoaWxkS2V5LnNrXSk7XG4gICAgcmV0dXJuIHtcbiAgICAgIHNlZWQsXG4gICAgICBjaGFpbmNvZGU6IGNoaWxkQ2hhaW5jb2RlLFxuICAgICAgc2VjcmV0U2hhcmVzOiBzZWNyZXRTaGFyZXMubWFwKChzZWNyZXRTaGFyZSkgPT4gYmlnSW50VG9IZXgoc2VjcmV0U2hhcmUpKSxcbiAgICAgIHB1YmxpY1NoYXJlOiBiaWdJbnRUb0hleChwdWJsaWNTaGFyZSksXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBBZ2dyZWdhdGVzIHRoZSBzZWNyZXQgc2hhcmVzIG9mIGRpZmZlcmVudCBrZXkgcGFpcnMgaW50byBvbmUgcHJpdmF0ZSBrZXlcbiAgICpcbiAgICogQHBhcmFtIHBydktleXMgYW4gYXJyYXkgb2Ygc2VjcmV0IHNoYXJlc1xuICAgKiBAcmV0dXJucyBhIHByaXZhdGUga2V5XG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGFnZ3JlZ2F0ZVBydmtleXMocHJ2S2V5czogc3RyaW5nW10pOiBzdHJpbmcge1xuICAgIGFzc2VydChwcnZLZXlzLmV2ZXJ5KGlzVmFsaWRCTFNQcml2YXRlS2V5KSwgJ0ludmFsaWQgcHJpdmF0ZSBrZXlzJyk7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IHNlY3JldFNoYXJlcyA9IHBydktleXMubWFwKChzZWNyZXRTaGFyZSkgPT4gQmlnSW50KCcweCcgKyBzZWNyZXRTaGFyZSkpO1xuICAgICAgY29uc3QgcHJ2ID0gQkxTLm1lcmdlU2VjcmV0U2hhcmVzKHNlY3JldFNoYXJlcyk7XG4gICAgICByZXR1cm4gYmlnSW50VG9IZXgocHJ2KTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0Vycm9yIGFnZ3JlZ2F0aW5nIHBydmtleXM6ICcgKyBlKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogQWdncmVnYXRlcyB0aGUgcHVibGljIHNoYXJlcyBvZiBkaWZmZXJlbnQga2V5IHBhaXJzIGludG8gYSBjb21tb24gcHVibGljIGtleVxuICAgKlxuICAgKiBAcGFyYW0gcHViS2V5cyBhbiBhcnJheSBvZiBwdWJsaWMgc2hhcmVzXG4gICAqIEByZXR1cm5zIGEgY29tbW9uIHB1YmxpYyBrZXlcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgYWdncmVnYXRlUHVia2V5cyhwdWJLZXlzOiBzdHJpbmdbXSk6IHN0cmluZyB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IHB1YmxpY1NoYXJlcyA9IHB1YktleXMubWFwKChwdWJsaWNTaGFyZSkgPT4gQmlnSW50KCcweCcgKyBwdWJsaWNTaGFyZSkpO1xuICAgICAgY29uc3QgY29tbW9uUHViS2V5ID0gQkxTLm1lcmdlUHVibGljU2hhcmVzKHB1YmxpY1NoYXJlcyk7XG4gICAgICByZXR1cm4gYmlnSW50VG9IZXgoY29tbW9uUHViS2V5KTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0Vycm9yIGFnZ3JlZ2F0aW5nIHB1YmtleXM6ICcgKyBlKTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgc3RhdGljIGFnZ3JlZ2F0ZUNoYWluY29kZXMoY2hhaW5jb2RlQ29udHJpYnV0aW9uczogc3RyaW5nW10pOiBzdHJpbmcge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCBjaGFpbmNvZGVzID0gY2hhaW5jb2RlQ29udHJpYnV0aW9ucy5tYXAoKGNoYWluY29kZSkgPT4gQmlnSW50KCcweCcgKyBjaGFpbmNvZGUpKTtcbiAgICAgIGNvbnN0IGNvbW1vbkNoYWluY29kZSA9IEJMUy5tZXJnZUNoYWluY29kZXMoY2hhaW5jb2Rlcyk7XG4gICAgICByZXR1cm4gYmlnSW50VG9IZXgoY29tbW9uQ2hhaW5jb2RlLCA2NCk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdFcnJvciBhZ2dyZWdhdGluZyBjaGFpbmNvZGVzOiAnICsgZSk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEFnZ3JlZ2F0ZXMgdGhlIG1lc3NhZ2Ugc2lnbmVkIGJ5IGRpZmZlcmVudCBrZXkgcGFpcnMgaW50byBvbmUgc2lnblxuICAgKlxuICAgKiBAcGFyYW0gc2lnbmF0dXJlcyB0aGUgbWVzc2FnZSBzaWduZWQgYnkgZGlmZmVyZW50IGtleSBwYWlycy4gVGhlIHNpZ25lciBpZCBpcyByZWxldmFudCB0byBlbnN1cmUgYSB2YWxpZCBzaWduYXR1cmUuXG4gICAqIEBleGFtcGxlIDxjYXB0aW9uPiBFLmcuLCB0aGUgbWVzc2FnZSBpcyBzaWduZWQgYnkgdXNlciBhbmQgd2FsbGV0LCB0aGVuIHNpZ25hdHVyZXMgd291bGQgYmU6PC9jYXB0aW9uPlxuICAgKiB7XG4gICAqICAgMTogQmlnSW50KG1lc3NhZ2VTaWduZWRXaXRoVXNlclBydiksXG4gICAqICAgMzogQmlnSW50KG1lc3NhZ2VTaWduZWRXaXRoV2FsbGV0UHJ2KSxcbiAgICogfVxuICAgKiBAcmV0dXJucyBhIHNpZ25hdHVyZSBjb21iaW5pbmcgYWxsIHRoZSBwcm92aWRlZCBzaWduZWQgbWVzc2FnZXNcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgYWdncmVnYXRlU2lnbmF0dXJlcyhzaWduYXR1cmVzOiB7IFtuOiBudW1iZXJdOiBiaWdpbnQgfSk6IHN0cmluZyB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IHNpZ25hdHVyZSA9IEJMUy5tZXJnZVNpZ25hdHVyZXMoc2lnbmF0dXJlcyk7XG4gICAgICByZXR1cm4gJzB4JyArIGJpZ0ludFRvSGV4KHNpZ25hdHVyZSk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdFcnJvciBhZ2dyZWdhdGluZyBzaWduYXR1cmVzOiAnICsgZSk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFZlcmlmaWVzIHRoZSBzaWduYXR1cmUgZm9yIHRoaXMga2V5IHBhaXJcbiAgICogQHBhcmFtIHB1YiBUaGUgcHVibGljIGtleSB3aXRoIHdoaWNoIHRvIHZlcmlmeSB0aGUgc2lnbmF0dXJlXG4gICAqIEBwYXJhbSBtc2cgVGhlIG1lc3NhZ2UgdG8gdmVyaWZ5IHRoZSBzaWduYXR1cmUgd2l0aFxuICAgKiBAcGFyYW0gc2lnbmF0dXJlIHRoZSBzaWduYXR1cmUgdG8gdmVyaWZ5XG4gICAqIEByZXR1cm4gdHJ1ZSBpZiB0aGUgc2lnbmF0dXJlIGlzIHZhbGlkLCBlbHNlIGZhbHNlXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGFzeW5jIHZlcmlmeVNpZ25hdHVyZShwdWI6IHN0cmluZywgbXNnOiBCdWZmZXIsIHNpZ25hdHVyZTogc3RyaW5nKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgYXNzZXJ0KGlzVmFsaWRCTFNQdWJsaWNLZXkocHViKSwgYEludmFsaWQgcHVibGljIGtleTogJHtwdWJ9YCk7XG4gICAgcmV0dXJuIGF3YWl0IEJMUy52ZXJpZnkoQmlnSW50KHNpZ25hdHVyZSksIG1zZywgQmlnSW50KCcweCcgKyBwdWIpKTtcbiAgfVxufVxuIl19
@@ -1,31 +0,0 @@
1
- import { Ed25519Curve } from './curves';
2
- import { Secp256k1Curve } from '@bitgo-beta/sdk-lib-mpc';
3
- export declare const chaincodeBase: bigint;
4
- interface PrivateKeychain {
5
- pk: bigint;
6
- sk: bigint;
7
- prefix?: bigint;
8
- chaincode: bigint;
9
- }
10
- export interface PublicKeychain {
11
- pk: bigint;
12
- chaincode: bigint;
13
- }
14
- interface HDTree {
15
- publicDerive(keychain: PublicKeychain, path: string): PublicKeychain;
16
- privateDerive(keychain: PrivateKeychain, path: string): PrivateKeychain;
17
- }
18
- export default HDTree;
19
- export declare class Ed25519BIP32 {
20
- static curve: Ed25519Curve;
21
- static initialized: boolean;
22
- static initialize(): Promise<Ed25519BIP32>;
23
- publicDerive(keychain: PublicKeychain, path: string): PublicKeychain;
24
- privateDerive(keychain: PrivateKeychain, path: string): PrivateKeychain;
25
- }
26
- export declare class BIP32 {
27
- static curve: Secp256k1Curve;
28
- publicDerive(keychain: PublicKeychain, path: string): PublicKeychain;
29
- privateDerive(keychain: PrivateKeychain, path: string): PrivateKeychain;
30
- }
31
- //# sourceMappingURL=hdTree.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hdTree.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/mpc/hdTree.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAIzD,eAAO,MAAM,aAAa,QAAiF,CAAC;AAE5G,UAAU,eAAe;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,UAAU,MAAM;IACd,YAAY,CAAC,QAAQ,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,GAAG,cAAc,CAAC;IAErE,aAAa,CAAC,QAAQ,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,GAAG,eAAe,CAAC;CACzE;AAED,eAAe,MAAM,CAAC;AAyCtB,qBAAa,YAAY;IACvB,MAAM,CAAC,KAAK,EAAE,YAAY,CAAsB;IAChD,MAAM,CAAC,WAAW,UAAS;WAEd,UAAU,IAAI,OAAO,CAAC,YAAY,CAAC;IAShD,YAAY,CAAC,QAAQ,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,GAAG,cAAc;IAepE,aAAa,CAAC,QAAQ,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,GAAG,eAAe;CAqBxE;AAiBD,qBAAa,KAAK;IAChB,MAAM,CAAC,KAAK,EAAE,cAAc,CAAwB;IAEpD,YAAY,CAAC,QAAQ,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,GAAG,cAAc;IAiBpE,aAAa,CAAC,QAAQ,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,GAAG,eAAe;CAiBxE"}
@@ -1,141 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BIP32 = exports.Ed25519BIP32 = exports.chaincodeBase = void 0;
4
- /**
5
- * An interface for calculating a subkey in an HD key scheme.
6
- */
7
- const crypto_1 = require("crypto");
8
- const curves_1 = require("./curves");
9
- const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
10
- const util_1 = require("./util");
11
- // 2^256
12
- exports.chaincodeBase = BigInt('0x010000000000000000000000000000000000000000000000000000000000000000');
13
- function deriveEd25519Helper(index = 0, chaincode, pk, sk) {
14
- const zmac = crypto_1.createHmac('sha512', util_1.bigIntToBufferBE(chaincode, 32));
15
- const imac = crypto_1.createHmac('sha512', util_1.bigIntToBufferBE(chaincode, 32));
16
- const seri = Buffer.alloc(4);
17
- seri.writeUInt32LE(index, 0);
18
- if (((index >>> 0) & 0x80000000) === 0) {
19
- // Normal derivation:
20
- // Z = HMAC-SHA512(Key = cpar, Data = 0x02 || serP(point(kpar)) || ser32(i)).
21
- // I = HMAC-SHA512(Key = cpar, Data = 0x03 || serP(point(kpar)) || ser32(i)).
22
- zmac.update('\x02');
23
- zmac.update(util_1.bigIntToBufferLE(pk, 32));
24
- zmac.update(seri);
25
- imac.update('\x03');
26
- imac.update(util_1.bigIntToBufferLE(pk, 32));
27
- imac.update(seri);
28
- }
29
- else {
30
- if (sk === undefined) {
31
- throw new Error("Can't performed hardened derivation without private key");
32
- }
33
- // Hardened derivation:
34
- // Z = HMAC-SHA512(Key = cpar, Data = 0x00 || ser256(left(kpar)) || ser32(i)).
35
- // I = HMAC-SHA512(Key = cpar, Data = 0x01 || ser256(left(kpar)) || ser32(i)).
36
- zmac.update('\x00');
37
- zmac.update(util_1.bigIntToBufferLE(sk, 32));
38
- zmac.update(seri);
39
- imac.update('\x01');
40
- imac.update(util_1.bigIntToBufferLE(sk, 32));
41
- imac.update(seri);
42
- }
43
- return [zmac.digest(), imac.digest()];
44
- }
45
- function pathToIndices(path) {
46
- return path
47
- .replace(/^m?\//, '')
48
- .split('/')
49
- .map((index) => parseInt(index, 10));
50
- }
51
- class Ed25519BIP32 {
52
- static async initialize() {
53
- if (!Ed25519BIP32.initialized) {
54
- await curves_1.Ed25519Curve.initialize();
55
- Ed25519BIP32.initialized = true;
56
- }
57
- return new Ed25519BIP32();
58
- }
59
- publicDerive(keychain, path) {
60
- const indices = pathToIndices(path);
61
- function deriveIndex(acc, index) {
62
- const [pk, chaincode] = acc;
63
- const [zout, iout] = deriveEd25519Helper(index, chaincode, pk);
64
- const zl = zout.slice(0, 32);
65
- // left = kl + 8 * trunc28(zl)
66
- const t = BigInt(8) * util_1.bigIntFromBufferLE(zl.slice(0, 28));
67
- const left = Ed25519BIP32.curve.pointAdd(pk, Ed25519BIP32.curve.basePointMult(t));
68
- return [left, util_1.bigIntFromBufferBE(iout.slice(32))];
69
- }
70
- const subkey = indices.reduce(deriveIndex, deriveIndex([keychain.pk, keychain.chaincode], indices.shift()));
71
- return { pk: subkey[0], chaincode: subkey[1] };
72
- }
73
- privateDerive(keychain, path) {
74
- const indices = pathToIndices(path);
75
- function deriveIndex(acc, index) {
76
- const [pk, sk, prefix, chaincode] = acc;
77
- const [zout, iout] = deriveEd25519Helper(index, chaincode, pk, sk);
78
- const zl = zout.slice(0, 32);
79
- const zr = zout.slice(32);
80
- // left = kl + 8 * trunc28(zl)
81
- const t = BigInt(8) * util_1.bigIntFromBufferLE(zl.slice(0, 28));
82
- const left_pk = Ed25519BIP32.curve.pointAdd(pk, Ed25519BIP32.curve.basePointMult(t));
83
- const left_sk = Ed25519BIP32.curve.scalarAdd(sk, t);
84
- // right = zr + kr
85
- const right = (prefix + util_1.bigIntFromBufferBE(zr)) % exports.chaincodeBase;
86
- return [left_pk, left_sk, right, util_1.bigIntFromBufferBE(iout.slice(32))];
87
- }
88
- const [pk, sk, prefix, chaincode] = indices.reduce(deriveIndex, deriveIndex([keychain.pk, keychain.sk, keychain.prefix, keychain.chaincode], indices.shift()));
89
- return { pk, sk, prefix, chaincode };
90
- }
91
- }
92
- exports.Ed25519BIP32 = Ed25519BIP32;
93
- Ed25519BIP32.curve = new curves_1.Ed25519Curve();
94
- Ed25519BIP32.initialized = false;
95
- function deriveSecp256k1Helper(index = 0, chaincode, pk, sk) {
96
- const data = Buffer.alloc(33 + 4);
97
- if (((index >>> 0) & 0x80000000) === 0) {
98
- util_1.bigIntToBufferBE(pk, 33).copy(data);
99
- }
100
- else {
101
- if (sk === undefined) {
102
- throw new Error("Can't performed hardened derivation without private key");
103
- }
104
- data[0] = 0;
105
- util_1.bigIntToBufferBE(sk, 32).copy(data, 1);
106
- }
107
- data.writeUInt32BE(index, 33);
108
- return crypto_1.createHmac('sha512', util_1.bigIntToBufferBE(chaincode, 32)).update(data).digest();
109
- }
110
- class BIP32 {
111
- publicDerive(keychain, path) {
112
- const indices = pathToIndices(path);
113
- function deriveIndex(acc, index) {
114
- const [pk, chaincode] = acc;
115
- const I = deriveSecp256k1Helper(index, chaincode, pk);
116
- const il = util_1.bigIntFromBufferBE(I.slice(0, 32));
117
- const ir = util_1.bigIntFromBufferBE(I.slice(32));
118
- const left_pk = BIP32.curve.pointAdd(pk, BIP32.curve.basePointMult(il));
119
- return [left_pk, ir];
120
- }
121
- const [pk, chaincode] = indices.reduce(deriveIndex, deriveIndex([keychain.pk, keychain.chaincode], indices.shift()));
122
- return { pk, chaincode };
123
- }
124
- privateDerive(keychain, path) {
125
- const indices = pathToIndices(path);
126
- function deriveIndex(acc, index) {
127
- const [pk, sk, chaincode] = acc;
128
- const I = deriveSecp256k1Helper(index, chaincode, pk, sk);
129
- const il = util_1.bigIntFromBufferBE(I.slice(0, 32));
130
- const ir = util_1.bigIntFromBufferBE(I.slice(32));
131
- const left_pk = BIP32.curve.pointAdd(pk, BIP32.curve.basePointMult(il));
132
- const left_sk = BIP32.curve.scalarAdd(sk, il);
133
- return [left_pk, left_sk, ir];
134
- }
135
- const [pk, sk, chaincode] = indices.reduce(deriveIndex, deriveIndex([keychain.pk, keychain.sk, keychain.chaincode], indices.shift()));
136
- return { pk, sk, chaincode };
137
- }
138
- }
139
- exports.BIP32 = BIP32;
140
- BIP32.curve = new sdk_lib_mpc_1.Secp256k1Curve();
141
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGRUcmVlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FjY291bnQtbGliL21wYy9oZFRyZWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUE7O0dBRUc7QUFDSCxtQ0FBb0M7QUFDcEMscUNBQXdDO0FBQ3hDLHlEQUF5RDtBQUN6RCxpQ0FBb0c7QUFFcEcsUUFBUTtBQUNLLFFBQUEsYUFBYSxHQUFHLE1BQU0sQ0FBQyxzRUFBc0UsQ0FBQyxDQUFDO0FBc0I1RyxTQUFTLG1CQUFtQixDQUFDLFFBQTRCLENBQUMsRUFBRSxTQUFpQixFQUFFLEVBQVUsRUFBRSxFQUFXO0lBQ3BHLE1BQU0sSUFBSSxHQUFHLG1CQUFVLENBQUMsUUFBUSxFQUFFLHVCQUFnQixDQUFDLFNBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ25FLE1BQU0sSUFBSSxHQUFHLG1CQUFVLENBQUMsUUFBUSxFQUFFLHVCQUFnQixDQUFDLFNBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ25FLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDN0IsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDN0IsSUFBSSxDQUFDLENBQUMsS0FBSyxLQUFLLENBQUMsQ0FBQyxHQUFHLFVBQVUsQ0FBQyxLQUFLLENBQUMsRUFBRTtRQUN0QyxxQkFBcUI7UUFDckIsNkVBQTZFO1FBQzdFLDZFQUE2RTtRQUM3RSxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3BCLElBQUksQ0FBQyxNQUFNLENBQUMsdUJBQWdCLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDdEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNsQixJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3BCLElB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QUFRLENBQUMsRUFBRSxFQUFFLFFBQVEsQ0FBQyxFQUFFLEVBQUUsUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUM3RSxDQUFDO1FBQ0YsT0FBTyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsU0FBUyxFQUFFLENBQUM7SUFDL0IsQ0FBQzs7QUFwQ0gsc0JBcUNDO0FBcENRLFdBQUssR0FBbUIsSUFBSSw0QkFBYyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEFuIGludGVyZmFjZSBmb3IgY2FsY3VsYXRpbmcgYSBzdWJrZXkgaW4gYW4gSEQga2V5IHNjaGVtZS5cbiAqL1xuaW1wb3J0IHsgY3JlYXRlSG1hYyB9IGZyb20gJ2NyeXB0byc7XG5pbXBvcnQgeyBFZDI1NTE5Q3VydmUgfSBmcm9tICcuL2N1cnZlcyc7XG5pbXBvcnQgeyBTZWNwMjU2azFDdXJ2ZSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1saWItbXBjJztcbmltcG9ydCB7IGJpZ0ludEZyb21CdWZmZXJCRSwgYmlnSW50VG9CdWZmZXJCRSwgYmlnSW50RnJvbUJ1ZmZlckxFLCBiaWdJbnRUb0J1ZmZlckxFIH0gZnJvbSAnLi91dGlsJztcblxuLy8gMl4yNTZcbmV4cG9ydCBjb25zdCBjaGFpbmNvZGVCYXNlID0gQmlnSW50KCcweDAxMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMCcpO1xuXG5pbnRlcmZhY2UgUHJpdmF0ZUtleWNoYWluIHtcbiAgcGs6IGJpZ2ludDtcbiAgc2s6IGJpZ2ludDtcbiAgcHJlZml4PzogYmlnaW50O1xuICBjaGFpbmNvZGU6IGJpZ2ludDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQdWJsaWNLZXljaGFpbiB7XG4gIHBrOiBiaWdpbnQ7XG4gIGNoYWluY29kZTogYmlnaW50O1xufVxuXG5pbnRlcmZhY2UgSERUcmVlIHtcbiAgcHVibGljRGVyaXZlKGtleWNoYWluOiBQdWJsaWNLZXljaGFpbiwgcGF0aDogc3RyaW5nKTogUHVibGljS2V5Y2hhaW47XG5cbiAgcHJpdmF0ZURlcml2ZShrZXljaGFpbjogUHJpdmF0ZUtleWNoYWluLCBwYXRoOiBzdHJpbmcpOiBQcml2YXRlS2V5Y2hhaW47XG59XG5cbmV4cG9ydCBkZWZhdWx0IEhEVHJlZTtcblxuZnVuY3Rpb24gZGVyaXZlRWQyNTUxOUhlbHBlcihpbmRleDogbnVtYmVyIHwgdW5kZWZpbmVkID0gMCwgY2hhaW5jb2RlOiBiaWdpbnQsIHBrOiBiaWdpbnQsIHNrPzogYmlnaW50KTogQnVmZmVyW10ge1xuICBjb25zdCB6bWFjID0gY3JlYXRlSG1hYygnc2hhNTEyJywgYmlnSW50VG9CdWZmZXJCRShjaGFpbmNvZGUsIDMyKSk7XG4gIGNvbnN0IGltYWMgPSBjcmVhdGVIbWFjKCdzaGE1MTInLCBiaWdJbnRUb0J1ZmZlckJFKGNoYWluY29kZSwgMzIpKTtcbiAgY29uc3Qgc2VyaSA9IEJ1ZmZlci5hbGxvYyg0KTtcbiAgc2VyaS53cml0ZVVJbnQzMkxFKGluZGV4LCAwKTtcbiAgaWYgKCgoaW5kZXggPj4+IDApICYgMHg4MDAwMDAwMCkgPT09IDApIHtcbiAgICAvLyBOb3JtYWwgZGVyaXZhdGlvbjpcbiAgICAvLyBaID0gSE1BQy1TSEE1MTIoS2V5ID0gY3BhciwgRGF0YSA9IDB4MDIgfHwgc2VyUChwb2ludChrcGFyKSkgfHwgc2VyMzIoaSkpLlxuICAgIC8vIEkgPSBITUFDLVNIQTUxMihLZXkgPSBjcGFyLCBEYXRhID0gMHgwMyB8fCBzZXJQKHBvaW50KGtwYXIpKSB8fCBzZXIzMihpKSkuXG4gICAgem1hYy51cGRhdGUoJ1xceDAyJyk7XG4gICAgem1hYy51cGRhdGUoYmlnSW50VG9CdWZmZXJMRShwaywgMzIpKTtcbiAgICB6bWFjLnVwZGF0ZShzZXJpKTtcbiAgICBpbWFjLnVwZGF0ZSgnXFx4MDMnKTtcbiAgICBpbWFjLnVwZGF0ZShiaWdJbnRUb0J1ZmZlckxFKHBrLCAzMikpO1xuICAgIGltYWMudXBkYXRlKHNlcmkpO1xuICB9IGVsc2Uge1xuICAgIGlmIChzayA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXCJDYW4ndCBwZXJmb3JtZWQgaGFyZGVuZWQgZGVyaXZhdGlvbiB3aXRob3V0IHByaXZhdGUga2V5XCIpO1xuICAgIH1cbiAgICAvLyBIYXJkZW5lZCBkZXJpdmF0aW9uOlxuICAgIC8vIFogPSBITUFDLVNIQTUxMihLZXkgPSBjcGFyLCBEYXRhID0gMHgwMCB8fCBzZXIyNTYobGVmdChrcGFyKSkgfHwgc2VyMzIoaSkpLlxuICAgIC8vIEkgPSBITUFDLVNIQTUxMihLZXkgPSBjcGFyLCBEYXRhID0gMHgwMSB8fCBzZXIyNTYobGVmdChrcGFyKSkgfHwgc2VyMzIoaSkpLlxuICAgIHptYWMudXBkYXRlKCdcXHgwMCcpO1xuICAgIHptYWMudXBkYXRlKGJpZ0ludFRvQnVmZmVyTEUoc2ssIDMyKSk7XG4gICAgem1hYy51cGRhdGUoc2VyaSk7XG4gICAgaW1hYy51cGRhdGUoJ1xceDAxJyk7XG4gICAgaW1hYy51cGRhdGUoYmlnSW50VG9CdWZmZXJMRShzaywgMzIpKTtcbiAgICBpbWFjLnVwZGF0ZShzZXJpKTtcbiAgfVxuICByZXR1cm4gW3ptYWMuZGlnZXN0KCksIGltYWMuZGlnZXN0KCldO1xufVxuXG5mdW5jdGlvbiBwYXRoVG9JbmRpY2VzKHBhdGg6IHN0cmluZyk6IG51bWJlcltdIHtcbiAgcmV0dXJuIHBhdGhcbiAgICAucmVwbGFjZSgvXm0/XFwvLywgJycpXG4gICAgLnNwbGl0KCcvJylcbiAgICAubWFwKChpbmRleCkgPT4gcGFyc2VJbnQoaW5kZXgsIDEwKSk7XG59XG5cbmV4cG9ydCBjbGFzcyBFZDI1NTE5QklQMzIge1xuICBzdGF0aWMgY3VydmU6IEVkMjU1MTlDdXJ2ZSA9IG5ldyBFZDI1NTE5Q3VydmUoKTtcbiAgc3RhdGljIGluaXRpYWxpemVkID0gZmFsc2U7XG5cbiAgc3RhdGljIGFzeW5jIGluaXRpYWxpemUoKTogUHJvbWlzZTxFZDI1NTE5QklQMzI+IHtcbiAgICBpZiAoIUVkMjU1MTlCSVAzMi5pbml0aWFsaXplZCkge1xuICAgICAgYXdhaXQgRWQyNTUxOUN1cnZlLmluaXRpYWxpemUoKTtcbiAgICAgIEVkMjU1MTlCSVAzMi5pbml0aWFsaXplZCA9IHRydWU7XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ldyBFZDI1NTE5QklQMzIoKTtcbiAgfVxuXG4gIHB1YmxpY0Rlcml2ZShrZXljaGFpbjogUHVibGljS2V5Y2hhaW4sIHBhdGg6IHN0cmluZyk6IFB1YmxpY0tleWNoYWluIHtcbiAgICBjb25zdCBpbmRpY2VzID0gcGF0aFRvSW5kaWNlcyhwYXRoKTtcbiAgICBmdW5jdGlvbiBkZXJpdmVJbmRleChhY2M6IGJpZ2ludFtdLCBpbmRleDogbnVtYmVyIHwgdW5kZWZpbmVkKTogYmlnaW50W10ge1xuICAgICAgY29uc3QgW3BrLCBjaGFpbmNvZGVdID0gYWNjO1xuICAgICAgY29uc3QgW3pvdXQsIGlvdXRdID0gZGVyaXZlRWQyNTUxOUhlbHBlcihpbmRleCwgY2hhaW5jb2RlLCBwayk7XG4gICAgICBjb25zdCB6bCA9IHpvdXQuc2xpY2UoMCwgMzIpO1xuICAgICAgLy8gbGVmdCA9IGtsICsgOCAqIHRydW5jMjgoemwpXG4gICAgICBjb25zdCB0ID0gQmlnSW50KDgpICogYmlnSW50RnJvbUJ1ZmZlckxFKHpsLnNsaWNlKDAsIDI4KSk7XG4gICAgICBjb25zdCBsZWZ0ID0gRWQyNTUxOUJJUDMyLmN1cnZlLnBvaW50QWRkKHBrLCBFZDI1NTE5QklQMzIuY3VydmUuYmFzZVBvaW50TXVsdCh0KSk7XG4gICAgICByZXR1cm4gW2xlZnQsIGJpZ0ludEZyb21CdWZmZXJCRShpb3V0LnNsaWNlKDMyKSldO1xuICAgIH1cbiAgICBjb25zdCBzdWJrZXkgPSBpbmRpY2VzLnJlZHVjZShkZXJpdmVJbmRleCwgZGVyaXZlSW5kZXgoW2tleWNoYWluLnBrLCBrZXljaGFpbi5jaGFpbmNvZGVdLCBpbmRpY2VzLnNoaWZ0KCkpKTtcbiAgICByZXR1cm4geyBwazogc3Via2V5WzBdLCBjaGFpbmNvZGU6IHN1YmtleVsxXSB9O1xuICB9XG5cbiAgcHJpdmF0ZURlcml2ZShrZXljaGFpbjogUHJpdmF0ZUtleWNoYWluLCBwYXRoOiBzdHJpbmcpOiBQcml2YXRlS2V5Y2hhaW4ge1xuICAgIGNvbnN0IGluZGljZXMgPSBwYXRoVG9JbmRpY2VzKHBhdGgpO1xuICAgIGZ1bmN0aW9uIGRlcml2ZUluZGV4KGFjYzogYmlnaW50W10sIGluZGV4OiBudW1iZXIgfCB1bmRlZmluZWQpOiBiaWdpbnRbXSB7XG4gICAgICBjb25zdCBbcGssIHNrLCBwcmVmaXgsIGNoYWluY29kZV0gPSBhY2M7XG4gICAgICBjb25zdCBbem91dCwgaW91dF0gPSBkZXJpdmVFZDI1NTE5SGVscGVyKGluZGV4LCBjaGFpbmNvZGUsIHBrLCBzayk7XG4gICAgICBjb25zdCB6bCA9IHpvdXQuc2xpY2UoMCwgMzIpO1xuICAgICAgY29uc3QgenIgPSB6b3V0LnNsaWNlKDMyKTtcbiAgICAgIC8vIGxlZnQgPSBrbCArIDggKiB0cnVuYzI4KHpsKVxuICAgICAgY29uc3QgdCA9IEJpZ0ludCg4KSAqIGJpZ0ludEZyb21CdWZmZXJMRSh6bC5zbGljZSgwLCAyOCkpO1xuICAgICAgY29uc3QgbGVmdF9wayA9IEVkMjU1MTlCSVAzMi5jdXJ2ZS5wb2ludEFkZChwaywgRWQyNTUxOUJJUDMyLmN1cnZlLmJhc2VQb2ludE11bHQodCkpO1xuICAgICAgY29uc3QgbGVmdF9zayA9IEVkMjU1MTlCSVAzMi5jdXJ2ZS5zY2FsYXJBZGQoc2ssIHQpO1xuICAgICAgLy8gcmlnaHQgPSB6ciArIGtyXG4gICAgICBjb25zdCByaWdodCA9IChwcmVmaXggKyBiaWdJbnRGcm9tQnVmZmVyQkUoenIpKSAlIGNoYWluY29kZUJhc2U7XG4gICAgICByZXR1cm4gW2xlZnRfcGssIGxlZnRfc2ssIHJpZ2h0LCBiaWdJbnRGcm9tQnVmZmVyQkUoaW91dC5zbGljZSgzMikpXTtcbiAgICB9XG4gICAgY29uc3QgW3BrLCBzaywgcHJlZml4LCBjaGFpbmNvZGVdID0gaW5kaWNlcy5yZWR1Y2UoXG4gICAgICBkZXJpdmVJbmRleCxcbiAgICAgIGRlcml2ZUluZGV4KFtrZXljaGFpbi5waywga2V5Y2hhaW4uc2ssIGtleWNoYWluLnByZWZpeCEsIGtleWNoYWluLmNoYWluY29kZV0sIGluZGljZXMuc2hpZnQoKSlcbiAgICApO1xuICAgIHJldHVybiB7IHBrLCBzaywgcHJlZml4LCBjaGFpbmNvZGUgfTtcbiAgfVxufVxuXG5mdW5jdGlvbiBkZXJpdmVTZWNwMjU2azFIZWxwZXIoaW5kZXg6IG51bWJlciB8IHVuZGVmaW5lZCA9IDAsIGNoYWluY29kZTogYmlnaW50LCBwazogYmlnaW50LCBzaz86IGJpZ2ludCk6IEJ1ZmZlciB7XG4gIGNvbnN0IGRhdGEgPSBCdWZmZXIuYWxsb2MoMzMgKyA0KTtcbiAgaWYgKCgoaW5kZXggPj4+IDApICYgMHg4MDAwMDAwMCkgPT09IDApIHtcbiAgICBiaWdJbnRUb0J1ZmZlckJFKHBrLCAzMykuY29weShkYXRhKTtcbiAgfSBlbHNlIHtcbiAgICBpZiAoc2sgPT09IHVuZGVmaW5lZCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFwiQ2FuJ3QgcGVyZm9ybWVkIGhhcmRlbmVkIGRlcml2YXRpb24gd2l0aG91dCBwcml2YXRlIGtleVwiKTtcbiAgICB9XG4gICAgZGF0YVswXSA9IDA7XG4gICAgYmlnSW50VG9CdWZmZXJCRShzaywgMzIpLmNvcHkoZGF0YSwgMSk7XG4gIH1cbiAgZGF0YS53cml0ZVVJbnQzMkJFKGluZGV4LCAzMyk7XG4gIHJldHVybiBjcmVhdGVIbWFjKCdzaGE1MTInLCBiaWdJbnRUb0J1ZmZlckJFKGNoYWluY29kZSwgMzIpKS51cGRhdGUoZGF0YSkuZGlnZXN0KCk7XG59XG5cbmV4cG9ydCBjbGFzcyBCSVAzMiB7XG4gIHN0YXRpYyBjdXJ2ZTogU2VjcDI1NmsxQ3VydmUgPSBuZXcgU2VjcDI1NmsxQ3VydmUoKTtcblxuICBwdWJsaWNEZXJpdmUoa2V5Y2hhaW46IFB1YmxpY0tleWNoYWluLCBwYXRoOiBzdHJpbmcpOiBQdWJsaWNLZXljaGFpbiB7XG4gICAgY29uc3QgaW5kaWNlcyA9IHBhdGhUb0luZGljZXMocGF0aCk7XG4gICAgZnVuY3Rpb24gZGVyaXZlSW5kZXgoYWNjOiBiaWdpbnRbXSwgaW5kZXg6IG51bWJlciB8IHVuZGVmaW5lZCk6IGJpZ2ludFtdIHtcbiAgICAgIGNvbnN0IFtwaywgY2hhaW5jb2RlXSA9IGFjYztcbiAgICAgIGNvbnN0IEkgPSBkZXJpdmVTZWNwMjU2azFIZWxwZXIoaW5kZXgsIGNoYWluY29kZSwgcGspO1xuICAgICAgY29uc3QgaWwgPSBiaWdJbnRGcm9tQnVmZmVyQkUoSS5zbGljZSgwLCAzMikpO1xuICAgICAgY29uc3QgaXIgPSBiaWdJbnRGcm9tQnVmZmVyQkUoSS5zbGljZSgzMikpO1xuICAgICAgY29uc3QgbGVmdF9wayA9IEJJUDMyLmN1cnZlLnBvaW50QWRkKHBrLCBCSVAzMi5jdXJ2ZS5iYXNlUG9pbnRNdWx0KGlsKSk7XG4gICAgICByZXR1cm4gW2xlZnRfcGssIGlyXTtcbiAgICB9XG4gICAgY29uc3QgW3BrLCBjaGFpbmNvZGVdID0gaW5kaWNlcy5yZWR1Y2UoXG4gICAgICBkZXJpdmVJbmRleCxcbiAgICAgIGRlcml2ZUluZGV4KFtrZXljaGFpbi5waywga2V5Y2hhaW4uY2hhaW5jb2RlXSwgaW5kaWNlcy5zaGlmdCgpKVxuICAgICk7XG4gICAgcmV0dXJuIHsgcGssIGNoYWluY29kZSB9O1xuICB9XG5cbiAgcHJpdmF0ZURlcml2ZShrZXljaGFpbjogUHJpdmF0ZUtleWNoYWluLCBwYXRoOiBzdHJpbmcpOiBQcml2YXRlS2V5Y2hhaW4ge1xuICAgIGNvbnN0IGluZGljZXMgPSBwYXRoVG9JbmRpY2VzKHBhdGgpO1xuICAgIGZ1bmN0aW9uIGRlcml2ZUluZGV4KGFjYzogYmlnaW50W10sIGluZGV4OiBudW1iZXIgfCB1bmRlZmluZWQpOiBiaWdpbnRbXSB7XG4gICAgICBjb25zdCBbcGssIHNrLCBjaGFpbmNvZGVdID0gYWNjO1xuICAgICAgY29uc3QgSSA9IGRlcml2ZVNlY3AyNTZrMUhlbHBlcihpbmRleCwgY2hhaW5jb2RlLCBwaywgc2spO1xuICAgICAgY29uc3QgaWwgPSBiaWdJbnRGcm9tQnVmZmVyQkUoSS5zbGljZSgwLCAzMikpO1xuICAgICAgY29uc3QgaXIgPSBiaWdJbnRGcm9tQnVmZmVyQkUoSS5zbGljZSgzMikpO1xuICAgICAgY29uc3QgbGVmdF9wayA9IEJJUDMyLmN1cnZlLnBvaW50QWRkKHBrLCBCSVAzMi5jdXJ2ZS5iYXNlUG9pbnRNdWx0KGlsKSk7XG4gICAgICBjb25zdCBsZWZ0X3NrID0gQklQMzIuY3VydmUuc2NhbGFyQWRkKHNrLCBpbCk7XG4gICAgICByZXR1cm4gW2xlZnRfcGssIGxlZnRfc2ssIGlyXTtcbiAgICB9XG4gICAgY29uc3QgW3BrLCBzaywgY2hhaW5jb2RlXSA9IGluZGljZXMucmVkdWNlKFxuICAgICAgZGVyaXZlSW5kZXgsXG4gICAgICBkZXJpdmVJbmRleChba2V5Y2hhaW4ucGssIGtleWNoYWluLnNrLCBrZXljaGFpbi5jaGFpbmNvZGVdLCBpbmRpY2VzLnNoaWZ0KCkpXG4gICAgKTtcbiAgICByZXR1cm4geyBwaywgc2ssIGNoYWluY29kZSB9O1xuICB9XG59XG4iXX0=
@@ -1,5 +0,0 @@
1
- export interface SplitSecret {
2
- shares: Record<number, bigint>;
3
- v: Array<bigint>;
4
- }
5
- //# sourceMappingURL=types.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/mpc/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,WAAW;IAC1B,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/B,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;CAClB"}
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYWNjb3VudC1saWIvbXBjL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFNwbGl0U2VjcmV0IHtcbiAgc2hhcmVzOiBSZWNvcmQ8bnVtYmVyLCBiaWdpbnQ+O1xuICB2OiBBcnJheTxiaWdpbnQ+O1xufVxuIl19