@bitgo-beta/sdk-core 8.2.1-beta.586 → 8.2.1-beta.588

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 (190) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/dist/src/account-lib/baseCoin/baseTransaction.d.ts +0 -2
  3. package/dist/src/account-lib/baseCoin/baseTransaction.d.ts.map +1 -1
  4. package/dist/src/account-lib/baseCoin/baseTransactionBuilder.d.ts +0 -2
  5. package/dist/src/account-lib/baseCoin/baseTransactionBuilder.d.ts.map +1 -1
  6. package/dist/src/account-lib/baseCoin/baseTransactionBuilder.js +1 -1
  7. package/dist/src/account-lib/baseCoin/blsKeyPair.d.ts +0 -2
  8. package/dist/src/account-lib/baseCoin/blsKeyPair.d.ts.map +1 -1
  9. package/dist/src/account-lib/baseCoin/blsKeyPair.js +18 -8
  10. package/dist/src/account-lib/baseCoin/ed25519KeyPair.js +18 -8
  11. package/dist/src/account-lib/baseCoin/enum.js +5 -5
  12. package/dist/src/account-lib/baseCoin/errors.js +1 -1
  13. package/dist/src/account-lib/baseCoin/iface.d.ts +0 -2
  14. package/dist/src/account-lib/baseCoin/iface.d.ts.map +1 -1
  15. package/dist/src/account-lib/baseCoin/iface.js +6 -7
  16. package/dist/src/account-lib/baseCoin/secp256k1ExtendedKeyPair.d.ts +0 -2
  17. package/dist/src/account-lib/baseCoin/secp256k1ExtendedKeyPair.d.ts.map +1 -1
  18. package/dist/src/account-lib/baseCoin/secp256k1ExtendedKeyPair.js +18 -8
  19. package/dist/src/account-lib/index.js +18 -8
  20. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts +0 -3
  21. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -1
  22. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.js +19 -9
  23. package/dist/src/account-lib/mpc/tss/ecdsa/index.js +18 -8
  24. package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts +0 -2
  25. package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts.map +1 -1
  26. package/dist/src/account-lib/mpc/tss/eddsa/eddsa.d.ts +0 -2
  27. package/dist/src/account-lib/mpc/tss/eddsa/eddsa.d.ts.map +1 -1
  28. package/dist/src/account-lib/mpc/tss/eddsa/eddsa.js +2 -2
  29. package/dist/src/account-lib/mpc/tss/eddsa/index.js +18 -8
  30. package/dist/src/account-lib/mpc/tss/index.js +18 -8
  31. package/dist/src/account-lib/mpc/util.js +3 -3
  32. package/dist/src/account-lib/staking/utils.js +3 -3
  33. package/dist/src/account-lib/util/crypto.d.ts +0 -2
  34. package/dist/src/account-lib/util/crypto.d.ts.map +1 -1
  35. package/dist/src/account-lib/util/crypto.js +36 -26
  36. package/dist/src/account-lib/util/ed25519KeyDeriver.d.ts +0 -2
  37. package/dist/src/account-lib/util/ed25519KeyDeriver.d.ts.map +1 -1
  38. package/dist/src/account-lib/util/ed25519KeyDeriver.js +1 -1
  39. package/dist/src/api/bip32path.js +2 -3
  40. package/dist/src/bitgo/address-book/address-book.js +1 -1
  41. package/dist/src/bitgo/baseCoin/baseCoin.d.ts +0 -3
  42. package/dist/src/bitgo/baseCoin/baseCoin.d.ts.map +1 -1
  43. package/dist/src/bitgo/baseCoin/baseCoin.js +18 -8
  44. package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts +2 -4
  45. package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts.map +1 -1
  46. package/dist/src/bitgo/baseCoin/iBaseCoin.js +2 -2
  47. package/dist/src/bitgo/bip32util.d.ts +0 -2
  48. package/dist/src/bitgo/bip32util.d.ts.map +1 -1
  49. package/dist/src/bitgo/bip32util.js +20 -11
  50. package/dist/src/bitgo/bitcoin.d.ts +0 -2
  51. package/dist/src/bitgo/bitcoin.d.ts.map +1 -1
  52. package/dist/src/bitgo/bitcoin.js +21 -12
  53. package/dist/src/bitgo/coinFactory.js +1 -1
  54. package/dist/src/bitgo/config.d.ts +26 -26
  55. package/dist/src/bitgo/config.js +20 -10
  56. package/dist/src/bitgo/ecdh.d.ts +0 -2
  57. package/dist/src/bitgo/ecdh.d.ts.map +1 -1
  58. package/dist/src/bitgo/ecdh.js +21 -12
  59. package/dist/src/bitgo/enterprise/enterprise.d.ts +0 -2
  60. package/dist/src/bitgo/enterprise/enterprise.d.ts.map +1 -1
  61. package/dist/src/bitgo/enterprise/enterprise.js +18 -8
  62. package/dist/src/bitgo/enterprise/enterprises.js +18 -8
  63. package/dist/src/bitgo/enterprise/iEnterprise.d.ts +0 -2
  64. package/dist/src/bitgo/enterprise/iEnterprise.d.ts.map +1 -1
  65. package/dist/src/bitgo/environments.js +8 -8
  66. package/dist/src/bitgo/index.js +18 -8
  67. package/dist/src/bitgo/inscriptionBuilder/iInscriptionBuilder.d.ts +0 -2
  68. package/dist/src/bitgo/inscriptionBuilder/iInscriptionBuilder.d.ts.map +1 -1
  69. package/dist/src/bitgo/internal/internal.js +2 -3
  70. package/dist/src/bitgo/internal/keycard.js +2 -3
  71. package/dist/src/bitgo/keychain/decryptKeychain.js +2 -3
  72. package/dist/src/bitgo/keychain/iKeychains.d.ts +0 -2
  73. package/dist/src/bitgo/keychain/iKeychains.d.ts.map +1 -1
  74. package/dist/src/bitgo/keychain/iKeychains.js +2 -2
  75. package/dist/src/bitgo/keychain/keychains.d.ts +0 -2
  76. package/dist/src/bitgo/keychain/keychains.d.ts.map +1 -1
  77. package/dist/src/bitgo/keychain/keychains.js +18 -8
  78. package/dist/src/bitgo/keychain/ovcJsonCodec.js +18 -8
  79. package/dist/src/bitgo/legacyBitcoin.d.ts +0 -2
  80. package/dist/src/bitgo/legacyBitcoin.d.ts.map +1 -1
  81. package/dist/src/bitgo/legacyBitcoin.js +21 -11
  82. package/dist/src/bitgo/lightning/codecs.js +20 -10
  83. package/dist/src/bitgo/lightning/custodial/iLightning.js +18 -8
  84. package/dist/src/bitgo/lightning/custodial/lightning.js +1 -1
  85. package/dist/src/bitgo/lightning/custodial/lightningUtils.js +22 -13
  86. package/dist/src/bitgo/lightning/custodial/lnurlCodec.js +3 -4
  87. package/dist/src/bitgo/lightning/lightningUtils.d.ts +0 -2
  88. package/dist/src/bitgo/lightning/lightningUtils.d.ts.map +1 -1
  89. package/dist/src/bitgo/lightning/lightningUtils.js +30 -20
  90. package/dist/src/bitgo/lightning/lightningWallet.js +4 -5
  91. package/dist/src/bitgo/lightning/signableJson.js +2 -3
  92. package/dist/src/bitgo/lightning/signature.js +20 -11
  93. package/dist/src/bitgo/market/markets.js +18 -8
  94. package/dist/src/bitgo/pendingApproval/iPendingApproval.js +4 -4
  95. package/dist/src/bitgo/pendingApproval/pendingApproval.js +18 -8
  96. package/dist/src/bitgo/pendingApproval/pendingApprovals.js +18 -8
  97. package/dist/src/bitgo/recovery/initiate.js +7 -8
  98. package/dist/src/bitgo/staking/iStakingWallet.js +2 -2
  99. package/dist/src/bitgo/staking/stakingWallet.js +1 -1
  100. package/dist/src/bitgo/trading/network/decrypt-aes-gcm.d.ts +0 -2
  101. package/dist/src/bitgo/trading/network/decrypt-aes-gcm.d.ts.map +1 -1
  102. package/dist/src/bitgo/trading/network/decrypt-aes-gcm.js +2 -3
  103. package/dist/src/bitgo/trading/network/decrypt-rsa.js +2 -3
  104. package/dist/src/bitgo/trading/network/decrypt.js +2 -3
  105. package/dist/src/bitgo/trading/network/encrypt-aes-gcm.d.ts +0 -2
  106. package/dist/src/bitgo/trading/network/encrypt-aes-gcm.d.ts.map +1 -1
  107. package/dist/src/bitgo/trading/network/encrypt-aes-gcm.js +2 -3
  108. package/dist/src/bitgo/trading/network/encrypt-rsa-browser.js +2 -3
  109. package/dist/src/bitgo/trading/network/encrypt-rsa.js +2 -3
  110. package/dist/src/bitgo/trading/network/encrypt.js +3 -4
  111. package/dist/src/bitgo/trading/network/network.js +1 -1
  112. package/dist/src/bitgo/trading/network/utils.d.ts +0 -2
  113. package/dist/src/bitgo/trading/network/utils.d.ts.map +1 -1
  114. package/dist/src/bitgo/trading/network/utils.js +4 -5
  115. package/dist/src/bitgo/tss/bitgoPubKeys.js +5 -5
  116. package/dist/src/bitgo/tss/common.js +8 -9
  117. package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts +0 -3
  118. package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts.map +1 -1
  119. package/dist/src/bitgo/tss/ecdsa/ecdsa.js +52 -42
  120. package/dist/src/bitgo/tss/ecdsa/ecdsaMPCv2.js +8 -9
  121. package/dist/src/bitgo/tss/ecdsa/index.js +18 -8
  122. package/dist/src/bitgo/tss/ecdsa/types.js +3 -3
  123. package/dist/src/bitgo/tss/eddsa/eddsa.d.ts +0 -2
  124. package/dist/src/bitgo/tss/eddsa/eddsa.d.ts.map +1 -1
  125. package/dist/src/bitgo/tss/eddsa/eddsa.js +12 -12
  126. package/dist/src/bitgo/tss/eddsa/index.js +18 -8
  127. package/dist/src/bitgo/tss/index.js +18 -8
  128. package/dist/src/bitgo/tss/types.js +2 -2
  129. package/dist/src/bitgo/utils/abstractUtxoCoinUtil.js +21 -12
  130. package/dist/src/bitgo/utils/blsUtils.js +1 -1
  131. package/dist/src/bitgo/utils/codecProps.js +19 -10
  132. package/dist/src/bitgo/utils/decode.d.ts.map +1 -1
  133. package/dist/src/bitgo/utils/decode.js +21 -11
  134. package/dist/src/bitgo/utils/index.js +18 -8
  135. package/dist/src/bitgo/utils/mpcUtils.js +1 -1
  136. package/dist/src/bitgo/utils/notEmpty.js +2 -3
  137. package/dist/src/bitgo/utils/opengpgUtils.js +31 -22
  138. package/dist/src/bitgo/utils/postWithCodec.js +2 -3
  139. package/dist/src/bitgo/utils/promise-utils.js +2 -3
  140. package/dist/src/bitgo/utils/triple.js +2 -3
  141. package/dist/src/bitgo/utils/tss/baseTSSUtils.js +18 -8
  142. package/dist/src/bitgo/utils/tss/baseTypes.d.ts +0 -2
  143. package/dist/src/bitgo/utils/tss/baseTypes.d.ts.map +1 -1
  144. package/dist/src/bitgo/utils/tss/baseTypes.js +8 -8
  145. package/dist/src/bitgo/utils/tss/ecdsa/base.js +1 -1
  146. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts +0 -2
  147. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts.map +1 -1
  148. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.js +18 -8
  149. package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.d.ts +3 -5
  150. package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.d.ts.map +1 -1
  151. package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.js +22 -12
  152. package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2KeyGenSender.js +2 -3
  153. package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts +0 -2
  154. package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts.map +1 -1
  155. package/dist/src/bitgo/utils/tss/ecdsa/typesMPCv2.d.ts +22 -22
  156. package/dist/src/bitgo/utils/tss/ecdsa/typesMPCv2.js +19 -9
  157. package/dist/src/bitgo/utils/tss/eddsa/eddsa.js +18 -8
  158. package/dist/src/bitgo/utils/tss/eddsa/index.js +18 -8
  159. package/dist/src/bitgo/utils/tss/index.js +18 -8
  160. package/dist/src/bitgo/utils/util.js +18 -8
  161. package/dist/src/bitgo/utils/wallet.js +19 -10
  162. package/dist/src/bitgo/wallet/BuildParams.js +18 -8
  163. package/dist/src/bitgo/wallet/iWallets.js +18 -8
  164. package/dist/src/bitgo/wallet/wallet.js +19 -9
  165. package/dist/src/bitgo/wallet/wallets.js +20 -10
  166. package/dist/src/bitgo/webhook/webhooks.js +18 -8
  167. package/dist/src/coins/fiateur.d.ts +0 -2
  168. package/dist/src/coins/fiateur.d.ts.map +1 -1
  169. package/dist/src/coins/fiatgbp.d.ts +0 -2
  170. package/dist/src/coins/fiatgbp.d.ts.map +1 -1
  171. package/dist/src/coins/fiatusd.d.ts +0 -2
  172. package/dist/src/coins/fiatusd.d.ts.map +1 -1
  173. package/dist/src/coins/ofc.d.ts +0 -2
  174. package/dist/src/coins/ofc.d.ts.map +1 -1
  175. package/dist/src/coins/ofc.js +1 -1
  176. package/dist/src/coins/ofcToken.js +1 -1
  177. package/dist/src/coins/susd.d.ts +0 -2
  178. package/dist/src/coins/susd.d.ts.map +1 -1
  179. package/dist/src/common.js +22 -12
  180. package/dist/src/index.js +18 -8
  181. package/dist/src/units.js +5 -6
  182. package/dist/test/unit/account-lib/mpc/tss/ecdsa/ecdsa.js +18 -8
  183. package/dist/test/unit/bitgo/lightning/codecs.js +18 -8
  184. package/dist/test/unit/bitgo/lightning/lightningUtils.js +18 -8
  185. package/dist/test/unit/bitgo/lightning/signature.js +18 -8
  186. package/dist/test/unit/bitgo/utils/postWithCodec.js +18 -8
  187. package/dist/test/unit/bitgo/wallet/BuildParams.js +18 -8
  188. package/dist/test/unit/bitgo/wallet/SendTransactionRequest.js +18 -8
  189. package/dist/tsconfig.tsbuildinfo +1 -1
  190. package/package.json +9 -8
package/CHANGELOG.md CHANGED
@@ -3,6 +3,18 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ # [28.15.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-core@28.14.2...@bitgo/sdk-core@28.15.0) (2024-12-03)
7
+
8
+ ### Bug Fixes
9
+
10
+ - **sdk-core:** deprecate displayOrder in ITransactionExplanation ([316ea22](https://github.com/BitGo/BitGoJS/commit/316ea22b4e834d4f850ef3589e2d6f66a6d62fe5))
11
+
12
+ ### Features
13
+
14
+ - add @types/keccak to packages that use it ([7e25872](https://github.com/BitGo/BitGoJS/commit/7e25872a5749cb6b3281b5355d4f45151d042d67))
15
+ - **sdk-core:** add sender walletId for btc unstaking ([ab12948](https://github.com/BitGo/BitGoJS/commit/ab12948c11455eb96bf21aaf0f3987227ca00603))
16
+ - **sdk-core:** enable dkls cold and custody wallet creation ([5360e06](https://github.com/BitGo/BitGoJS/commit/5360e06bca19430324e48e30ce5d0e4df1d79125))
17
+
6
18
  ## [28.14.2](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-core@28.14.1...@bitgo/sdk-core@28.14.2) (2024-11-26)
7
19
 
8
20
  ### Bug Fixes
@@ -1,5 +1,3 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
1
  import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
4
2
  import { BaseKey, Entry } from './iface';
5
3
  import { TransactionType } from './enum';
@@ -1 +1 @@
1
- {"version":3,"file":"baseTransaction.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/baseTransaction.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AACzC,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAGzC;;GAEG;AACH,8BAAsB,eAAe;IACnC,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC;IAClC,SAAS,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC;IAC3B,SAAS,CAAC,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC5B,SAAS,CAAC,KAAK,EAAE,eAAe,GAAG,SAAS,CAAC;IAC7C,SAAS,CAAC,WAAW,EAAE,MAAM,EAAE,CAAC;IAChC,SAAS,CAAC,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC;IAC5C;;;;OAIG;IACH,SAAS,aAAa,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IASvD;;;OAGG;IACH,IAAI,EAAE,IAAI,MAAM,CAEf;IAED;;OAEG;IACH,IAAI,IAAI,IAAI,eAAe,CAE1B;IAED;;OAEG;IACH,IAAI,OAAO,IAAI,KAAK,EAAE,CAErB;IAED;;OAEG;IACH,IAAI,MAAM,IAAI,KAAK,EAAE,CAEpB;IAED;;OAEG;IACH,IAAI,SAAS,IAAI,MAAM,EAAE,CAExB;IAED;;;;;;;OAOG;IACH,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO;IAEvC;;OAEG;IACH,QAAQ,CAAC,MAAM,IAAI,GAAG;IAEtB;;OAEG;IACH,QAAQ,CAAC,iBAAiB,IAAI,GAAG;IAEjC;;;OAGG;IACH,IAAI,eAAe,IAAI,MAAM,CAE5B;IAED;;;;OAIG;IAEH,kBAAkB,IAAI,GAAG;CAC1B"}
1
+ {"version":3,"file":"baseTransaction.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/baseTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AACzC,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAGzC;;GAEG;AACH,8BAAsB,eAAe;IACnC,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC;IAClC,SAAS,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC;IAC3B,SAAS,CAAC,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC5B,SAAS,CAAC,KAAK,EAAE,eAAe,GAAG,SAAS,CAAC;IAC7C,SAAS,CAAC,WAAW,EAAE,MAAM,EAAE,CAAC;IAChC,SAAS,CAAC,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC;IAC5C;;;;OAIG;IACH,SAAS,aAAa,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IASvD;;;OAGG;IACH,IAAI,EAAE,IAAI,MAAM,CAEf;IAED;;OAEG;IACH,IAAI,IAAI,IAAI,eAAe,CAE1B;IAED;;OAEG;IACH,IAAI,OAAO,IAAI,KAAK,EAAE,CAErB;IAED;;OAEG;IACH,IAAI,MAAM,IAAI,KAAK,EAAE,CAEpB;IAED;;OAEG;IACH,IAAI,SAAS,IAAI,MAAM,EAAE,CAExB;IAED;;;;;;;OAOG;IACH,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO;IAEvC;;OAEG;IACH,QAAQ,CAAC,MAAM,IAAI,GAAG;IAEtB;;OAEG;IACH,QAAQ,CAAC,iBAAiB,IAAI,GAAG;IAEjC;;;OAGG;IACH,IAAI,eAAe,IAAI,MAAM,CAE5B;IAED;;;;OAIG;IAEH,kBAAkB,IAAI,GAAG;CAC1B"}
@@ -1,5 +1,3 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
1
  import BigNumber from 'bignumber.js';
4
2
  import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
5
3
  import { BaseAddress, BaseKey, PublicKey, ValidityWindow } from './iface';
@@ -1 +1 @@
1
- {"version":3,"file":"baseTransactionBuilder.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/baseTransactionBuilder.ts"],"names":[],"mappings":";;AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC1E,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAGpD;;;GAGG;AACH,8BAAsB,sBAAsB;IAC1C,SAAS,CAAC,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC;IAC5C;;;;OAIG;IACH,SAAS,aAAa,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAIvD;;;;;OAKG;IACH,IAAI,CAAC,cAAc,EAAE,GAAG,GAAG,IAAI;IAK/B;;;;;OAKG;IACH,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC,cAAc,EAAE,GAAG,GAAG,eAAe;IAE3E;;;;OAIG;IACH,IAAI,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IASxB;;;;;OAKG;IACH,YAAY,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAI3D;;;;;OAKG;IACH,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,eAAe;IAEpE;;;;;OAKG;IACG,KAAK,IAAI,OAAO,CAAC,eAAe,CAAC;IAKvC;;;;;OAKG;IACH,SAAS,CAAC,QAAQ,CAAC,mBAAmB,IAAI,OAAO,CAAC,eAAe,CAAC;IAElE;;;;OAIG;IACH,QAAQ,CAAC,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAExC;;;;;OAKG;IACH,QAAQ,CAAC,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI;IAE5E;;;;OAIG;IACH,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IAE9C;;;;OAIG;IACH,QAAQ,CAAC,sBAAsB,CAAC,cAAc,EAAE,GAAG,GAAG,IAAI;IAE1D;;;;;OAKG;IACH,QAAQ,CAAC,mBAAmB,CAAC,WAAW,CAAC,EAAE,eAAe,GAAG,IAAI;IAEjE;;OAEG;IACH,WAAW,IAAI,MAAM;IAIrB;;OAEG;IACH,QAAQ,IAAI,MAAM;IAIlB;;;;;;;;;;;OAWG;IACH,iBAAiB,CAAC,MAAM,EAAE,cAAc,GAAG,cAAc;IAyDzD;;OAEG;IACH,SAAS,CAAC,QAAQ,KAAK,WAAW,IAAI,eAAe,CAAC;IAEtD;;OAEG;IACH,SAAS,CAAC,QAAQ,KAAK,WAAW,CAAC,WAAW,EAAE,eAAe,EAAE;CAClE"}
1
+ {"version":3,"file":"baseTransactionBuilder.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/baseTransactionBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC1E,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAGpD;;;GAGG;AACH,8BAAsB,sBAAsB;IAC1C,SAAS,CAAC,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC;IAC5C;;;;OAIG;IACH,SAAS,aAAa,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAIvD;;;;;OAKG;IACH,IAAI,CAAC,cAAc,EAAE,GAAG,GAAG,IAAI;IAK/B;;;;;OAKG;IACH,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC,cAAc,EAAE,GAAG,GAAG,eAAe;IAE3E;;;;OAIG;IACH,IAAI,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IASxB;;;;;OAKG;IACH,YAAY,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAI3D;;;;;OAKG;IACH,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,eAAe;IAEpE;;;;;OAKG;IACG,KAAK,IAAI,OAAO,CAAC,eAAe,CAAC;IAKvC;;;;;OAKG;IACH,SAAS,CAAC,QAAQ,CAAC,mBAAmB,IAAI,OAAO,CAAC,eAAe,CAAC;IAElE;;;;OAIG;IACH,QAAQ,CAAC,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAExC;;;;;OAKG;IACH,QAAQ,CAAC,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI;IAE5E;;;;OAIG;IACH,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IAE9C;;;;OAIG;IACH,QAAQ,CAAC,sBAAsB,CAAC,cAAc,EAAE,GAAG,GAAG,IAAI;IAE1D;;;;;OAKG;IACH,QAAQ,CAAC,mBAAmB,CAAC,WAAW,CAAC,EAAE,eAAe,GAAG,IAAI;IAEjE;;OAEG;IACH,WAAW,IAAI,MAAM;IAIrB;;OAEG;IACH,QAAQ,IAAI,MAAM;IAIlB;;;;;;;;;;;OAWG;IACH,iBAAiB,CAAC,MAAM,EAAE,cAAc,GAAG,cAAc;IAyDzD;;OAEG;IACH,SAAS,CAAC,QAAQ,KAAK,WAAW,IAAI,eAAe,CAAC;IAEtD;;OAEG;IACH,SAAS,CAAC,QAAQ,KAAK,WAAW,CAAC,WAAW,EAAE,eAAe,EAAE;CAClE"}
@@ -135,4 +135,4 @@ class BaseTransactionBuilder {
135
135
  }
136
136
  }
137
137
  exports.BaseTransactionBuilder = BaseTransactionBuilder;
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTransactionBuilder.js","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/baseTransactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import BigNumber from 'bignumber.js';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { BaseAddress, BaseKey, PublicKey, ValidityWindow } from './iface';\nimport { BaseTransaction } from './baseTransaction';\nimport { SigningError } from './errors';\n\n/**\n * Generic transaction builder to be extended with coin specific logic.\n * Provide a set of default steps (i.e. from, sign, build) and enforces mandatory validations.\n */\nexport abstract class BaseTransactionBuilder {\n  protected _coinConfig: Readonly<CoinConfig>;\n  /**\n   * Base constructor.\n   *\n   * @param _coinConfig BaseCoin from statics library\n   */\n  protected constructor(_coinConfig: Readonly<CoinConfig>) {\n    this._coinConfig = _coinConfig;\n  }\n\n  /**\n   * Parse a transaction based on existing data. The input format is determined by the coin\n   * extending this class. Some examples are hex, base64, or JSON.\n   *\n   * @param rawTransaction A raw transaction to be parsed\n   */\n  from(rawTransaction: any): void {\n    this.validateRawTransaction(rawTransaction);\n    this.transaction = this.fromImplementation(rawTransaction);\n  }\n\n  /**\n   * Coin specific implementation of {@code from}.\n   *\n   * @see {@link from}\n   * @returns the parsed coin specific transaction object\n   */\n  protected abstract fromImplementation(rawTransaction: any): BaseTransaction;\n\n  /**\n   * Validate keys and sign the transaction.\n   *\n   * @param key One of the keys associated with this transaction\n   */\n  sign(key: BaseKey): void {\n    this.validateKey(key);\n    if (!this.transaction.canSign(key)) {\n      throw new SigningError('Private key cannot sign the transaction');\n    }\n\n    this.transaction = this.signImplementation(key);\n  }\n\n  /**\n   * Adds a signature to the transaction.\n   *\n   * @param publicKey public key that produced the signature\n   * @param signature raw signature as a hex encoded Buffer\n   */\n  addSignature(publicKey: PublicKey, signature: Buffer): void {\n    throw new SigningError(`${this.coinName()} does not support adding signatures directly.`);\n  }\n\n  /**\n   * Coin specific implementation of {@code sign}.\n   *\n   * @see {@link sign}\n   * @returns coin specific transaction with signature data\n   */\n  protected abstract signImplementation(key: BaseKey): BaseTransaction;\n\n  /**\n   * Finalize the transaction by performing any extra step like calculating hashes, verifying\n   * integrity, or adding default values.\n   *\n   * @returns valid coin specific transaction (signed or unsigned)\n   */\n  async build(): Promise<BaseTransaction> {\n    this.validateTransaction(this.transaction);\n    return this.buildImplementation();\n  }\n\n  /**\n   * Coin specific implementation of {@code build}.\n   *\n   * @see {@link build}\n   * @returns valid coin specific transaction (signed or unsigned)\n   */\n  protected abstract buildImplementation(): Promise<BaseTransaction>;\n\n  /**\n   * Check the private key is present and is valid in the blockchain context, throw otherwise.\n   *\n   * @param {BaseKey} key Private key to validate\n   */\n  abstract validateKey(key: BaseKey): void;\n\n  /**\n   * Check the address provided is valid in the blockchain context, throw otherwise.\n   *\n   * @param address Address data to be validated\n   * @param addressFormat The format the address should be in if more than one is supported\n   */\n  abstract validateAddress(address: BaseAddress, addressFormat?: string): void;\n\n  /**\n   * Check the amount provided is valid in the blockchain context, throw otherwise.\n   *\n   * @param {BigNumber} value Transaction amount\n   */\n  abstract validateValue(value: BigNumber): void;\n\n  /**\n   * Check the raw transaction has a valid format in the blockchain context, throw otherwise.\n   *\n   * @param rawTransaction Transaction in any format\n   */\n  abstract validateRawTransaction(rawTransaction: any): void;\n\n  /**\n   * Check the transaction mandatory fields per transaction type and ensures it is valid, throw\n   * otherwise.\n   *\n   * @param {BaseTransaction} transaction\n   */\n  abstract validateTransaction(transaction?: BaseTransaction): void;\n\n  /**\n   * Get the underlying coin full name as specified in the statics library.\n   */\n  displayName(): string {\n    return this._coinConfig.fullName;\n  }\n\n  /**\n   * Get the underlying coin full name as specified in the statics library.\n   */\n  coinName(): string {\n    return this._coinConfig.name;\n  }\n\n  /**\n   * Verified validity windows params if them exist and return a valid validity windows.\n   * Unit param must be specified\n   * If params are not consistent, default params will be return based on firstValid and minDuration\n   * @param {ValidityWindow} params validity windows parameters to validate.\n   * @param {String} params.unit Parameter that could be 'blockheight' or 'timestamp'\n   * @param {Number} [params.minDuration] Optional - Minimum duration of the window\n   * @param {Number} [params.maxDuration] Optional - Maximum duration of the window\n   * @param {Number} [params.firstValid] Optional - First valid value\n   * @param {Number} [params.lastValid] Optional - Last valid value\n   * @returns {ValidityWindow} verified validity windows or default values\n   */\n  getValidityWindow(params: ValidityWindow): ValidityWindow {\n    if (!params.unit || (params.unit !== 'timestamp' && params.unit !== 'blockheight')) {\n      throw new Error('Unit parameter must be specified as blockheight or timestamp');\n    }\n    const unit = params.unit;\n    let defaultMinDuration: number;\n    let defaultMaxDuration: number;\n    let defaultFirstValid: number;\n    let defaultLastValid: number;\n\n    /* Set Default Params\n      minimum duration is set as 1 hr (3600000 msec) if unit is timestamp or 20 blocks if it is blockheight\n      maximum duration is set as 1 year (31536000000 msec) if unit is timestamp or 1000000 blocks if it is blockheight.\n     */\n    if (unit === 'timestamp') {\n      defaultMinDuration = 0;\n      defaultMaxDuration = 31536000000;\n      defaultFirstValid = Date.now();\n      defaultLastValid = defaultFirstValid + defaultMaxDuration;\n    } else {\n      defaultMinDuration = 0;\n      defaultMaxDuration = 1000000;\n      defaultFirstValid = 0;\n      defaultLastValid = defaultFirstValid + defaultMaxDuration;\n    }\n\n    // If any params exist, they will be used, otherwise it will be used default params.\n    let firstValid: number = params.firstValid || defaultFirstValid;\n    let lastValid: number = params.lastValid || defaultLastValid;\n    let minDuration: number = params.minDuration || defaultMinDuration;\n    let maxDuration: number = params.maxDuration || defaultMaxDuration;\n\n    /* Validate Params:\n      minDuration < maxDuration\n      firstValid < lastValid\n      firstValid + minDuration <= lastValid <= firstValid + maxDuration\n     */\n    if (minDuration >= maxDuration) {\n      throw new Error(`Expected maxDuration (${maxDuration}) to be grather than minDuration (${minDuration})`);\n    }\n    firstValid = firstValid >= 0 ? firstValid : defaultFirstValid;\n    minDuration = minDuration >= 0 ? minDuration : defaultMinDuration;\n    maxDuration = maxDuration > minDuration ? maxDuration : defaultMaxDuration;\n    lastValid =\n      lastValid >= firstValid + minDuration && lastValid <= firstValid + maxDuration\n        ? lastValid\n        : firstValid + maxDuration;\n\n    return {\n      firstValid,\n      lastValid,\n      minDuration,\n      maxDuration,\n      unit,\n    };\n  }\n\n  /**\n   * Get the transaction being built.\n   */\n  protected abstract get transaction(): BaseTransaction;\n\n  /**\n   * Set the transaction being built.\n   */\n  protected abstract set transaction(transaction: BaseTransaction);\n}\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTransactionBuilder.js","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/baseTransactionBuilder.ts"],"names":[],"mappings":";;;AAIA,qCAAwC;AAExC;;;GAGG;AACH,MAAsB,sBAAsB;IAE1C;;;;OAIG;IACH,YAAsB,WAAiC;QACrD,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACjC,CAAC;IAED;;;;;OAKG;IACH,IAAI,CAAC,cAAmB;QACtB,IAAI,CAAC,sBAAsB,CAAC,cAAc,CAAC,CAAC;QAC5C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC;IAC7D,CAAC;IAUD;;;;OAIG;IACH,IAAI,CAAC,GAAY;QACf,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QACtB,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;YACnC,MAAM,IAAI,qBAAY,CAAC,yCAAyC,CAAC,CAAC;QACpE,CAAC;QAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;IAClD,CAAC;IAED;;;;;OAKG;IACH,YAAY,CAAC,SAAoB,EAAE,SAAiB;QAClD,MAAM,IAAI,qBAAY,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,+CAA+C,CAAC,CAAC;IAC5F,CAAC;IAUD;;;;;OAKG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC3C,OAAO,IAAI,CAAC,mBAAmB,EAAE,CAAC;IACpC,CAAC;IA+CD;;OAEG;IACH,WAAW;QACT,OAAO,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC;IACnC,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;IAC/B,CAAC;IAED;;;;;;;;;;;OAWG;IACH,iBAAiB,CAAC,MAAsB;QACtC,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,WAAW,IAAI,MAAM,CAAC,IAAI,KAAK,aAAa,CAAC,EAAE,CAAC;YACnF,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAC;QAClF,CAAC;QACD,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACzB,IAAI,kBAA0B,CAAC;QAC/B,IAAI,kBAA0B,CAAC;QAC/B,IAAI,iBAAyB,CAAC;QAC9B,IAAI,gBAAwB,CAAC;QAE7B;;;WAGG;QACH,IAAI,IAAI,KAAK,WAAW,EAAE,CAAC;YACzB,kBAAkB,GAAG,CAAC,CAAC;YACvB,kBAAkB,GAAG,WAAW,CAAC;YACjC,iBAAiB,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YAC/B,gBAAgB,GAAG,iBAAiB,GAAG,kBAAkB,CAAC;QAC5D,CAAC;aAAM,CAAC;YACN,kBAAkB,GAAG,CAAC,CAAC;YACvB,kBAAkB,GAAG,OAAO,CAAC;YAC7B,iBAAiB,GAAG,CAAC,CAAC;YACtB,gBAAgB,GAAG,iBAAiB,GAAG,kBAAkB,CAAC;QAC5D,CAAC;QAED,oFAAoF;QACpF,IAAI,UAAU,GAAW,MAAM,CAAC,UAAU,IAAI,iBAAiB,CAAC;QAChE,IAAI,SAAS,GAAW,MAAM,CAAC,SAAS,IAAI,gBAAgB,CAAC;QAC7D,IAAI,WAAW,GAAW,MAAM,CAAC,WAAW,IAAI,kBAAkB,CAAC;QACnE,IAAI,WAAW,GAAW,MAAM,CAAC,WAAW,IAAI,kBAAkB,CAAC;QAEnE;;;;WAIG;QACH,IAAI,WAAW,IAAI,WAAW,EAAE,CAAC;YAC/B,MAAM,IAAI,KAAK,CAAC,yBAAyB,WAAW,qCAAqC,WAAW,GAAG,CAAC,CAAC;QAC3G,CAAC;QACD,UAAU,GAAG,UAAU,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,CAAC;QAC9D,WAAW,GAAG,WAAW,IAAI,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,kBAAkB,CAAC;QAClE,WAAW,GAAG,WAAW,GAAG,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,kBAAkB,CAAC;QAC3E,SAAS;YACP,SAAS,IAAI,UAAU,GAAG,WAAW,IAAI,SAAS,IAAI,UAAU,GAAG,WAAW;gBAC5E,CAAC,CAAC,SAAS;gBACX,CAAC,CAAC,UAAU,GAAG,WAAW,CAAC;QAE/B,OAAO;YACL,UAAU;YACV,SAAS;YACT,WAAW;YACX,WAAW;YACX,IAAI;SACL,CAAC;IACJ,CAAC;CAWF;AAlND,wDAkNC","sourcesContent":["import BigNumber from 'bignumber.js';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { BaseAddress, BaseKey, PublicKey, ValidityWindow } from './iface';\nimport { BaseTransaction } from './baseTransaction';\nimport { SigningError } from './errors';\n\n/**\n * Generic transaction builder to be extended with coin specific logic.\n * Provide a set of default steps (i.e. from, sign, build) and enforces mandatory validations.\n */\nexport abstract class BaseTransactionBuilder {\n  protected _coinConfig: Readonly<CoinConfig>;\n  /**\n   * Base constructor.\n   *\n   * @param _coinConfig BaseCoin from statics library\n   */\n  protected constructor(_coinConfig: Readonly<CoinConfig>) {\n    this._coinConfig = _coinConfig;\n  }\n\n  /**\n   * Parse a transaction based on existing data. The input format is determined by the coin\n   * extending this class. Some examples are hex, base64, or JSON.\n   *\n   * @param rawTransaction A raw transaction to be parsed\n   */\n  from(rawTransaction: any): void {\n    this.validateRawTransaction(rawTransaction);\n    this.transaction = this.fromImplementation(rawTransaction);\n  }\n\n  /**\n   * Coin specific implementation of {@code from}.\n   *\n   * @see {@link from}\n   * @returns the parsed coin specific transaction object\n   */\n  protected abstract fromImplementation(rawTransaction: any): BaseTransaction;\n\n  /**\n   * Validate keys and sign the transaction.\n   *\n   * @param key One of the keys associated with this transaction\n   */\n  sign(key: BaseKey): void {\n    this.validateKey(key);\n    if (!this.transaction.canSign(key)) {\n      throw new SigningError('Private key cannot sign the transaction');\n    }\n\n    this.transaction = this.signImplementation(key);\n  }\n\n  /**\n   * Adds a signature to the transaction.\n   *\n   * @param publicKey public key that produced the signature\n   * @param signature raw signature as a hex encoded Buffer\n   */\n  addSignature(publicKey: PublicKey, signature: Buffer): void {\n    throw new SigningError(`${this.coinName()} does not support adding signatures directly.`);\n  }\n\n  /**\n   * Coin specific implementation of {@code sign}.\n   *\n   * @see {@link sign}\n   * @returns coin specific transaction with signature data\n   */\n  protected abstract signImplementation(key: BaseKey): BaseTransaction;\n\n  /**\n   * Finalize the transaction by performing any extra step like calculating hashes, verifying\n   * integrity, or adding default values.\n   *\n   * @returns valid coin specific transaction (signed or unsigned)\n   */\n  async build(): Promise<BaseTransaction> {\n    this.validateTransaction(this.transaction);\n    return this.buildImplementation();\n  }\n\n  /**\n   * Coin specific implementation of {@code build}.\n   *\n   * @see {@link build}\n   * @returns valid coin specific transaction (signed or unsigned)\n   */\n  protected abstract buildImplementation(): Promise<BaseTransaction>;\n\n  /**\n   * Check the private key is present and is valid in the blockchain context, throw otherwise.\n   *\n   * @param {BaseKey} key Private key to validate\n   */\n  abstract validateKey(key: BaseKey): void;\n\n  /**\n   * Check the address provided is valid in the blockchain context, throw otherwise.\n   *\n   * @param address Address data to be validated\n   * @param addressFormat The format the address should be in if more than one is supported\n   */\n  abstract validateAddress(address: BaseAddress, addressFormat?: string): void;\n\n  /**\n   * Check the amount provided is valid in the blockchain context, throw otherwise.\n   *\n   * @param {BigNumber} value Transaction amount\n   */\n  abstract validateValue(value: BigNumber): void;\n\n  /**\n   * Check the raw transaction has a valid format in the blockchain context, throw otherwise.\n   *\n   * @param rawTransaction Transaction in any format\n   */\n  abstract validateRawTransaction(rawTransaction: any): void;\n\n  /**\n   * Check the transaction mandatory fields per transaction type and ensures it is valid, throw\n   * otherwise.\n   *\n   * @param {BaseTransaction} transaction\n   */\n  abstract validateTransaction(transaction?: BaseTransaction): void;\n\n  /**\n   * Get the underlying coin full name as specified in the statics library.\n   */\n  displayName(): string {\n    return this._coinConfig.fullName;\n  }\n\n  /**\n   * Get the underlying coin full name as specified in the statics library.\n   */\n  coinName(): string {\n    return this._coinConfig.name;\n  }\n\n  /**\n   * Verified validity windows params if them exist and return a valid validity windows.\n   * Unit param must be specified\n   * If params are not consistent, default params will be return based on firstValid and minDuration\n   * @param {ValidityWindow} params validity windows parameters to validate.\n   * @param {String} params.unit Parameter that could be 'blockheight' or 'timestamp'\n   * @param {Number} [params.minDuration] Optional - Minimum duration of the window\n   * @param {Number} [params.maxDuration] Optional - Maximum duration of the window\n   * @param {Number} [params.firstValid] Optional - First valid value\n   * @param {Number} [params.lastValid] Optional - Last valid value\n   * @returns {ValidityWindow} verified validity windows or default values\n   */\n  getValidityWindow(params: ValidityWindow): ValidityWindow {\n    if (!params.unit || (params.unit !== 'timestamp' && params.unit !== 'blockheight')) {\n      throw new Error('Unit parameter must be specified as blockheight or timestamp');\n    }\n    const unit = params.unit;\n    let defaultMinDuration: number;\n    let defaultMaxDuration: number;\n    let defaultFirstValid: number;\n    let defaultLastValid: number;\n\n    /* Set Default Params\n      minimum duration is set as 1 hr (3600000 msec) if unit is timestamp or 20 blocks if it is blockheight\n      maximum duration is set as 1 year (31536000000 msec) if unit is timestamp or 1000000 blocks if it is blockheight.\n     */\n    if (unit === 'timestamp') {\n      defaultMinDuration = 0;\n      defaultMaxDuration = 31536000000;\n      defaultFirstValid = Date.now();\n      defaultLastValid = defaultFirstValid + defaultMaxDuration;\n    } else {\n      defaultMinDuration = 0;\n      defaultMaxDuration = 1000000;\n      defaultFirstValid = 0;\n      defaultLastValid = defaultFirstValid + defaultMaxDuration;\n    }\n\n    // If any params exist, they will be used, otherwise it will be used default params.\n    let firstValid: number = params.firstValid || defaultFirstValid;\n    let lastValid: number = params.lastValid || defaultLastValid;\n    let minDuration: number = params.minDuration || defaultMinDuration;\n    let maxDuration: number = params.maxDuration || defaultMaxDuration;\n\n    /* Validate Params:\n      minDuration < maxDuration\n      firstValid < lastValid\n      firstValid + minDuration <= lastValid <= firstValid + maxDuration\n     */\n    if (minDuration >= maxDuration) {\n      throw new Error(`Expected maxDuration (${maxDuration}) to be grather than minDuration (${minDuration})`);\n    }\n    firstValid = firstValid >= 0 ? firstValid : defaultFirstValid;\n    minDuration = minDuration >= 0 ? minDuration : defaultMinDuration;\n    maxDuration = maxDuration > minDuration ? maxDuration : defaultMaxDuration;\n    lastValid =\n      lastValid >= firstValid + minDuration && lastValid <= firstValid + maxDuration\n        ? lastValid\n        : firstValid + maxDuration;\n\n    return {\n      firstValid,\n      lastValid,\n      minDuration,\n      maxDuration,\n      unit,\n    };\n  }\n\n  /**\n   * Get the transaction being built.\n   */\n  protected abstract get transaction(): BaseTransaction;\n\n  /**\n   * Set the transaction being built.\n   */\n  protected abstract set transaction(transaction: BaseTransaction);\n}\n"]}
@@ -1,5 +1,3 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
1
  import { BaseKeyPair } from './baseKeyPair';
4
2
  import { AddressFormat } from './enum';
5
3
  import { BlsKeys, KeyPairOptions } from './iface';
@@ -1 +1 @@
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
+ {"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"}
@@ -15,13 +15,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
15
15
  }) : function(o, v) {
16
16
  o["default"] = v;
17
17
  });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
25
35
  var __importDefault = (this && this.__importDefault) || function (mod) {
26
36
  return (mod && mod.__esModule) ? mod : { "default": mod };
27
37
  };
@@ -210,4 +220,4 @@ class BlsKeyPair {
210
220
  }
211
221
  }
212
222
  exports.BlsKeyPair = BlsKeyPair;
213
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"blsKeyPair.js","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/blsKeyPair.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,oDAA4B;AAC5B,mCAAqC;AACrC,yDAA2C;AAG3C,qCAA+C;AAC/C,mCAAiF;AACjF,2CAAwF;AAExF,MAAM,2BAA2B,GAAG,CAAC,CAAC;AACtC,MAAM,8BAA8B,GAAG,CAAC,CAAC;AAEzC;;GAEG;AACH,MAAsB,UAAU;IAG9B;;;;OAIG;IACH,YAAsB,MAAuB;QAC3C,IAAI,CAAC,MAAM,EAAE;YACX,IAAI,CAAC,YAAY,CAAC,2BAA2B,EAAE,8BAA8B,CAAC,CAAC;SAChF;aAAM,IAAI,IAAA,aAAK,EAAC,MAAM,CAAC,EAAE;YACxB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,YAAY,CAAC,CAAC;SAC1D;aAAM,IAAI,IAAA,gBAAQ,EAAC,MAAM,CAAC,EAAE;YAC3B,IAAA,gBAAM,EAAC,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,6BAAoB,CAAC,EAAE,sBAAsB,CAAC,CAAC;YAChF,IAAA,gBAAM,EAAC,IAAA,4BAAmB,EAAC,MAAM,CAAC,WAAW,CAAC,EAAE,oBAAoB,CAAC,CAAC;YACtE,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;SACvB;aAAM,IAAI,IAAA,oBAAY,EAAC,MAAM,CAAC,EAAE;YAC/B,IAAI,CAAC,OAAO,GAAG;gBACb,GAAG,EAAE,MAAM,CAAC,GAAG;gBACf,WAAW,EAAE,EAAE;gBACf,YAAY,EAAE,EAAE;gBAChB,IAAI,EAAE,EAAE;gBACR,SAAS,EAAE,EAAE;aACd,CAAC;SACH;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;SAC7C;IACH,CAAC;IAED,YAAY,CAAC,SAAiB,EAAE,YAAoB;QAClD,IAAI,YAAY,GAAG,SAAS,EAAE;YAC5B,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;SAClE;QACD,MAAM,UAAU,GAAG,GAAG,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QACrD,MAAM,eAAe,GAAG,GAAG,CAAC,YAAY,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;QACnE,MAAM,cAAc,GAAG,GAAG,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QACnD,IAAI,CAAC,OAAO,GAAG;YACb,IAAI,EAAE,IAAA,oBAAW,EAAC,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;YACpC,SAAS,EAAE,IAAA,oBAAW,EAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YAC1C,YAAY,EAAE,eAAe,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,IAAA,oBAAW,EAAC,WAAW,EAAE,EAAE,CAAC,CAAC;YAChF,WAAW,EAAE,IAAA,oBAAW,EAAC,cAAc,CAAC;SACzC,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,wBAAwB,CAAC,GAAW;QAClC,MAAM,IAAI,4BAAmB,CAAC,gDAAgD,CAAC,CAAC;IAClF,CAAC;IAED;;;;OAIG;IACH,uBAAuB,CAAC,GAAW;QACjC,MAAM,IAAI,4BAAmB,CAAC,+CAA+C,CAAC,CAAC;IACjF,CAAC;IAED,UAAU,CAAC,MAAsB;QAC/B,MAAM,IAAI,4BAAmB,CAAC,4BAA4B,CAAC,CAAC;IAC9D,CAAC;IAED,OAAO;QACL,MAAM,IAAI,4BAAmB,CAAC,yBAAyB,CAAC,CAAC;IAC3D,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,IAAI,CAAC,GAAW;QACpB,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE;YACpB,MAAM,aAAa,GAAG,MAAM,GAAG,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;YAC3E,OAAO,IAAI,GAAG,IAAA,oBAAW,EAAC,aAAa,CAAC,CAAC;SAC1C;QACD,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;IACzC,CAAC;IAEM,MAAM,CAAC,SAAS,CAAC,IAAY,EAAE,EAAU,EAAE,SAAiB,EAAE,IAAY;QAC/E,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;QACnC,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,GAAG,EAAE,CAAC,CAAC;QAC/B,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,GAAG,SAAS,CAAC,CAAC;QAC7C,MAAM,QAAQ,GAAG,GAAG,CAAC,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;QACpE,MAAM,cAAc,GAAG,IAAA,oBAAW,EAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QACvD,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,GAAG,IAAA,oBAAW,EAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QAC/D,MAAM,YAAY,GAAG,GAAG,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,EAAE,EAAE,OAAO,CAAC,EAAE,8BAA8B,CAAC,CAAC;QAC9F,MAAM,WAAW,GAAG,GAAG,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC;QACnD,OAAO;YACL,IAAI;YACJ,SAAS,EAAE,cAAc;YACzB,YAAY,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,IAAA,oBAAW,EAAC,WAAW,CAAC,CAAC;YACzE,WAAW,EAAE,IAAA,oBAAW,EAAC,WAAW,CAAC;SACtC,CAAC;IACJ,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,gBAAgB,CAAC,OAAiB;QAC9C,IAAA,gBAAM,EAAC,OAAO,CAAC,KAAK,CAAC,6BAAoB,CAAC,EAAE,sBAAsB,CAAC,CAAC;QACpE,IAAI;YACF,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,GAAG,WAAW,CAAC,CAAC,CAAC;YAC9E,MAAM,GAAG,GAAG,GAAG,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC;YAChD,OAAO,IAAA,oBAAW,EAAC,GAAG,CAAC,CAAC;SACzB;QAAC,OAAO,CAAC,EAAE;YACV,MAAM,IAAI,KAAK,CAAC,6BAA6B,GAAG,CAAC,CAAC,CAAC;SACpD;IACH,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,gBAAgB,CAAC,OAAiB;QAC9C,IAAI;YACF,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,GAAG,WAAW,CAAC,CAAC,CAAC;YAC9E,MAAM,YAAY,GAAG,GAAG,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC;YACzD,OAAO,IAAA,oBAAW,EAAC,YAAY,CAAC,CAAC;SAClC;QAAC,OAAO,CAAC,EAAE;YACV,MAAM,IAAI,KAAK,CAAC,6BAA6B,GAAG,CAAC,CAAC,CAAC;SACpD;IACH,CAAC;IAEM,MAAM,CAAC,mBAAmB,CAAC,sBAAgC;QAChE,IAAI;YACF,MAAM,UAAU,GAAG,sBAAsB,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC;YACvF,MAAM,eAAe,GAAG,GAAG,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;YACxD,OAAO,IAAA,oBAAW,EAAC,eAAe,EAAE,EAAE,CAAC,CAAC;SACzC;QAAC,OAAO,CAAC,EAAE;YACV,MAAM,IAAI,KAAK,CAAC,gCAAgC,GAAG,CAAC,CAAC,CAAC;SACvD;IACH,CAAC;IAED;;;;;;;;;;OAUG;IACI,MAAM,CAAC,mBAAmB,CAAC,UAAmC;QACnE,IAAI;YACF,MAAM,SAAS,GAAG,GAAG,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;YAClD,OAAO,IAAI,GAAG,IAAA,oBAAW,EAAC,SAAS,CAAC,CAAC;SACtC;QAAC,OAAO,CAAC,EAAE;YACV,MAAM,IAAI,KAAK,CAAC,gCAAgC,GAAG,CAAC,CAAC,CAAC;SACvD;IACH,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,GAAW,EAAE,GAAW,EAAE,SAAiB;QAC7E,IAAA,gBAAM,EAAC,IAAA,4BAAmB,EAAC,GAAG,CAAC,EAAE,uBAAuB,GAAG,EAAE,CAAC,CAAC;QAC/D,OAAO,MAAM,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC;IACtE,CAAC;CACF;AAhLD,gCAgLC","sourcesContent":["import assert from 'assert';\nimport { randomBytes } from 'crypto';\nimport * as BLS from '@bitgo-beta/bls-dkg';\nimport { BaseKeyPair } from './baseKeyPair';\nimport { AddressFormat } from './enum';\nimport { NotImplementedError } from './errors';\nimport { BlsKeys, KeyPairOptions, isDkg, isBlsKey, isPrivateKey } from './iface';\nimport { isValidBLSPublicKey, isValidBLSPrivateKey, bigIntToHex } from '../util/crypto';\n\nconst DEFAULT_SIGNATURE_THRESHOLD = 2;\nconst DEFAULT_SIGNATURE_PARTICIPANTS = 3;\n\n/**\n * Base class for BLS keypairs.\n */\nexport abstract class BlsKeyPair implements BaseKeyPair {\n  protected keyPair: BlsKeys;\n\n  /**\n   * Public constructor. By default, creates a key pair with a random polynomial.\n   *\n   * @param {KeyPairOptions} source Either a dkg options, a public and secret shares, or a private key\n   */\n  protected constructor(source?: KeyPairOptions) {\n    if (!source) {\n      this.createShares(DEFAULT_SIGNATURE_THRESHOLD, DEFAULT_SIGNATURE_PARTICIPANTS);\n    } else if (isDkg(source)) {\n      this.createShares(source.threshold, source.participants);\n    } else if (isBlsKey(source)) {\n      assert(source.secretShares.every(isValidBLSPrivateKey), 'Invalid private keys');\n      assert(isValidBLSPublicKey(source.publicShare), 'Invalid public key');\n      this.keyPair = source;\n    } else if (isPrivateKey(source)) {\n      this.keyPair = {\n        prv: source.prv,\n        publicShare: '',\n        secretShares: [],\n        seed: '',\n        chaincode: '',\n      };\n    } else {\n      throw new Error('Invalid key pair options');\n    }\n  }\n\n  createShares(threshold: number, participants: number): void {\n    if (participants < threshold) {\n      throw new Error('Participants should be greater than threshold');\n    }\n    const polynomial = BLS.generatePolynomial(threshold);\n    const keySecretShares = BLS.secretShares(polynomial, participants);\n    const keyPublicShare = BLS.publicShare(polynomial);\n    this.keyPair = {\n      seed: bigIntToHex(polynomial[0], 64),\n      chaincode: randomBytes(32).toString('hex'),\n      secretShares: keySecretShares.map((secretShare) => bigIntToHex(secretShare, 64)),\n      publicShare: bigIntToHex(keyPublicShare),\n    };\n  }\n\n  /**\n   * Note - this is not possible using BLS. BLS does not support prvkey derived key gen\n   *\n   * @param {string[]} prv a hexadecimal private key\n   */\n  recordKeysFromPrivateKey(prv: string): void {\n    throw new NotImplementedError('Private key derivation is not supported in bls');\n  }\n\n  /**\n   * Note - this is not possible using BLS. BLS does not support pubkey derived key gen\n   *\n   * @param {string} pub - An extended, compressed, or uncompressed public key\n   */\n  recordKeysFromPublicKey(pub: string): void {\n    throw new NotImplementedError('Public key derivation is not supported in bls');\n  }\n\n  getAddress(format?: AddressFormat): string {\n    throw new NotImplementedError('getAddress not implemented');\n  }\n\n  getKeys(): any {\n    throw new NotImplementedError('getKeys not implemented');\n  }\n\n  /**\n   * Signs bytes using the key pair\n   *\n   * @param msg The message bytes to sign\n   * @return signature of the bytes using this keypair\n   */\n  async sign(msg: Buffer): Promise<string> {\n    if (this.keyPair.prv) {\n      const signedMessage = await BLS.sign(msg, BigInt('0x' + this.keyPair.prv));\n      return '0x' + bigIntToHex(signedMessage);\n    }\n    throw new Error('Missing private key');\n  }\n\n  public static keyDerive(seed: string, pk: string, chaincode: string, path: string): BlsKeys {\n    const seedBI = BigInt('0x' + seed);\n    const pkBI = BigInt('0x' + pk);\n    const chaincodeBI = BigInt('0x' + chaincode);\n    const childKey = BLS.privateDerive(seedBI, pkBI, chaincodeBI, path);\n    const childChaincode = bigIntToHex(childKey.chaincode);\n    const entropy = BigInt('0x' + randomBytes(32).toString('hex'));\n    const secretShares = BLS.secretShares([childKey.sk, entropy], DEFAULT_SIGNATURE_PARTICIPANTS);\n    const publicShare = BLS.publicShare([childKey.sk]);\n    return {\n      seed,\n      chaincode: childChaincode,\n      secretShares: secretShares.map((secretShare) => bigIntToHex(secretShare)),\n      publicShare: bigIntToHex(publicShare),\n    };\n  }\n\n  /**\n   * Aggregates the secret shares of different key pairs into one private key\n   *\n   * @param prvKeys an array of secret shares\n   * @returns a private key\n   */\n  public static aggregatePrvkeys(prvKeys: string[]): string {\n    assert(prvKeys.every(isValidBLSPrivateKey), 'Invalid private keys');\n    try {\n      const secretShares = prvKeys.map((secretShare) => BigInt('0x' + secretShare));\n      const prv = BLS.mergeSecretShares(secretShares);\n      return bigIntToHex(prv);\n    } catch (e) {\n      throw new Error('Error aggregating prvkeys: ' + e);\n    }\n  }\n\n  /**\n   * Aggregates the public shares of different key pairs into a common public key\n   *\n   * @param pubKeys an array of public shares\n   * @returns a common public key\n   */\n  public static aggregatePubkeys(pubKeys: string[]): string {\n    try {\n      const publicShares = pubKeys.map((publicShare) => BigInt('0x' + publicShare));\n      const commonPubKey = BLS.mergePublicShares(publicShares);\n      return bigIntToHex(commonPubKey);\n    } catch (e) {\n      throw new Error('Error aggregating pubkeys: ' + e);\n    }\n  }\n\n  public static aggregateChaincodes(chaincodeContributions: string[]): string {\n    try {\n      const chaincodes = chaincodeContributions.map((chaincode) => BigInt('0x' + chaincode));\n      const commonChaincode = BLS.mergeChaincodes(chaincodes);\n      return bigIntToHex(commonChaincode, 64);\n    } catch (e) {\n      throw new Error('Error aggregating chaincodes: ' + e);\n    }\n  }\n\n  /**\n   * Aggregates the message signed by different key pairs into one sign\n   *\n   * @param signatures the message signed by different key pairs. The signer id is relevant to ensure a valid signature.\n   * @example <caption> E.g., the message is signed by user and wallet, then signatures would be:</caption>\n   * {\n   *   1: BigInt(messageSignedWithUserPrv),\n   *   3: BigInt(messageSignedWithWalletPrv),\n   * }\n   * @returns a signature combining all the provided signed messages\n   */\n  public static aggregateSignatures(signatures: { [n: number]: bigint }): string {\n    try {\n      const signature = BLS.mergeSignatures(signatures);\n      return '0x' + bigIntToHex(signature);\n    } catch (e) {\n      throw new Error('Error aggregating signatures: ' + e);\n    }\n  }\n\n  /**\n   * Verifies the signature for this key pair\n   * @param pub The public key with which to verify the signature\n   * @param msg The message to verify the signature with\n   * @param signature the signature to verify\n   * @return true if the signature is valid, else false\n   */\n  public static async verifySignature(pub: string, msg: Buffer, signature: string): Promise<boolean> {\n    assert(isValidBLSPublicKey(pub), `Invalid public key: ${pub}`);\n    return await BLS.verify(BigInt(signature), msg, BigInt('0x' + pub));\n  }\n}\n"]}
223
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"blsKeyPair.js","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/blsKeyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport { randomBytes } from 'crypto';\nimport * as BLS from '@bitgo-beta/bls-dkg';\nimport { BaseKeyPair } from './baseKeyPair';\nimport { AddressFormat } from './enum';\nimport { NotImplementedError } from './errors';\nimport { BlsKeys, KeyPairOptions, isDkg, isBlsKey, isPrivateKey } from './iface';\nimport { isValidBLSPublicKey, isValidBLSPrivateKey, bigIntToHex } from '../util/crypto';\n\nconst DEFAULT_SIGNATURE_THRESHOLD = 2;\nconst DEFAULT_SIGNATURE_PARTICIPANTS = 3;\n\n/**\n * Base class for BLS keypairs.\n */\nexport abstract class BlsKeyPair implements BaseKeyPair {\n  protected keyPair: BlsKeys;\n\n  /**\n   * Public constructor. By default, creates a key pair with a random polynomial.\n   *\n   * @param {KeyPairOptions} source Either a dkg options, a public and secret shares, or a private key\n   */\n  protected constructor(source?: KeyPairOptions) {\n    if (!source) {\n      this.createShares(DEFAULT_SIGNATURE_THRESHOLD, DEFAULT_SIGNATURE_PARTICIPANTS);\n    } else if (isDkg(source)) {\n      this.createShares(source.threshold, source.participants);\n    } else if (isBlsKey(source)) {\n      assert(source.secretShares.every(isValidBLSPrivateKey), 'Invalid private keys');\n      assert(isValidBLSPublicKey(source.publicShare), 'Invalid public key');\n      this.keyPair = source;\n    } else if (isPrivateKey(source)) {\n      this.keyPair = {\n        prv: source.prv,\n        publicShare: '',\n        secretShares: [],\n        seed: '',\n        chaincode: '',\n      };\n    } else {\n      throw new Error('Invalid key pair options');\n    }\n  }\n\n  createShares(threshold: number, participants: number): void {\n    if (participants < threshold) {\n      throw new Error('Participants should be greater than threshold');\n    }\n    const polynomial = BLS.generatePolynomial(threshold);\n    const keySecretShares = BLS.secretShares(polynomial, participants);\n    const keyPublicShare = BLS.publicShare(polynomial);\n    this.keyPair = {\n      seed: bigIntToHex(polynomial[0], 64),\n      chaincode: randomBytes(32).toString('hex'),\n      secretShares: keySecretShares.map((secretShare) => bigIntToHex(secretShare, 64)),\n      publicShare: bigIntToHex(keyPublicShare),\n    };\n  }\n\n  /**\n   * Note - this is not possible using BLS. BLS does not support prvkey derived key gen\n   *\n   * @param {string[]} prv a hexadecimal private key\n   */\n  recordKeysFromPrivateKey(prv: string): void {\n    throw new NotImplementedError('Private key derivation is not supported in bls');\n  }\n\n  /**\n   * Note - this is not possible using BLS. BLS does not support pubkey derived key gen\n   *\n   * @param {string} pub - An extended, compressed, or uncompressed public key\n   */\n  recordKeysFromPublicKey(pub: string): void {\n    throw new NotImplementedError('Public key derivation is not supported in bls');\n  }\n\n  getAddress(format?: AddressFormat): string {\n    throw new NotImplementedError('getAddress not implemented');\n  }\n\n  getKeys(): any {\n    throw new NotImplementedError('getKeys not implemented');\n  }\n\n  /**\n   * Signs bytes using the key pair\n   *\n   * @param msg The message bytes to sign\n   * @return signature of the bytes using this keypair\n   */\n  async sign(msg: Buffer): Promise<string> {\n    if (this.keyPair.prv) {\n      const signedMessage = await BLS.sign(msg, BigInt('0x' + this.keyPair.prv));\n      return '0x' + bigIntToHex(signedMessage);\n    }\n    throw new Error('Missing private key');\n  }\n\n  public static keyDerive(seed: string, pk: string, chaincode: string, path: string): BlsKeys {\n    const seedBI = BigInt('0x' + seed);\n    const pkBI = BigInt('0x' + pk);\n    const chaincodeBI = BigInt('0x' + chaincode);\n    const childKey = BLS.privateDerive(seedBI, pkBI, chaincodeBI, path);\n    const childChaincode = bigIntToHex(childKey.chaincode);\n    const entropy = BigInt('0x' + randomBytes(32).toString('hex'));\n    const secretShares = BLS.secretShares([childKey.sk, entropy], DEFAULT_SIGNATURE_PARTICIPANTS);\n    const publicShare = BLS.publicShare([childKey.sk]);\n    return {\n      seed,\n      chaincode: childChaincode,\n      secretShares: secretShares.map((secretShare) => bigIntToHex(secretShare)),\n      publicShare: bigIntToHex(publicShare),\n    };\n  }\n\n  /**\n   * Aggregates the secret shares of different key pairs into one private key\n   *\n   * @param prvKeys an array of secret shares\n   * @returns a private key\n   */\n  public static aggregatePrvkeys(prvKeys: string[]): string {\n    assert(prvKeys.every(isValidBLSPrivateKey), 'Invalid private keys');\n    try {\n      const secretShares = prvKeys.map((secretShare) => BigInt('0x' + secretShare));\n      const prv = BLS.mergeSecretShares(secretShares);\n      return bigIntToHex(prv);\n    } catch (e) {\n      throw new Error('Error aggregating prvkeys: ' + e);\n    }\n  }\n\n  /**\n   * Aggregates the public shares of different key pairs into a common public key\n   *\n   * @param pubKeys an array of public shares\n   * @returns a common public key\n   */\n  public static aggregatePubkeys(pubKeys: string[]): string {\n    try {\n      const publicShares = pubKeys.map((publicShare) => BigInt('0x' + publicShare));\n      const commonPubKey = BLS.mergePublicShares(publicShares);\n      return bigIntToHex(commonPubKey);\n    } catch (e) {\n      throw new Error('Error aggregating pubkeys: ' + e);\n    }\n  }\n\n  public static aggregateChaincodes(chaincodeContributions: string[]): string {\n    try {\n      const chaincodes = chaincodeContributions.map((chaincode) => BigInt('0x' + chaincode));\n      const commonChaincode = BLS.mergeChaincodes(chaincodes);\n      return bigIntToHex(commonChaincode, 64);\n    } catch (e) {\n      throw new Error('Error aggregating chaincodes: ' + e);\n    }\n  }\n\n  /**\n   * Aggregates the message signed by different key pairs into one sign\n   *\n   * @param signatures the message signed by different key pairs. The signer id is relevant to ensure a valid signature.\n   * @example <caption> E.g., the message is signed by user and wallet, then signatures would be:</caption>\n   * {\n   *   1: BigInt(messageSignedWithUserPrv),\n   *   3: BigInt(messageSignedWithWalletPrv),\n   * }\n   * @returns a signature combining all the provided signed messages\n   */\n  public static aggregateSignatures(signatures: { [n: number]: bigint }): string {\n    try {\n      const signature = BLS.mergeSignatures(signatures);\n      return '0x' + bigIntToHex(signature);\n    } catch (e) {\n      throw new Error('Error aggregating signatures: ' + e);\n    }\n  }\n\n  /**\n   * Verifies the signature for this key pair\n   * @param pub The public key with which to verify the signature\n   * @param msg The message to verify the signature with\n   * @param signature the signature to verify\n   * @return true if the signature is valid, else false\n   */\n  public static async verifySignature(pub: string, msg: Buffer, signature: string): Promise<boolean> {\n    assert(isValidBLSPublicKey(pub), `Invalid public key: ${pub}`);\n    return await BLS.verify(BigInt(signature), msg, BigInt('0x' + pub));\n  }\n}\n"]}
@@ -15,13 +15,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
15
15
  }) : function(o, v) {
16
16
  o["default"] = v;
17
17
  });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
25
35
  Object.defineProperty(exports, "__esModule", { value: true });
26
36
  exports.Ed25519KeyPair = void 0;
27
37
  const nacl = __importStar(require("tweetnacl"));
@@ -147,4 +157,4 @@ class Ed25519KeyPair {
147
157
  }
148
158
  }
149
159
  exports.Ed25519KeyPair = Ed25519KeyPair;
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ed25519KeyPair.js","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/ed25519KeyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import * as nacl from 'tweetnacl';\nimport {\n  isValidEd25519PublicKey,\n  isValidEd25519SecretKey,\n  isValidEd25519Seed,\n  toHex,\n  toUint8Array,\n} from '../util/crypto';\nimport { Ed25519KeyDeriver } from '../util/ed25519KeyDeriver';\nimport { BaseKeyPair } from './baseKeyPair';\nimport { AddressFormat, DotAddressFormat } from './enum';\nimport { isPrivateKey, isPublicKey, isSeed, DefaultKeys, KeyPairOptions } from './iface';\n\nconst DEFAULT_SEED_SIZE_BYTES = 32;\n\nexport abstract class Ed25519KeyPair implements BaseKeyPair {\n  protected keyPair: DefaultKeys;\n  protected source?: KeyPairOptions;\n\n  /**\n   * Public constructor. By default, creates a key pair with a random master seed.\n   *\n   * @param {KeyPairOptions} source Either a master seed, a private key, or a public key\n   */\n  protected constructor(source?: KeyPairOptions) {\n    let naclKeyPair;\n    if (!source) {\n      const seed = nacl.randomBytes(DEFAULT_SEED_SIZE_BYTES);\n      naclKeyPair = nacl.sign.keyPair.fromSeed(seed);\n      this.setKeyPair(naclKeyPair);\n    } else if (isSeed(source)) {\n      naclKeyPair = nacl.sign.keyPair.fromSeed(source.seed);\n      this.setKeyPair(naclKeyPair);\n    } else if (isPrivateKey(source)) {\n      this.recordKeysFromPrivateKey(source.prv);\n    } else if (isPublicKey(source)) {\n      this.recordKeysFromPublicKey(source.pub);\n    } else {\n      throw new Error('Invalid key pair options');\n    }\n  }\n\n  private getKeyPair(naclKeyPair: nacl.SignKeyPair): DefaultKeys {\n    return {\n      prv: toHex(naclKeyPair.secretKey.slice(0, 32)),\n      pub: toHex(naclKeyPair.publicKey),\n    };\n  }\n\n  private setKeyPair(naclKeyPair: nacl.SignKeyPair): void {\n    this.keyPair = this.getKeyPair(naclKeyPair);\n  }\n\n  /** @inheritdoc */\n  recordKeysFromPrivateKey(prv: string): void {\n    if (isValidEd25519Seed(prv)) {\n      const decodedPrv = toUint8Array(prv);\n      const naclKeyPair = nacl.sign.keyPair.fromSeed(decodedPrv);\n      this.setKeyPair(naclKeyPair);\n    } else if (isValidEd25519SecretKey(prv)) {\n      const decodedPrv = toUint8Array(prv);\n      const naclKeyPair = nacl.sign.keyPair.fromSecretKey(decodedPrv);\n      this.setKeyPair(naclKeyPair);\n    } else {\n      this.keyPair = this.recordKeysFromPrivateKeyInProtocolFormat(prv);\n    }\n  }\n\n  /** @inheritdoc */\n  recordKeysFromPublicKey(pub: string): void {\n    if (isValidEd25519PublicKey(pub)) {\n      this.keyPair = { pub };\n    } else {\n      this.keyPair = this.recordKeysFromPublicKeyInProtocolFormat(pub);\n    }\n  }\n\n  abstract recordKeysFromPrivateKeyInProtocolFormat(prv: string): DefaultKeys;\n\n  abstract recordKeysFromPublicKeyInProtocolFormat(pub: string): DefaultKeys;\n\n  /** @inheritdoc */\n  abstract getAddress(format?: AddressFormat | DotAddressFormat): string;\n\n  /** @inheritdoc */\n  abstract getKeys(): any;\n\n  /**\n   * Generates a signature for an arbitrary string with the current private key using the ed25519 public-key signature\n   * system.\n   *\n   * @param {string} message to produce a signature for\n   * @returns {Uint8Array} The signature produced for the message\n   * @throws if there is no private key\n   */\n  signMessage(message: string): Uint8Array {\n    const messageToSign = toUint8Array(Buffer.from(message).toString('hex'));\n    const prv = this.keyPair?.prv;\n    if (!prv) {\n      throw new Error('Missing private key');\n    }\n    return nacl.sign.detached(messageToSign, nacl.sign.keyPair.fromSeed(toUint8Array(prv)).secretKey);\n  }\n\n  /**\n   * Verifies a message signature using the current public key.\n   *\n   * @param {string} message signed\n   * @param {Uint8Array} signature to verify\n   * @returns {boolean} True if the message was signed with the current key pair\n   */\n  verifySignature(message: Uint8Array | string, signature: Uint8Array): boolean {\n    let messageToVerify;\n    if (typeof message === 'string') {\n      messageToVerify = toUint8Array(Buffer.from(message).toString('hex'));\n    } else {\n      messageToVerify = message;\n    }\n    if (!this.keyPair?.pub) {\n      return false;\n    }\n    const publicKey = toUint8Array(this.keyPair.pub);\n    return nacl.sign.detached.verify(messageToVerify, signature, publicKey);\n  }\n\n  /**\n   * Derives a hardened child key pair using this key pair's secret key\n   * as the seed.\n   *\n   * @param path derivation path\n   * @deprecated\n   */\n  deriveHardened(path: string): DefaultKeys {\n    if (!this.keyPair?.prv) {\n      throw new Error('need private key to derive hardened keypair');\n    }\n\n    const seed = Ed25519KeyDeriver.derivePath(path, this.keyPair.prv).key;\n    const derivedKeyPair = nacl.sign.keyPair.fromSeed(seed);\n\n    return this.getKeyPair(derivedKeyPair);\n  }\n}\n"]}
160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ed25519KeyPair.js","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/ed25519KeyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import * as nacl from 'tweetnacl';\nimport {\n  isValidEd25519PublicKey,\n  isValidEd25519SecretKey,\n  isValidEd25519Seed,\n  toHex,\n  toUint8Array,\n} from '../util/crypto';\nimport { Ed25519KeyDeriver } from '../util/ed25519KeyDeriver';\nimport { BaseKeyPair } from './baseKeyPair';\nimport { AddressFormat, DotAddressFormat } from './enum';\nimport { isPrivateKey, isPublicKey, isSeed, DefaultKeys, KeyPairOptions } from './iface';\n\nconst DEFAULT_SEED_SIZE_BYTES = 32;\n\nexport abstract class Ed25519KeyPair implements BaseKeyPair {\n  protected keyPair: DefaultKeys;\n  protected source?: KeyPairOptions;\n\n  /**\n   * Public constructor. By default, creates a key pair with a random master seed.\n   *\n   * @param {KeyPairOptions} source Either a master seed, a private key, or a public key\n   */\n  protected constructor(source?: KeyPairOptions) {\n    let naclKeyPair;\n    if (!source) {\n      const seed = nacl.randomBytes(DEFAULT_SEED_SIZE_BYTES);\n      naclKeyPair = nacl.sign.keyPair.fromSeed(seed);\n      this.setKeyPair(naclKeyPair);\n    } else if (isSeed(source)) {\n      naclKeyPair = nacl.sign.keyPair.fromSeed(source.seed);\n      this.setKeyPair(naclKeyPair);\n    } else if (isPrivateKey(source)) {\n      this.recordKeysFromPrivateKey(source.prv);\n    } else if (isPublicKey(source)) {\n      this.recordKeysFromPublicKey(source.pub);\n    } else {\n      throw new Error('Invalid key pair options');\n    }\n  }\n\n  private getKeyPair(naclKeyPair: nacl.SignKeyPair): DefaultKeys {\n    return {\n      prv: toHex(naclKeyPair.secretKey.slice(0, 32)),\n      pub: toHex(naclKeyPair.publicKey),\n    };\n  }\n\n  private setKeyPair(naclKeyPair: nacl.SignKeyPair): void {\n    this.keyPair = this.getKeyPair(naclKeyPair);\n  }\n\n  /** @inheritdoc */\n  recordKeysFromPrivateKey(prv: string): void {\n    if (isValidEd25519Seed(prv)) {\n      const decodedPrv = toUint8Array(prv);\n      const naclKeyPair = nacl.sign.keyPair.fromSeed(decodedPrv);\n      this.setKeyPair(naclKeyPair);\n    } else if (isValidEd25519SecretKey(prv)) {\n      const decodedPrv = toUint8Array(prv);\n      const naclKeyPair = nacl.sign.keyPair.fromSecretKey(decodedPrv);\n      this.setKeyPair(naclKeyPair);\n    } else {\n      this.keyPair = this.recordKeysFromPrivateKeyInProtocolFormat(prv);\n    }\n  }\n\n  /** @inheritdoc */\n  recordKeysFromPublicKey(pub: string): void {\n    if (isValidEd25519PublicKey(pub)) {\n      this.keyPair = { pub };\n    } else {\n      this.keyPair = this.recordKeysFromPublicKeyInProtocolFormat(pub);\n    }\n  }\n\n  abstract recordKeysFromPrivateKeyInProtocolFormat(prv: string): DefaultKeys;\n\n  abstract recordKeysFromPublicKeyInProtocolFormat(pub: string): DefaultKeys;\n\n  /** @inheritdoc */\n  abstract getAddress(format?: AddressFormat | DotAddressFormat): string;\n\n  /** @inheritdoc */\n  abstract getKeys(): any;\n\n  /**\n   * Generates a signature for an arbitrary string with the current private key using the ed25519 public-key signature\n   * system.\n   *\n   * @param {string} message to produce a signature for\n   * @returns {Uint8Array} The signature produced for the message\n   * @throws if there is no private key\n   */\n  signMessage(message: string): Uint8Array {\n    const messageToSign = toUint8Array(Buffer.from(message).toString('hex'));\n    const prv = this.keyPair?.prv;\n    if (!prv) {\n      throw new Error('Missing private key');\n    }\n    return nacl.sign.detached(messageToSign, nacl.sign.keyPair.fromSeed(toUint8Array(prv)).secretKey);\n  }\n\n  /**\n   * Verifies a message signature using the current public key.\n   *\n   * @param {string} message signed\n   * @param {Uint8Array} signature to verify\n   * @returns {boolean} True if the message was signed with the current key pair\n   */\n  verifySignature(message: Uint8Array | string, signature: Uint8Array): boolean {\n    let messageToVerify;\n    if (typeof message === 'string') {\n      messageToVerify = toUint8Array(Buffer.from(message).toString('hex'));\n    } else {\n      messageToVerify = message;\n    }\n    if (!this.keyPair?.pub) {\n      return false;\n    }\n    const publicKey = toUint8Array(this.keyPair.pub);\n    return nacl.sign.detached.verify(messageToVerify, signature, publicKey);\n  }\n\n  /**\n   * Derives a hardened child key pair using this key pair's secret key\n   * as the seed.\n   *\n   * @param path derivation path\n   * @deprecated\n   */\n  deriveHardened(path: string): DefaultKeys {\n    if (!this.keyPair?.prv) {\n      throw new Error('need private key to derive hardened keypair');\n    }\n\n    const seed = Ed25519KeyDeriver.derivePath(path, this.keyPair.prv).key;\n    const derivedKeyPair = nacl.sign.keyPair.fromSeed(seed);\n\n    return this.getKeyPair(derivedKeyPair);\n  }\n}\n"]}
@@ -78,7 +78,7 @@ var TransactionType;
78
78
  TransactionType[TransactionType["SendToken"] = 36] = "SendToken";
79
79
  // Setup a trustline with issuer of a token (eg. XRPL tokens)
80
80
  TransactionType[TransactionType["TrustLine"] = 37] = "TrustLine";
81
- })(TransactionType = exports.TransactionType || (exports.TransactionType = {}));
81
+ })(TransactionType || (exports.TransactionType = TransactionType = {}));
82
82
  /**
83
83
  * Generic list of encoding formats. Can be used as arguments for methods inputs.
84
84
  */
@@ -88,7 +88,7 @@ var AddressFormat;
88
88
  AddressFormat["base58"] = "base58";
89
89
  AddressFormat["mainnet"] = "mainnet";
90
90
  AddressFormat["testnet"] = "testnet";
91
- })(AddressFormat = exports.AddressFormat || (exports.AddressFormat = {}));
91
+ })(AddressFormat || (exports.AddressFormat = AddressFormat = {}));
92
92
  // TODO(): create union type of all address formats enums
93
93
  // list of ss58 format encoding types for Dot ecosystem
94
94
  var DotAddressFormat;
@@ -97,7 +97,7 @@ var DotAddressFormat;
97
97
  DotAddressFormat[DotAddressFormat["substrate"] = 42] = "substrate";
98
98
  // format for polkadot mainnet addresses
99
99
  DotAddressFormat[DotAddressFormat["polkadot"] = 0] = "polkadot";
100
- })(DotAddressFormat = exports.DotAddressFormat || (exports.DotAddressFormat = {}));
100
+ })(DotAddressFormat || (exports.DotAddressFormat = DotAddressFormat = {}));
101
101
  var StakingOperationTypes;
102
102
  (function (StakingOperationTypes) {
103
103
  StakingOperationTypes[StakingOperationTypes["LOCK"] = 0] = "LOCK";
@@ -106,5 +106,5 @@ var StakingOperationTypes;
106
106
  StakingOperationTypes[StakingOperationTypes["ACTIVATE"] = 3] = "ACTIVATE";
107
107
  StakingOperationTypes[StakingOperationTypes["UNLOCK"] = 4] = "UNLOCK";
108
108
  StakingOperationTypes[StakingOperationTypes["WITHDRAW"] = 5] = "WITHDRAW";
109
- })(StakingOperationTypes = exports.StakingOperationTypes || (exports.StakingOperationTypes = {}));
110
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hY2NvdW50LWxpYi9iYXNlQ29pbi9lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOztHQUVHO0FBQ0gsSUFBWSxlQXlFWDtBQXpFRCxXQUFZLGVBQWU7SUFDekIscURBQUksQ0FBQTtJQUNKLCtCQUErQjtJQUMvQixpRUFBVSxDQUFBO0lBQ1YsZ0NBQWdDO0lBQ2hDLG1FQUFXLENBQUE7SUFDWCxvRUFBb0U7SUFDcEUscUZBQW9CLENBQUE7SUFDcEIscUVBQXFFO0lBQ3JFLHVGQUFxQixDQUFBO0lBQ3JCLDBDQUEwQztJQUMxQyxxSEFBb0MsQ0FBQTtJQUNwQyw0REFBNEQ7SUFDNUQsbUVBQVcsQ0FBQTtJQUNYLHdFQUF3RTtJQUN4RSxpRUFBVSxDQUFBO0lBQ1Ysb0NBQW9DO0lBQ3BDLHVFQUFhLENBQUE7SUFDYiw4RUFBOEU7SUFDOUUsdUVBQWEsQ0FBQTtJQUNiLE9BQU87SUFDUCxvRUFBVyxDQUFBO0lBQ1gsT0FBTztJQUNQLG9FQUFXLENBQUE7SUFDWCxTQUFTO0lBQ1Qsd0VBQWEsQ0FBQTtJQUNiLFdBQVc7SUFDWCw0RUFBZSxDQUFBO0lBQ2YsU0FBUztJQUNULHdFQUFhLENBQUE7SUFDYixXQUFXO0lBQ1gsNEVBQWUsQ0FBQTtJQUNmLDhCQUE4QjtJQUM5QixzRUFBWSxDQUFBO0lBQ1osYUFBYTtJQUNiLGdGQUFpQixDQUFBO0lBQ2pCLG1FQUFtRTtJQUNuRSx3REFBSyxDQUFBO0lBQ0wsNEJBQTRCO0lBQzVCLHNFQUFZLENBQUE7SUFDWiwyQkFBMkI7SUFDM0IsY0FBYztJQUNkLHNFQUFZLENBQUE7SUFDWiwyQkFBMkI7SUFDM0IsY0FBYztJQUNkLHNFQUFZLENBQUE7SUFDWiwrQkFBK0I7SUFDL0IsMERBQU0sQ0FBQTtJQUNOLDBEQUFNLENBQUE7SUFDTiwyQ0FBMkM7SUFDM0MsOEZBQXdCLENBQUE7SUFDeEIsY0FBYztJQUNkLGtFQUFVLENBQUE7SUFDViw0QkFBNEI7SUFDNUIsd0VBQWEsQ0FBQTtJQUNiLCtCQUErQjtJQUMvQiw4RUFBZ0IsQ0FBQTtJQUNoQixnREFBZ0Q7SUFDaEQsb0ZBQW1CLENBQUE7SUFDbkIsV0FBVztJQUNYLDRFQUFlLENBQUE7SUFDZixnQ0FBZ0M7SUFDaEMsOERBQVEsQ0FBQTtJQUNSLGdGQUFpQixDQUFBO0lBQ2pCLGtHQUEwQixDQUFBO0lBQzFCLGtHQUEwQixDQUFBO0lBQzFCLGlEQUFpRDtJQUNqRCxvR0FBMkIsQ0FBQTtJQUMzQiw0RkFBdUIsQ0FBQTtJQUN2QixnQ0FBZ0M7SUFDaEMsZ0VBQVMsQ0FBQTtJQUNULDZEQUE2RDtJQUM3RCxnRUFBUyxDQUFBO0FBQ1gsQ0FBQyxFQXpFVyxlQUFlLEdBQWYsdUJBQWUsS0FBZix1QkFBZSxRQXlFMUI7QUFFRDs7R0FFRztBQUNILElBQVksYUFLWDtBQUxELFdBQVksYUFBYTtJQUN2Qiw0QkFBVyxDQUFBO0lBQ1gsa0NBQWlCLENBQUE7SUFDakIsb0NBQW1CLENBQUE7SUFDbkIsb0NBQW1CLENBQUE7QUFDckIsQ0FBQyxFQUxXLGFBQWEsR0FBYixxQkFBYSxLQUFiLHFCQUFhLFFBS3hCO0FBRUQseURBQXlEO0FBQ3pELHVEQUF1RDtBQUN2RCxJQUFZLGdCQUtYO0FBTEQsV0FBWSxnQkFBZ0I7SUFDMUIsbURBQW1EO0lBQ25ELGtFQUFjLENBQUE7SUFDZCx3Q0FBd0M7SUFDeEMsK0RBQVksQ0FBQTtBQUNkLENBQUMsRUFMVyxnQkFBZ0IsR0FBaEIsd0JBQWdCLEtBQWhCLHdCQUFnQixRQUszQjtBQUlELElBQVkscUJBT1g7QUFQRCxXQUFZLHFCQUFxQjtJQUMvQixpRUFBSSxDQUFBO0lBQ0osaUVBQUksQ0FBQTtJQUNKLHFFQUFNLENBQUE7SUFDTix5RUFBUSxDQUFBO0lBQ1IscUVBQU0sQ0FBQTtJQUNOLHlFQUFRLENBQUE7QUFDVixDQUFDLEVBUFcscUJBQXFCLEdBQXJCLDZCQUFxQixLQUFyQiw2QkFBcUIsUUFPaEMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEludGVybmFsIG1ldGFkYXRhLiBEZWZpbmVzIHRoZSB0eXBlIG9mIHRyYW5zYWN0aW9uLlxuICovXG5leHBvcnQgZW51bSBUcmFuc2FjdGlvblR5cGUge1xuICBTZW5kLFxuICAvLyBTZW5kIEVSQzcyMSBjb21wbGlhbnQgdG9rZW5zXG4gIFNlbmRFUkM3MjEsXG4gIC8vIFNlbmQgRVJDMTE1NSBjb21wbGlhbnQgdG9rZW5zXG4gIFNlbmRFUkMxMTU1LFxuICAvLyBJbml0aWFsaXplIGEgd2FsbGV0IG9uLWNoYWluIChlLmcuIE11bHRpLXNpZyBjb250cmFjdCBkZXBsb3ltZW50KVxuICBXYWxsZXRJbml0aWFsaXphdGlvbixcbiAgLy8gSW5pdGlhbGl6ZSBhbiBhZGRyZXNzIG9uLWNoYWluKGUuZy4gRm9yd2FyZGVyIGNvbnRyYWN0IGRlcGxveW1lbnQpXG4gIEFkZHJlc3NJbml0aWFsaXphdGlvbixcbiAgLy8gSW5pdGlhbGl6ZWQgYW4gYXNzb2NpYXRlZCB0b2tlbiBhY2NvdW50XG4gIEFzc29jaWF0ZWRUb2tlbkFjY291bnRJbml0aWFsaXphdGlvbixcbiAgLy8gRmx1c2ggdG9rZW5zIGZyb20gYSBmb3J3YXJkZXIgYWRkcmVzcyB0byBpdHMgYmFzZSBhZGRyZXNzXG4gIEZsdXNoVG9rZW5zLFxuICAvLyBGbHVzaCBuYXRpdmUgY29pbnMgKGVnLiBFVEgpIGZyb20gYSBmb3J3YXJkZXIgYWRkcmVzcyB0byBiYXNlIGFkZHJlc3NcbiAgRmx1c2hDb2lucyxcbiAgLy8gU2VuZCBhIHJhdyBzaW5nbGUtc2lnIHRyYW5zYWN0aW9uXG4gIFNpbmdsZVNpZ1NlbmQsXG4gIC8vIFVwZGF0ZSBhbiBhY2NvdW50IG9uLWNoYWluIChlLmcuIFB1YmxpYyBrZXkgcmV2ZWxhdGlvbiBvcGVyYXRpb24gZm9yIFRlem9zKVxuICBBY2NvdW50VXBkYXRlLFxuICAvLyBMb2NrXG4gIFN0YWtpbmdMb2NrLFxuICAvLyBWb3RlXG4gIFN0YWtpbmdWb3RlLFxuICAvLyBVbnZvdGVcbiAgU3Rha2luZ1Vudm90ZSxcbiAgLy8gQWN0aXZhdGVcbiAgU3Rha2luZ0FjdGl2YXRlLFxuICAvLyBVbmxvY2tcbiAgU3Rha2luZ1VubG9jayxcbiAgLy8gV2l0aGRyYXdcbiAgU3Rha2luZ1dpdGhkcmF3LFxuICAvLyBIYW5kbGUgc21hcnQgY29udHJhY3QgY2FsbHNcbiAgQ29udHJhY3RDYWxsLFxuICAvLyBEZWFjdGl2YXRlXG4gIFN0YWtpbmdEZWFjdGl2YXRlLFxuICAvLyBCYXRjaCBvZiBtdWx0aXBsZSB0cmFuc2FjdGlvbnMgYnJvYWRjYXN0IGFzIGEgc2luZ2xlIHRyYW5zYWN0aW9uXG4gIEJhdGNoLFxuICAvLyBDbGFpbSB0aGUgc3Rha2luZyByZXdhcmRzXG4gIFN0YWtpbmdDbGFpbSxcbiAgLy8gQWRkIGRlbGVnYXRvciB0byBwLWNoYWluXG4gIC8vIEBkZXByZWNhdGVkXG4gIEFkZERlbGVnYXRvcixcbiAgLy8gQWRkIHZhbGlkYXRvciB0byBwLWNoYWluXG4gIC8vIEBkZXByZWNhdGVkXG4gIEFkZFZhbGlkYXRvcixcbiAgLy8gQ3Jvc3MgY2hhaW4gdHJhbnNmZXIgYXQgQXZheFxuICBFeHBvcnQsXG4gIEltcG9ydCxcbiAgLy8gQ3Jvc3MgY2hhaW4gUmVjb3ZlcnkgZm9yIGV2bSBsaWtlIGNoYWluc1xuICBSZWNvdmVyeVdhbGxldERlcGxveW1lbnQsXG4gIC8vIEFkZCBzdGFraW5nXG4gIFN0YWtpbmdBZGQsXG4gIC8vIFN0YWtpbmcgcGxlZGdlIChlLmcuIEFEQSlcbiAgU3Rha2luZ1BsZWRnZSxcbiAgLy8gU3Rha2luZyBBdXRob3JpemUgKGUuZy4gU09MKVxuICBTdGFraW5nQXV0aG9yaXplLFxuICAvLyBTdGFraW5nIEF1dGhvcml6ZSBmcm9tIHJhdyBtZXNzYWdlIChlLmcuIFNPTClcbiAgU3Rha2luZ0F1dGhvcml6ZVJhdyxcbiAgLy8gRGVsZWdhdGVcbiAgU3Rha2luZ0RlbGVnYXRlLFxuICAvLyBDdXN0b20gdHJhbnNhY3Rpb24gKGUuZy4gU1VJKVxuICBDdXN0b21UeCxcbiAgU3Rha2luZ1JlZGVsZWdhdGUsXG4gIEFkZFBlcm1pc3Npb25sZXNzRGVsZWdhdG9yLFxuICBBZGRQZXJtaXNzaW9ubGVzc1ZhbGlkYXRvcixcbiAgLy8gQ2xvc2luZyBhbiBhc3NvY2lhdGVkIHRva2VuIGFjY291bnQgKGUuZy4gU09MKVxuICBDbG9zZUFzc29jaWF0ZWRUb2tlbkFjY291bnQsXG4gIFNpbmdsZU5vbWluYXRvcldpdGhkcmF3LFxuICAvLyBTZW5kIFRva2VucyAoZS5nIFhSUEwgdG9rZW5zKVxuICBTZW5kVG9rZW4sXG4gIC8vIFNldHVwIGEgdHJ1c3RsaW5lIHdpdGggaXNzdWVyIG9mIGEgdG9rZW4gKGVnLiBYUlBMIHRva2VucylcbiAgVHJ1c3RMaW5lLFxufVxuXG4vKipcbiAqIEdlbmVyaWMgbGlzdCBvZiBlbmNvZGluZyBmb3JtYXRzLiBDYW4gYmUgdXNlZCBhcyBhcmd1bWVudHMgZm9yIG1ldGhvZHMgaW5wdXRzLlxuICovXG5leHBvcnQgZW51bSBBZGRyZXNzRm9ybWF0IHtcbiAgaGV4ID0gJ2hleCcsXG4gIGJhc2U1OCA9ICdiYXNlNTgnLFxuICBtYWlubmV0ID0gJ21haW5uZXQnLFxuICB0ZXN0bmV0ID0gJ3Rlc3RuZXQnLFxufVxuXG4vLyBUT0RPKCk6IGNyZWF0ZSB1bmlvbiB0eXBlIG9mIGFsbCBhZGRyZXNzIGZvcm1hdHMgZW51bXNcbi8vIGxpc3Qgb2Ygc3M1OCBmb3JtYXQgZW5jb2RpbmcgdHlwZXMgZm9yIERvdCBlY29zeXN0ZW1cbmV4cG9ydCBlbnVtIERvdEFkZHJlc3NGb3JtYXQge1xuICAvLyBmb3JtYXQgZm9yIHdlc3RlbmQgKGdlbmVyaWMgc3Vic3RyYXRlKSBhZGRyZXNzZXNcbiAgc3Vic3RyYXRlID0gNDIsXG4gIC8vIGZvcm1hdCBmb3IgcG9sa2Fkb3QgbWFpbm5ldCBhZGRyZXNzZXNcbiAgcG9sa2Fkb3QgPSAwLFxufVxuXG5leHBvcnQgdHlwZSBEb3RBc3NldFR5cGVzID0gJ2RvdCcgfCAndGRvdCc7XG5cbmV4cG9ydCBlbnVtIFN0YWtpbmdPcGVyYXRpb25UeXBlcyB7XG4gIExPQ0ssXG4gIFZPVEUsXG4gIFVOVk9URSxcbiAgQUNUSVZBVEUsXG4gIFVOTE9DSyxcbiAgV0lUSERSQVcsXG59XG4iXX0=
109
+ })(StakingOperationTypes || (exports.StakingOperationTypes = StakingOperationTypes = {}));
110
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hY2NvdW50LWxpYi9iYXNlQ29pbi9lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOztHQUVHO0FBQ0gsSUFBWSxlQXlFWDtBQXpFRCxXQUFZLGVBQWU7SUFDekIscURBQUksQ0FBQTtJQUNKLCtCQUErQjtJQUMvQixpRUFBVSxDQUFBO0lBQ1YsZ0NBQWdDO0lBQ2hDLG1FQUFXLENBQUE7SUFDWCxvRUFBb0U7SUFDcEUscUZBQW9CLENBQUE7SUFDcEIscUVBQXFFO0lBQ3JFLHVGQUFxQixDQUFBO0lBQ3JCLDBDQUEwQztJQUMxQyxxSEFBb0MsQ0FBQTtJQUNwQyw0REFBNEQ7SUFDNUQsbUVBQVcsQ0FBQTtJQUNYLHdFQUF3RTtJQUN4RSxpRUFBVSxDQUFBO0lBQ1Ysb0NBQW9DO0lBQ3BDLHVFQUFhLENBQUE7SUFDYiw4RUFBOEU7SUFDOUUsdUVBQWEsQ0FBQTtJQUNiLE9BQU87SUFDUCxvRUFBVyxDQUFBO0lBQ1gsT0FBTztJQUNQLG9FQUFXLENBQUE7SUFDWCxTQUFTO0lBQ1Qsd0VBQWEsQ0FBQTtJQUNiLFdBQVc7SUFDWCw0RUFBZSxDQUFBO0lBQ2YsU0FBUztJQUNULHdFQUFhLENBQUE7SUFDYixXQUFXO0lBQ1gsNEVBQWUsQ0FBQTtJQUNmLDhCQUE4QjtJQUM5QixzRUFBWSxDQUFBO0lBQ1osYUFBYTtJQUNiLGdGQUFpQixDQUFBO0lBQ2pCLG1FQUFtRTtJQUNuRSx3REFBSyxDQUFBO0lBQ0wsNEJBQTRCO0lBQzVCLHNFQUFZLENBQUE7SUFDWiwyQkFBMkI7SUFDM0IsY0FBYztJQUNkLHNFQUFZLENBQUE7SUFDWiwyQkFBMkI7SUFDM0IsY0FBYztJQUNkLHNFQUFZLENBQUE7SUFDWiwrQkFBK0I7SUFDL0IsMERBQU0sQ0FBQTtJQUNOLDBEQUFNLENBQUE7SUFDTiwyQ0FBMkM7SUFDM0MsOEZBQXdCLENBQUE7SUFDeEIsY0FBYztJQUNkLGtFQUFVLENBQUE7SUFDViw0QkFBNEI7SUFDNUIsd0VBQWEsQ0FBQTtJQUNiLCtCQUErQjtJQUMvQiw4RUFBZ0IsQ0FBQTtJQUNoQixnREFBZ0Q7SUFDaEQsb0ZBQW1CLENBQUE7SUFDbkIsV0FBVztJQUNYLDRFQUFlLENBQUE7SUFDZixnQ0FBZ0M7SUFDaEMsOERBQVEsQ0FBQTtJQUNSLGdGQUFpQixDQUFBO0lBQ2pCLGtHQUEwQixDQUFBO0lBQzFCLGtHQUEwQixDQUFBO0lBQzFCLGlEQUFpRDtJQUNqRCxvR0FBMkIsQ0FBQTtJQUMzQiw0RkFBdUIsQ0FBQTtJQUN2QixnQ0FBZ0M7SUFDaEMsZ0VBQVMsQ0FBQTtJQUNULDZEQUE2RDtJQUM3RCxnRUFBUyxDQUFBO0FBQ1gsQ0FBQyxFQXpFVyxlQUFlLCtCQUFmLGVBQWUsUUF5RTFCO0FBRUQ7O0dBRUc7QUFDSCxJQUFZLGFBS1g7QUFMRCxXQUFZLGFBQWE7SUFDdkIsNEJBQVcsQ0FBQTtJQUNYLGtDQUFpQixDQUFBO0lBQ2pCLG9DQUFtQixDQUFBO0lBQ25CLG9DQUFtQixDQUFBO0FBQ3JCLENBQUMsRUFMVyxhQUFhLDZCQUFiLGFBQWEsUUFLeEI7QUFFRCx5REFBeUQ7QUFDekQsdURBQXVEO0FBQ3ZELElBQVksZ0JBS1g7QUFMRCxXQUFZLGdCQUFnQjtJQUMxQixtREFBbUQ7SUFDbkQsa0VBQWMsQ0FBQTtJQUNkLHdDQUF3QztJQUN4QywrREFBWSxDQUFBO0FBQ2QsQ0FBQyxFQUxXLGdCQUFnQixnQ0FBaEIsZ0JBQWdCLFFBSzNCO0FBSUQsSUFBWSxxQkFPWDtBQVBELFdBQVkscUJBQXFCO0lBQy9CLGlFQUFJLENBQUE7SUFDSixpRUFBSSxDQUFBO0lBQ0oscUVBQU0sQ0FBQTtJQUNOLHlFQUFRLENBQUE7SUFDUixxRUFBTSxDQUFBO0lBQ04seUVBQVEsQ0FBQTtBQUNWLENBQUMsRUFQVyxxQkFBcUIscUNBQXJCLHFCQUFxQixRQU9oQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogSW50ZXJuYWwgbWV0YWRhdGEuIERlZmluZXMgdGhlIHR5cGUgb2YgdHJhbnNhY3Rpb24uXG4gKi9cbmV4cG9ydCBlbnVtIFRyYW5zYWN0aW9uVHlwZSB7XG4gIFNlbmQsXG4gIC8vIFNlbmQgRVJDNzIxIGNvbXBsaWFudCB0b2tlbnNcbiAgU2VuZEVSQzcyMSxcbiAgLy8gU2VuZCBFUkMxMTU1IGNvbXBsaWFudCB0b2tlbnNcbiAgU2VuZEVSQzExNTUsXG4gIC8vIEluaXRpYWxpemUgYSB3YWxsZXQgb24tY2hhaW4gKGUuZy4gTXVsdGktc2lnIGNvbnRyYWN0IGRlcGxveW1lbnQpXG4gIFdhbGxldEluaXRpYWxpemF0aW9uLFxuICAvLyBJbml0aWFsaXplIGFuIGFkZHJlc3Mgb24tY2hhaW4oZS5nLiBGb3J3YXJkZXIgY29udHJhY3QgZGVwbG95bWVudClcbiAgQWRkcmVzc0luaXRpYWxpemF0aW9uLFxuICAvLyBJbml0aWFsaXplZCBhbiBhc3NvY2lhdGVkIHRva2VuIGFjY291bnRcbiAgQXNzb2NpYXRlZFRva2VuQWNjb3VudEluaXRpYWxpemF0aW9uLFxuICAvLyBGbHVzaCB0b2tlbnMgZnJvbSBhIGZvcndhcmRlciBhZGRyZXNzIHRvIGl0cyBiYXNlIGFkZHJlc3NcbiAgRmx1c2hUb2tlbnMsXG4gIC8vIEZsdXNoIG5hdGl2ZSBjb2lucyAoZWcuIEVUSCkgZnJvbSBhIGZvcndhcmRlciBhZGRyZXNzIHRvIGJhc2UgYWRkcmVzc1xuICBGbHVzaENvaW5zLFxuICAvLyBTZW5kIGEgcmF3IHNpbmdsZS1zaWcgdHJhbnNhY3Rpb25cbiAgU2luZ2xlU2lnU2VuZCxcbiAgLy8gVXBkYXRlIGFuIGFjY291bnQgb24tY2hhaW4gKGUuZy4gUHVibGljIGtleSByZXZlbGF0aW9uIG9wZXJhdGlvbiBmb3IgVGV6b3MpXG4gIEFjY291bnRVcGRhdGUsXG4gIC8vIExvY2tcbiAgU3Rha2luZ0xvY2ssXG4gIC8vIFZvdGVcbiAgU3Rha2luZ1ZvdGUsXG4gIC8vIFVudm90ZVxuICBTdGFraW5nVW52b3RlLFxuICAvLyBBY3RpdmF0ZVxuICBTdGFraW5nQWN0aXZhdGUsXG4gIC8vIFVubG9ja1xuICBTdGFraW5nVW5sb2NrLFxuICAvLyBXaXRoZHJhd1xuICBTdGFraW5nV2l0aGRyYXcsXG4gIC8vIEhhbmRsZSBzbWFydCBjb250cmFjdCBjYWxsc1xuICBDb250cmFjdENhbGwsXG4gIC8vIERlYWN0aXZhdGVcbiAgU3Rha2luZ0RlYWN0aXZhdGUsXG4gIC8vIEJhdGNoIG9mIG11bHRpcGxlIHRyYW5zYWN0aW9ucyBicm9hZGNhc3QgYXMgYSBzaW5nbGUgdHJhbnNhY3Rpb25cbiAgQmF0Y2gsXG4gIC8vIENsYWltIHRoZSBzdGFraW5nIHJld2FyZHNcbiAgU3Rha2luZ0NsYWltLFxuICAvLyBBZGQgZGVsZWdhdG9yIHRvIHAtY2hhaW5cbiAgLy8gQGRlcHJlY2F0ZWRcbiAgQWRkRGVsZWdhdG9yLFxuICAvLyBBZGQgdmFsaWRhdG9yIHRvIHAtY2hhaW5cbiAgLy8gQGRlcHJlY2F0ZWRcbiAgQWRkVmFsaWRhdG9yLFxuICAvLyBDcm9zcyBjaGFpbiB0cmFuc2ZlciBhdCBBdmF4XG4gIEV4cG9ydCxcbiAgSW1wb3J0LFxuICAvLyBDcm9zcyBjaGFpbiBSZWNvdmVyeSBmb3IgZXZtIGxpa2UgY2hhaW5zXG4gIFJlY292ZXJ5V2FsbGV0RGVwbG95bWVudCxcbiAgLy8gQWRkIHN0YWtpbmdcbiAgU3Rha2luZ0FkZCxcbiAgLy8gU3Rha2luZyBwbGVkZ2UgKGUuZy4gQURBKVxuICBTdGFraW5nUGxlZGdlLFxuICAvLyBTdGFraW5nIEF1dGhvcml6ZSAoZS5nLiBTT0wpXG4gIFN0YWtpbmdBdXRob3JpemUsXG4gIC8vIFN0YWtpbmcgQXV0aG9yaXplIGZyb20gcmF3IG1lc3NhZ2UgKGUuZy4gU09MKVxuICBTdGFraW5nQXV0aG9yaXplUmF3LFxuICAvLyBEZWxlZ2F0ZVxuICBTdGFraW5nRGVsZWdhdGUsXG4gIC8vIEN1c3RvbSB0cmFuc2FjdGlvbiAoZS5nLiBTVUkpXG4gIEN1c3RvbVR4LFxuICBTdGFraW5nUmVkZWxlZ2F0ZSxcbiAgQWRkUGVybWlzc2lvbmxlc3NEZWxlZ2F0b3IsXG4gIEFkZFBlcm1pc3Npb25sZXNzVmFsaWRhdG9yLFxuICAvLyBDbG9zaW5nIGFuIGFzc29jaWF0ZWQgdG9rZW4gYWNjb3VudCAoZS5nLiBTT0wpXG4gIENsb3NlQXNzb2NpYXRlZFRva2VuQWNjb3VudCxcbiAgU2luZ2xlTm9taW5hdG9yV2l0aGRyYXcsXG4gIC8vIFNlbmQgVG9rZW5zIChlLmcgWFJQTCB0b2tlbnMpXG4gIFNlbmRUb2tlbixcbiAgLy8gU2V0dXAgYSB0cnVzdGxpbmUgd2l0aCBpc3N1ZXIgb2YgYSB0b2tlbiAoZWcuIFhSUEwgdG9rZW5zKVxuICBUcnVzdExpbmUsXG59XG5cbi8qKlxuICogR2VuZXJpYyBsaXN0IG9mIGVuY29kaW5nIGZvcm1hdHMuIENhbiBiZSB1c2VkIGFzIGFyZ3VtZW50cyBmb3IgbWV0aG9kcyBpbnB1dHMuXG4gKi9cbmV4cG9ydCBlbnVtIEFkZHJlc3NGb3JtYXQge1xuICBoZXggPSAnaGV4JyxcbiAgYmFzZTU4ID0gJ2Jhc2U1OCcsXG4gIG1haW5uZXQgPSAnbWFpbm5ldCcsXG4gIHRlc3RuZXQgPSAndGVzdG5ldCcsXG59XG5cbi8vIFRPRE8oKTogY3JlYXRlIHVuaW9uIHR5cGUgb2YgYWxsIGFkZHJlc3MgZm9ybWF0cyBlbnVtc1xuLy8gbGlzdCBvZiBzczU4IGZvcm1hdCBlbmNvZGluZyB0eXBlcyBmb3IgRG90IGVjb3N5c3RlbVxuZXhwb3J0IGVudW0gRG90QWRkcmVzc0Zvcm1hdCB7XG4gIC8vIGZvcm1hdCBmb3Igd2VzdGVuZCAoZ2VuZXJpYyBzdWJzdHJhdGUpIGFkZHJlc3Nlc1xuICBzdWJzdHJhdGUgPSA0MixcbiAgLy8gZm9ybWF0IGZvciBwb2xrYWRvdCBtYWlubmV0IGFkZHJlc3Nlc1xuICBwb2xrYWRvdCA9IDAsXG59XG5cbmV4cG9ydCB0eXBlIERvdEFzc2V0VHlwZXMgPSAnZG90JyB8ICd0ZG90JztcblxuZXhwb3J0IGVudW0gU3Rha2luZ09wZXJhdGlvblR5cGVzIHtcbiAgTE9DSyxcbiAgVk9URSxcbiAgVU5WT1RFLFxuICBBQ1RJVkFURSxcbiAgVU5MT0NLLFxuICBXSVRIRFJBVyxcbn1cbiJdfQ==
@@ -108,4 +108,4 @@ class DuplicateMethodError extends ExtendableError {
108
108
  }
109
109
  }
110
110
  exports.DuplicateMethodError = DuplicateMethodError;
111
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FjY291bnQtbGliL2Jhc2VDb2luL2Vycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQTs7O0dBR0c7QUFDSCxNQUFhLGVBQWdCLFNBQVEsS0FBSztJQUN4QyxZQUFZLE9BQU87UUFDakIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQztRQUNsQyxJQUFJLE9BQU8sS0FBSyxDQUFDLGlCQUFpQixLQUFLLFVBQVUsRUFBRTtZQUNqRCxLQUFLLENBQUMsaUJBQWlCLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztTQUNqRDthQUFNO1lBQ0wsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxLQUFLLENBQUM7U0FDdkM7SUFDSCxDQUFDO0NBQ0Y7QUFWRCwwQ0FVQztBQUVELE1BQWEscUJBQXNCLFNBQVEsZUFBZTtJQUN4RCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2pCLENBQUM7Q0FDRjtBQUpELHNEQUlDO0FBRUQsTUFBYSxZQUFhLFNBQVEsZUFBZTtJQUMvQyxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2pCLENBQUM7Q0FDRjtBQUpELG9DQUlDO0FBRUQsTUFBYSxxQkFBc0IsU0FBUSxlQUFlO0lBQ3hELFlBQVksT0FBZTtRQUN6QixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztDQUNGO0FBSkQsc0RBSUM7QUFFRCxNQUFhLFVBQVcsU0FBUSxlQUFlO0lBQzdDLFlBQVksT0FBZTtRQUN6QixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztDQUNGO0FBSkQsZ0NBSUM7QUFFRCxNQUFhLHNCQUF1QixTQUFRLGVBQWU7SUFDekQsWUFBWSxPQUFlO1FBQ3pCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqQixDQUFDO0NBQ0Y7QUFKRCx3REFJQztBQUVEOztHQUVHO0FBQ0gsTUFBYSwwQkFBMkIsU0FBUSxlQUFlO0lBQzdELFlBQVksT0FBZTtRQUN6QixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztDQUNGO0FBSkQsZ0VBSUM7QUFFRDs7R0FFRztBQUNILE1BQWEscUJBQXNCLFNBQVEsZUFBZTtJQUN4RCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2pCLENBQUM7Q0FDRjtBQUpELHNEQUlDO0FBRUQ7O0dBRUc7QUFDSCxNQUFhLG1CQUFvQixTQUFRLGVBQWU7SUFDdEQsWUFBWSxPQUFlO1FBQ3pCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqQixDQUFDO0NBQ0Y7QUFKRCxrREFJQztBQUVEOztHQUVHO0FBQ0gsTUFBYSxZQUFhLFNBQVEsZUFBZTtJQUMvQyxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2pCLENBQUM7Q0FDRjtBQUpELG9DQUlDO0FBRUQ7O0dBRUc7QUFDSCxNQUFhLFVBQVcsU0FBUSxlQUFlO0lBQzdDLFlBQVksT0FBZTtRQUN6QixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztDQUNGO0FBSkQsZ0NBSUM7QUFFRDs7R0FFRztBQUNILE1BQWEscUJBQXNCLFNBQVEsZUFBZTtJQUN4RCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2pCLENBQUM7Q0FDRjtBQUpELHNEQUlDO0FBRUQsTUFBYSxvQkFBcUIsU0FBUSxlQUFlO0lBQ3ZELFlBQVksT0FBZTtRQUN6QixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztDQUNGO0FBSkQsb0RBSUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoaXMgYmFzZSBjbGFzcyBlbnN1cmVzIHRoYXQgb3VyIHN0YWNrIHRyYWNlIGlzIGNhcHR1cmVkIHByb3Blcmx5IGJ1dCBhbHNvIHRoYXQgd2UgaGF2ZSBjbGFzc2VzIG9mIGVycm9yc1xuICogdGhhdCBjYW4gYmUgZm91bmQgaW4gYSBzd2l0Y2guXG4gKi9cbmV4cG9ydCBjbGFzcyBFeHRlbmRhYmxlRXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2UpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSB0aGlzLmNvbnN0cnVjdG9yLm5hbWU7XG4gICAgaWYgKHR5cGVvZiBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuc3RhY2sgPSBuZXcgRXJyb3IobWVzc2FnZSkuc3RhY2s7XG4gICAgfVxuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBQYXJzZVRyYW5zYWN0aW9uRXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgU2lnbmluZ0Vycm9yIGV4dGVuZHMgRXh0ZW5kYWJsZUVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEJ1aWxkVHJhbnNhY3Rpb25FcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBVdGlsc0Vycm9yIGV4dGVuZHMgRXh0ZW5kYWJsZUVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEV4dGVuZFRyYW5zYWN0aW9uRXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgfVxufVxuXG4vKipcbiAqIEVycm9yIGZvciBhbiBpbnZhbGlkIHZhbHVlIGZvciBhIGNvbnRyYWN0IG1ldGhvZCBwYXJhbWV0ZXJcbiAqL1xuZXhwb3J0IGNsYXNzIEludmFsaWRQYXJhbWV0ZXJWYWx1ZUVycm9yIGV4dGVuZHMgRXh0ZW5kYWJsZUVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gIH1cbn1cblxuLyoqXG4gKiBFcnJvciBwcm9kdWNlZCBieSBub3QgdHJ1dGh5IHNpZ25hdHVyZSB2YWx1ZXNcbiAqL1xuZXhwb3J0IGNsYXNzIEludmFsaWRTaWduYXR1cmVFcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICB9XG59XG5cbi8qKlxuICogRXJyb3IgZm9yIGEgbWV0aG9kIHRoYXQgbmVlZHMgdG8gYmUgaW1wbGVtZW50ZWRcbiAqL1xuZXhwb3J0IGNsYXNzIE5vdEltcGxlbWVudGVkRXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgfVxufVxuXG4vKipcbiAqIEVycm9yIGZvciBub3Qgc3VwcG9ydGVkIGZlYXR1cmVzXG4gKi9cbmV4cG9ydCBjbGFzcyBOb3RTdXBwb3J0ZWQgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgfVxufVxuXG4vKipcbiAqIEVycm9yIGZvciBpbnZhbGlkIHNlZWQsIHB1YmxpYywgb3IgcHJpdmF0ZSBrZXlzXG4gKi9cbmV4cG9ydCBjbGFzcyBJbnZhbGlkS2V5IGV4dGVuZHMgRXh0ZW5kYWJsZUVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gIH1cbn1cblxuLyoqXG4gKiBFcnJvciBmb3IgaW52YWxpZCBtaW50L3Rva2VuXG4gKi9cbmV4cG9ydCBjbGFzcyBVbnN1cHBvcnRlZFRva2VuRXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgRHVwbGljYXRlTWV0aG9kRXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgfVxufVxuIl19
111
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FjY291bnQtbGliL2Jhc2VDb2luL2Vycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQTs7O0dBR0c7QUFDSCxNQUFhLGVBQWdCLFNBQVEsS0FBSztJQUN4QyxZQUFZLE9BQU87UUFDakIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQztRQUNsQyxJQUFJLE9BQU8sS0FBSyxDQUFDLGlCQUFpQixLQUFLLFVBQVUsRUFBRSxDQUFDO1lBQ2xELEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ2xELENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxLQUFLLENBQUM7UUFDeEMsQ0FBQztJQUNILENBQUM7Q0FDRjtBQVZELDBDQVVDO0FBRUQsTUFBYSxxQkFBc0IsU0FBUSxlQUFlO0lBQ3hELFlBQVksT0FBZTtRQUN6QixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztDQUNGO0FBSkQsc0RBSUM7QUFFRCxNQUFhLFlBQWEsU0FBUSxlQUFlO0lBQy9DLFlBQVksT0FBZTtRQUN6QixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztDQUNGO0FBSkQsb0NBSUM7QUFFRCxNQUFhLHFCQUFzQixTQUFRLGVBQWU7SUFDeEQsWUFBWSxPQUFlO1FBQ3pCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqQixDQUFDO0NBQ0Y7QUFKRCxzREFJQztBQUVELE1BQWEsVUFBVyxTQUFRLGVBQWU7SUFDN0MsWUFBWSxPQUFlO1FBQ3pCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqQixDQUFDO0NBQ0Y7QUFKRCxnQ0FJQztBQUVELE1BQWEsc0JBQXVCLFNBQVEsZUFBZTtJQUN6RCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2pCLENBQUM7Q0FDRjtBQUpELHdEQUlDO0FBRUQ7O0dBRUc7QUFDSCxNQUFhLDBCQUEyQixTQUFRLGVBQWU7SUFDN0QsWUFBWSxPQUFlO1FBQ3pCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqQixDQUFDO0NBQ0Y7QUFKRCxnRUFJQztBQUVEOztHQUVHO0FBQ0gsTUFBYSxxQkFBc0IsU0FBUSxlQUFlO0lBQ3hELFlBQVksT0FBZTtRQUN6QixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztDQUNGO0FBSkQsc0RBSUM7QUFFRDs7R0FFRztBQUNILE1BQWEsbUJBQW9CLFNBQVEsZUFBZTtJQUN0RCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2pCLENBQUM7Q0FDRjtBQUpELGtEQUlDO0FBRUQ7O0dBRUc7QUFDSCxNQUFhLFlBQWEsU0FBUSxlQUFlO0lBQy9DLFlBQVksT0FBZTtRQUN6QixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztDQUNGO0FBSkQsb0NBSUM7QUFFRDs7R0FFRztBQUNILE1BQWEsVUFBVyxTQUFRLGVBQWU7SUFDN0MsWUFBWSxPQUFlO1FBQ3pCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqQixDQUFDO0NBQ0Y7QUFKRCxnQ0FJQztBQUVEOztHQUVHO0FBQ0gsTUFBYSxxQkFBc0IsU0FBUSxlQUFlO0lBQ3hELFlBQVksT0FBZTtRQUN6QixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztDQUNGO0FBSkQsc0RBSUM7QUFFRCxNQUFhLG9CQUFxQixTQUFRLGVBQWU7SUFDdkQsWUFBWSxPQUFlO1FBQ3pCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqQixDQUFDO0NBQ0Y7QUFKRCxvREFJQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVGhpcyBiYXNlIGNsYXNzIGVuc3VyZXMgdGhhdCBvdXIgc3RhY2sgdHJhY2UgaXMgY2FwdHVyZWQgcHJvcGVybHkgYnV0IGFsc28gdGhhdCB3ZSBoYXZlIGNsYXNzZXMgb2YgZXJyb3JzXG4gKiB0aGF0IGNhbiBiZSBmb3VuZCBpbiBhIHN3aXRjaC5cbiAqL1xuZXhwb3J0IGNsYXNzIEV4dGVuZGFibGVFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZSkge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICAgIHRoaXMubmFtZSA9IHRoaXMuY29uc3RydWN0b3IubmFtZTtcbiAgICBpZiAodHlwZW9mIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5zdGFjayA9IG5ldyBFcnJvcihtZXNzYWdlKS5zdGFjaztcbiAgICB9XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIFBhcnNlVHJhbnNhY3Rpb25FcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBTaWduaW5nRXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgQnVpbGRUcmFuc2FjdGlvbkVycm9yIGV4dGVuZHMgRXh0ZW5kYWJsZUVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIFV0aWxzRXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgRXh0ZW5kVHJhbnNhY3Rpb25FcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICB9XG59XG5cbi8qKlxuICogRXJyb3IgZm9yIGFuIGludmFsaWQgdmFsdWUgZm9yIGEgY29udHJhY3QgbWV0aG9kIHBhcmFtZXRlclxuICovXG5leHBvcnQgY2xhc3MgSW52YWxpZFBhcmFtZXRlclZhbHVlRXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgfVxufVxuXG4vKipcbiAqIEVycm9yIHByb2R1Y2VkIGJ5IG5vdCB0cnV0aHkgc2lnbmF0dXJlIHZhbHVlc1xuICovXG5leHBvcnQgY2xhc3MgSW52YWxpZFNpZ25hdHVyZUVycm9yIGV4dGVuZHMgRXh0ZW5kYWJsZUVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gIH1cbn1cblxuLyoqXG4gKiBFcnJvciBmb3IgYSBtZXRob2QgdGhhdCBuZWVkcyB0byBiZSBpbXBsZW1lbnRlZFxuICovXG5leHBvcnQgY2xhc3MgTm90SW1wbGVtZW50ZWRFcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICB9XG59XG5cbi8qKlxuICogRXJyb3IgZm9yIG5vdCBzdXBwb3J0ZWQgZmVhdHVyZXNcbiAqL1xuZXhwb3J0IGNsYXNzIE5vdFN1cHBvcnRlZCBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICB9XG59XG5cbi8qKlxuICogRXJyb3IgZm9yIGludmFsaWQgc2VlZCwgcHVibGljLCBvciBwcml2YXRlIGtleXNcbiAqL1xuZXhwb3J0IGNsYXNzIEludmFsaWRLZXkgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgfVxufVxuXG4vKipcbiAqIEVycm9yIGZvciBpbnZhbGlkIG1pbnQvdG9rZW5cbiAqL1xuZXhwb3J0IGNsYXNzIFVuc3VwcG9ydGVkVG9rZW5FcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBEdXBsaWNhdGVNZXRob2RFcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICB9XG59XG4iXX0=
@@ -1,5 +1,3 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
1
  import { ITransactionExplanation } from '../../bitgo';
4
2
  import { BaseTransactionBuilder } from './baseTransactionBuilder';
5
3
  import { BaseTransactionBuilderFactory } from './baseTransactionBuilderFactory';
@@ -1 +1 @@
1
- {"version":3,"file":"iface.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/iface.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"iface.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/iface.ts"],"names":[],"mappings":"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"}
@@ -1,27 +1,28 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.isBlsKey = exports.isDkg = exports.isPublicKey = exports.isPrivateKey = exports.isSeed = void 0;
3
+ exports.isSeed = isSeed;
4
+ exports.isPrivateKey = isPrivateKey;
5
+ exports.isPublicKey = isPublicKey;
6
+ exports.isDkg = isDkg;
7
+ exports.isBlsKey = isBlsKey;
4
8
  /**
5
9
  * @param source
6
10
  */
7
11
  function isSeed(source) {
8
12
  return source.seed !== undefined;
9
13
  }
10
- exports.isSeed = isSeed;
11
14
  /**
12
15
  * @param source
13
16
  */
14
17
  function isPrivateKey(source) {
15
18
  return source.prv !== undefined;
16
19
  }
17
- exports.isPrivateKey = isPrivateKey;
18
20
  /**
19
21
  * @param source
20
22
  */
21
23
  function isPublicKey(source) {
22
24
  return source.pub !== undefined;
23
25
  }
24
- exports.isPublicKey = isPublicKey;
25
26
  /**
26
27
  * @param source
27
28
  */
@@ -29,7 +30,6 @@ function isDkg(source) {
29
30
  const dkg = source;
30
31
  return dkg.threshold !== undefined && dkg.participants !== undefined;
31
32
  }
32
- exports.isDkg = isDkg;
33
33
  /**
34
34
  * Checks if the provided source is of type `BlsKeys`.
35
35
  * @param source
@@ -38,5 +38,4 @@ function isBlsKey(source) {
38
38
  const bls = source;
39
39
  return bls.publicShare !== undefined && bls.secretShares !== undefined;
40
40
  }
41
- exports.isBlsKey = isBlsKey;
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYWNjb3VudC1saWIvYmFzZUNvaW4vaWZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBbURBOztHQUVHO0FBQ0gsU0FBZ0IsTUFBTSxDQUFDLE1BQXNCO0lBQzNDLE9BQVEsTUFBZSxDQUFDLElBQUksS0FBSyxTQUFTLENBQUM7QUFDN0MsQ0FBQztBQUZELHdCQUVDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixZQUFZLENBQUMsTUFBc0I7SUFDakQsT0FBUSxNQUFxQixDQUFDLEdBQUcsS0FBSyxTQUFTLENBQUM7QUFDbEQsQ0FBQztBQUZELG9DQUVDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixXQUFXLENBQUMsTUFBc0I7SUFDaEQsT0FBUSxNQUFvQixDQUFDLEdBQUcsS0FBSyxTQUFTLENBQUM7QUFDakQsQ0FBQztBQUZELGtDQUVDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixLQUFLLENBQUMsTUFBc0I7SUFDMUMsTUFBTSxHQUFHLEdBQUcsTUFBb0IsQ0FBQztJQUNqQyxPQUFPLEdBQUcsQ0FBQyxTQUFTLEtBQUssU0FBUyxJQUFJLEdBQUcsQ0FBQyxZQUFZLEtBQUssU0FBUyxDQUFDO0FBQ3ZFLENBQUM7QUFIRCxzQkFHQztBQUVEOzs7R0FHRztBQUNILFNBQWdCLFFBQVEsQ0FBQyxNQUFzQjtJQUM3QyxNQUFNLEdBQUcsR0FBRyxNQUFpQixDQUFDO0lBQzlCLE9BQU8sR0FBRyxDQUFDLFdBQVcsS0FBSyxTQUFTLElBQUksR0FBRyxDQUFDLFlBQVksS0FBSyxTQUFTLENBQUM7QUFDekUsQ0FBQztBQUhELDRCQUdDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSVRyYW5zYWN0aW9uRXhwbGFuYXRpb24gfSBmcm9tICcuLi8uLi9iaXRnbyc7XG5pbXBvcnQgeyBCYXNlVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi9iYXNlVHJhbnNhY3Rpb25CdWlsZGVyJztcbmltcG9ydCB7IEJhc2VUcmFuc2FjdGlvbkJ1aWxkZXJGYWN0b3J5IH0gZnJvbSAnLi9iYXNlVHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFzZUtleSB7XG4gIGtleTogYW55O1xufVxuXG4vKipcbiAqIEEgcHJpdmF0ZSBrZXkgaW4gZXh0ZW5kZWQgb3IgcmF3IGZvcm1hdFxuICovXG5leHBvcnQgdHlwZSBQcml2YXRlS2V5ID0ge1xuICBwcnY6IHN0cmluZztcbn07XG5cbi8qKlxuICogQSBwdWJsaWMga2V5IGluIGV4dGVuZGVkLCBjb21wcmVzc2VkLCBvciB1bmNvbXByZXNzZWQgZm9ybWF0XG4gKi9cbmV4cG9ydCB0eXBlIFB1YmxpY0tleSA9IHtcbiAgcHViOiBzdHJpbmc7XG59O1xuXG4vKipcbiAqIEEgc2VlZCB0byBjcmVhdGUga2V5IHBhaXJzLiBNdXN0IGJlIGJldHdlZW4gMTYgYW5kIDY0IEJ5dGVzIGxvbmdcbiAqL1xuZXhwb3J0IHR5cGUgU2VlZCA9IHtcbiAgc2VlZDogQnVmZmVyO1xufTtcblxuLyoqXG4gKiBUaGUgbnVtYmVyIG9mIHBhcnRpY2lwYW50cyBmb3Igd2hpY2ggdG8gZ2VuZXJhdGUgc2hhcmVzIGFuZCBhIHRocmVzaG9sZCBvZiB0aG9zZSB0aGF0IHdvdWxkIGJlIHJlcXVpcmVkIHdoZW4gc2lnbmluZ1xuICovXG5leHBvcnQgdHlwZSBEa2dPcHRpb25zID0ge1xuICB0aHJlc2hvbGQ6IG51bWJlcjtcbiAgcGFydGljaXBhbnRzOiBudW1iZXI7XG59O1xuXG4vKipcbiAqIFJlcHJlc2VudGF0aW9uIG9mIGEgU2lnbmF0dXJlIHRvIGJlIGFkZGVkIHRvIGEgVHJhbnNhY3Rpb24uXG4gKi9cbmV4cG9ydCB0eXBlIFNpZ25hdHVyZSA9IHtcbiAgcHVibGljS2V5OiBQdWJsaWNLZXk7XG4gIHNpZ25hdHVyZTogQnVmZmVyO1xufTtcblxuZXhwb3J0IHR5cGUgQmxzS2V5UGFpck9wdGlvbnMgPSBEa2dPcHRpb25zIHwgQmxzS2V5cztcblxuZXhwb3J0IHR5cGUgS2V5UGFpck9wdGlvbnMgPSBTZWVkIHwgUHJpdmF0ZUtleSB8IFB1YmxpY0tleSB8IEJsc0tleVBhaXJPcHRpb25zO1xuXG5leHBvcnQgdHlwZSBCYXNlQnVpbGRlciA9IEJhc2VUcmFuc2FjdGlvbkJ1aWxkZXIgfCBCYXNlVHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeTtcblxuLyoqXG4gKiBAcGFyYW0gc291cmNlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc1NlZWQoc291cmNlOiBLZXlQYWlyT3B0aW9ucyk6IHNvdXJjZSBpcyBTZWVkIHtcbiAgcmV0dXJuIChzb3VyY2UgYXMgU2VlZCkuc2VlZCAhPT0gdW5kZWZpbmVkO1xufVxuXG4vKipcbiAqIEBwYXJhbSBzb3VyY2VcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGlzUHJpdmF0ZUtleShzb3VyY2U6IEtleVBhaXJPcHRpb25zKTogc291cmNlIGlzIFByaXZhdGVLZXkge1xuICByZXR1cm4gKHNvdXJjZSBhcyBQcml2YXRlS2V5KS5wcnYgIT09IHVuZGVmaW5lZDtcbn1cblxuLyoqXG4gKiBAcGFyYW0gc291cmNlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc1B1YmxpY0tleShzb3VyY2U6IEtleVBhaXJPcHRpb25zKTogc291cmNlIGlzIFB1YmxpY0tleSB7XG4gIHJldHVybiAoc291cmNlIGFzIFB1YmxpY0tleSkucHViICE9PSB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogQHBhcmFtIHNvdXJjZVxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNEa2coc291cmNlOiBLZXlQYWlyT3B0aW9ucyk6IHNvdXJjZSBpcyBEa2dPcHRpb25zIHtcbiAgY29uc3QgZGtnID0gc291cmNlIGFzIERrZ09wdGlvbnM7XG4gIHJldHVybiBka2cudGhyZXNob2xkICE9PSB1bmRlZmluZWQgJiYgZGtnLnBhcnRpY2lwYW50cyAhPT0gdW5kZWZpbmVkO1xufVxuXG4vKipcbiAqIENoZWNrcyBpZiB0aGUgcHJvdmlkZWQgc291cmNlIGlzIG9mIHR5cGUgYEJsc0tleXNgLlxuICogQHBhcmFtIHNvdXJjZVxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNCbHNLZXkoc291cmNlOiBLZXlQYWlyT3B0aW9ucyk6IHNvdXJjZSBpcyBCbHNLZXlzIHtcbiAgY29uc3QgYmxzID0gc291cmNlIGFzIEJsc0tleXM7XG4gIHJldHVybiBibHMucHVibGljU2hhcmUgIT09IHVuZGVmaW5lZCAmJiBibHMuc2VjcmV0U2hhcmVzICE9PSB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogS2V5IHBhaXIgaW4gdGhlIHByb3RvY29sIGRlZmF1bHQgZm9ybWF0LlxuICovXG5leHBvcnQgdHlwZSBEZWZhdWx0S2V5cyA9IHtcbiAgcHJ2Pzogc3RyaW5nO1xuICBwdWI6IHN0cmluZztcbn07XG5cbi8qKlxuICogS2V5IHBhaXIgaW4gVWludDhBcnJheSBmb3JtYXQuXG4gKi9cbmV4cG9ydCB0eXBlIEJ5dGVLZXlzID0ge1xuICBwcnY/OiBVaW50OEFycmF5O1xuICBwdWI6IFVpbnQ4QXJyYXk7XG59O1xuXG4vKipcbiAqIEtleSBwYWlyIGluIGV4dGVuZGVkIGZvcm1hdC4gVXNlZCBmb3IgY29pbnMgc3VwcG9ydGluZyBzZWNwMjU2azEgZWxsaXB0aWMgY3VydmUuXG4gKi9cbmV4cG9ydCB0eXBlIEV4dGVuZGVkS2V5cyA9IHtcbiAgeHBydj86IHN0cmluZztcbiAgeHB1Yjogc3RyaW5nO1xufTtcblxuLyoqXG4gKiBCTFMgc2lnbmF0dXJlIGtleXMuXG4gKi9cbmV4cG9ydCB0eXBlIEJsc0tleXMgPSB7XG4gIHBydj86IHN0cmluZztcbiAgc2VjcmV0U2hhcmVzOiBzdHJpbmdbXTtcbiAgcHVibGljU2hhcmU6IHN0cmluZztcbiAgc2VlZDogc3RyaW5nO1xuICBjaGFpbmNvZGU6IHN0cmluZztcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFzZUFkZHJlc3Mge1xuICBhZGRyZXNzOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW50cnkgZXh0ZW5kcyBCYXNlQWRkcmVzcyB7XG4gIGNvaW4/OiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFzZUZlZSB7XG4gIGZlZTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zYWN0aW9uUmVjaXBpZW50IHtcbiAgYWRkcmVzczogc3RyaW5nO1xuICBhbW91bnQ6IHN0cmluZyB8IG51bWJlcjtcbiAgbWVtbz86IHN0cmluZztcbiAgdG9rZW5OYW1lPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zYWN0aW9uRmVlIHtcbiAgZmVlOiBzdHJpbmc7XG4gIGZlZVJhdGU/OiBudW1iZXI7XG4gIHNpemU/OiBudW1iZXI7XG4gIHR5cGU/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHJhbnNhY3Rpb25PdXRwdXRzIHtcbiAgb3V0cHV0czogVHJhbnNhY3Rpb25SZWNpcGllbnRbXTtcbiAgb3V0cHV0QW1vdW50OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHJhbnNhY3Rpb25DaGFuZ2VzIHtcbiAgY2hhbmdlT3V0cHV0czogVHJhbnNhY3Rpb25SZWNpcGllbnRbXTtcbiAgY2hhbmdlQW1vdW50OiBzdHJpbmc7XG59XG5cbmV4cG9ydCB0eXBlIFRyYW5zYWN0aW9uRXhwbGFuYXRpb24gPSBJVHJhbnNhY3Rpb25FeHBsYW5hdGlvbjxUcmFuc2FjdGlvbkZlZT47XG4vKipcbiAqIEZlZSBvcHRpb25zLlxuICovXG5leHBvcnQgdHlwZSBGZWVPcHRpb25zID0ge1xuICBhbW91bnQ6IG51bWJlciB8IHN0cmluZztcbiAgdW5pdD86ICdiYXNlVW5pdCcgfCAnY3B1JyB8ICdyYW0nO1xuICBmb3JtdWxhPzogJ2ZpeGVkJyB8ICdmZWVSYXRlJyB8ICdwZXJLQicgfCAnY3VzdG9tJztcbiAgdHlwZT86ICdiYXNlJyB8ICdtYXgnIHwgJ3RpcCc7XG59O1xuXG4vKipcbiAqIFRoZSB2YWxpZGl0eSB3aW5kb3cgc2lnbmFscyB3aGVuIGEgdHJhbnNhY3Rpb24gY2FuIGJlIGluY2x1ZGVkIGluIHRoZSBuZXR3b3JrLlxuICogIFZhbGlkaXR5V2luZG93IGluZm9ybWF0aW9uIGlzIHN0b3JlZCBhcyBwYXJ0IG9mIHRoZSB0cmFuc2FjdGlvbiBkYXRhIGluIHRoZSBpbmRleGVyIGFuZCB3YWxsZXQgcGxhdGZvcm0sIHVubGVzcyBpdCBpcyBhYnNvbHV0ZWx5IG5lY2Vzc2FyeS5cbiAqIGZpcnN0VmFsaWQ6IHRoZSBhYnNvbHV0ZSBibG9jay90aW1lIGFmdGVyIHdoaWNoIHRoZSB0cmFuc2FjdGlvbiBpcyB2YWxpZFxuICogbGFzdFZhbGlkOiB0aGUgYWJzb2x1dGUgYmxvY2svdGltZSBiZWZvcmUgd2hpY2ggdGhlIHRyYW5zYWN0aW9uIGlzIHZhbGlkXG4gKiBtaW5EdXJhdGlvbjogbWluaW11bSBkdXJhdGlvbiBhIHRyYW5zYWN0aW9uIGZvciB0aGlzIGNvaW4gaXMgdmFsaWRcbiAqIG1heER1cmF0aW9uOiBtYXhpbXVtIGR1cmF0aW9uIGEgdHJhbnNhY3Rpb24gZm9yIHRoaXMgY29pbiBpcyB2YWxpZFxuICogbWluRHVyYXRpb24gYW5kIG1heER1cmF0aW9uIGFyZSBkZWZpbmVkIHBlciBibG9ja2NoYWluLCB3aGVyZWFzIGZpcnN0VmFsaWQgYW5kIGxhc3RWYWxpZCBhcmUgZGVmaW5lZCBwZXIgdHJhbnNhY3Rpb25cbiAqIHVuaXQ6IHZhbGlkaXR5IHdpbmRvdyB3aWxsIGJlIG1lYXN1cmUgaW4gYmxvY2toZWlnaCBvciB0aW1lc3RhbXBcbiAqIFRPRE86IHZhbGlkaXR5V2luZG93IGNvbnN0cmFpbnQgbWV0aG9kcyB3aWxsIGJlIHRha2VuIG9uOiBodHRwczovL2JpdGdvaW5jLmF0bGFzc2lhbi5uZXQvYnJvd3NlL1NUTFgtMTA4MDBcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBWYWxpZGl0eVdpbmRvdyB7XG4gIGZpcnN0VmFsaWQ/OiBudW1iZXI7XG4gIGxhc3RWYWxpZD86IG51bWJlcjtcbiAgbWluRHVyYXRpb24/OiBudW1iZXI7XG4gIG1heER1cmF0aW9uPzogbnVtYmVyO1xuICB1bml0PzogJ2Jsb2NraGVpZ2h0JyB8ICd0aW1lc3RhbXAnO1xufVxuXG4vKipcbiAqIFNlcXVlbmNlIElkcyBhcmUgdXNlZCB0byBkaWZmZXJlbnRpYXRlIHBheW1lbnRzIGNvbWluZyBmcm9tIHRoZSBzYW1lIGFjY291bnQgYW5kIHRvIHByZXZlbnQgYWNjaWRlbnRhbCBkb3VibGUgc3BlbmRzIGFuZCByZXBsYXkgYXR0YWNrcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTZXF1ZW5jZUlkIHtcbiAgbmFtZTogJ05vbmNlJyB8ICdTZXF1ZW5jZSBJZCcgfCAnQ291bnRlcic7XG4gIGtleXdvcmQ6ICdub25jZScgfCAnc2VxdWVuY2VJZCcgfCAnY291bnRlcic7XG4gIHZhbHVlOiBzdHJpbmcgfCBudW1iZXI7XG59XG4iXX0=
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYWNjb3VudC1saWIvYmFzZUNvaW4vaWZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFzREEsd0JBRUM7QUFLRCxvQ0FFQztBQUtELGtDQUVDO0FBS0Qsc0JBR0M7QUFNRCw0QkFHQztBQXBDRDs7R0FFRztBQUNILFNBQWdCLE1BQU0sQ0FBQyxNQUFzQjtJQUMzQyxPQUFRLE1BQWUsQ0FBQyxJQUFJLEtBQUssU0FBUyxDQUFDO0FBQzdDLENBQUM7QUFFRDs7R0FFRztBQUNILFNBQWdCLFlBQVksQ0FBQyxNQUFzQjtJQUNqRCxPQUFRLE1BQXFCLENBQUMsR0FBRyxLQUFLLFNBQVMsQ0FBQztBQUNsRCxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixXQUFXLENBQUMsTUFBc0I7SUFDaEQsT0FBUSxNQUFvQixDQUFDLEdBQUcsS0FBSyxTQUFTLENBQUM7QUFDakQsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0IsS0FBSyxDQUFDLE1BQXNCO0lBQzFDLE1BQU0sR0FBRyxHQUFHLE1BQW9CLENBQUM7SUFDakMsT0FBTyxHQUFHLENBQUMsU0FBUyxLQUFLLFNBQVMsSUFBSSxHQUFHLENBQUMsWUFBWSxLQUFLLFNBQVMsQ0FBQztBQUN2RSxDQUFDO0FBRUQ7OztHQUdHO0FBQ0gsU0FBZ0IsUUFBUSxDQUFDLE1BQXNCO0lBQzdDLE1BQU0sR0FBRyxHQUFHLE1BQWlCLENBQUM7SUFDOUIsT0FBTyxHQUFHLENBQUMsV0FBVyxLQUFLLFNBQVMsSUFBSSxHQUFHLENBQUMsWUFBWSxLQUFLLFNBQVMsQ0FBQztBQUN6RSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSVRyYW5zYWN0aW9uRXhwbGFuYXRpb24gfSBmcm9tICcuLi8uLi9iaXRnbyc7XG5pbXBvcnQgeyBCYXNlVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi9iYXNlVHJhbnNhY3Rpb25CdWlsZGVyJztcbmltcG9ydCB7IEJhc2VUcmFuc2FjdGlvbkJ1aWxkZXJGYWN0b3J5IH0gZnJvbSAnLi9iYXNlVHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFzZUtleSB7XG4gIGtleTogYW55O1xufVxuXG4vKipcbiAqIEEgcHJpdmF0ZSBrZXkgaW4gZXh0ZW5kZWQgb3IgcmF3IGZvcm1hdFxuICovXG5leHBvcnQgdHlwZSBQcml2YXRlS2V5ID0ge1xuICBwcnY6IHN0cmluZztcbn07XG5cbi8qKlxuICogQSBwdWJsaWMga2V5IGluIGV4dGVuZGVkLCBjb21wcmVzc2VkLCBvciB1bmNvbXByZXNzZWQgZm9ybWF0XG4gKi9cbmV4cG9ydCB0eXBlIFB1YmxpY0tleSA9IHtcbiAgcHViOiBzdHJpbmc7XG59O1xuXG4vKipcbiAqIEEgc2VlZCB0byBjcmVhdGUga2V5IHBhaXJzLiBNdXN0IGJlIGJldHdlZW4gMTYgYW5kIDY0IEJ5dGVzIGxvbmdcbiAqL1xuZXhwb3J0IHR5cGUgU2VlZCA9IHtcbiAgc2VlZDogQnVmZmVyO1xufTtcblxuLyoqXG4gKiBUaGUgbnVtYmVyIG9mIHBhcnRpY2lwYW50cyBmb3Igd2hpY2ggdG8gZ2VuZXJhdGUgc2hhcmVzIGFuZCBhIHRocmVzaG9sZCBvZiB0aG9zZSB0aGF0IHdvdWxkIGJlIHJlcXVpcmVkIHdoZW4gc2lnbmluZ1xuICovXG5leHBvcnQgdHlwZSBEa2dPcHRpb25zID0ge1xuICB0aHJlc2hvbGQ6IG51bWJlcjtcbiAgcGFydGljaXBhbnRzOiBudW1iZXI7XG59O1xuXG4vKipcbiAqIFJlcHJlc2VudGF0aW9uIG9mIGEgU2lnbmF0dXJlIHRvIGJlIGFkZGVkIHRvIGEgVHJhbnNhY3Rpb24uXG4gKi9cbmV4cG9ydCB0eXBlIFNpZ25hdHVyZSA9IHtcbiAgcHVibGljS2V5OiBQdWJsaWNLZXk7XG4gIHNpZ25hdHVyZTogQnVmZmVyO1xufTtcblxuZXhwb3J0IHR5cGUgQmxzS2V5UGFpck9wdGlvbnMgPSBEa2dPcHRpb25zIHwgQmxzS2V5cztcblxuZXhwb3J0IHR5cGUgS2V5UGFpck9wdGlvbnMgPSBTZWVkIHwgUHJpdmF0ZUtleSB8IFB1YmxpY0tleSB8IEJsc0tleVBhaXJPcHRpb25zO1xuXG5leHBvcnQgdHlwZSBCYXNlQnVpbGRlciA9IEJhc2VUcmFuc2FjdGlvbkJ1aWxkZXIgfCBCYXNlVHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeTtcblxuLyoqXG4gKiBAcGFyYW0gc291cmNlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc1NlZWQoc291cmNlOiBLZXlQYWlyT3B0aW9ucyk6IHNvdXJjZSBpcyBTZWVkIHtcbiAgcmV0dXJuIChzb3VyY2UgYXMgU2VlZCkuc2VlZCAhPT0gdW5kZWZpbmVkO1xufVxuXG4vKipcbiAqIEBwYXJhbSBzb3VyY2VcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGlzUHJpdmF0ZUtleShzb3VyY2U6IEtleVBhaXJPcHRpb25zKTogc291cmNlIGlzIFByaXZhdGVLZXkge1xuICByZXR1cm4gKHNvdXJjZSBhcyBQcml2YXRlS2V5KS5wcnYgIT09IHVuZGVmaW5lZDtcbn1cblxuLyoqXG4gKiBAcGFyYW0gc291cmNlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc1B1YmxpY0tleShzb3VyY2U6IEtleVBhaXJPcHRpb25zKTogc291cmNlIGlzIFB1YmxpY0tleSB7XG4gIHJldHVybiAoc291cmNlIGFzIFB1YmxpY0tleSkucHViICE9PSB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogQHBhcmFtIHNvdXJjZVxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNEa2coc291cmNlOiBLZXlQYWlyT3B0aW9ucyk6IHNvdXJjZSBpcyBEa2dPcHRpb25zIHtcbiAgY29uc3QgZGtnID0gc291cmNlIGFzIERrZ09wdGlvbnM7XG4gIHJldHVybiBka2cudGhyZXNob2xkICE9PSB1bmRlZmluZWQgJiYgZGtnLnBhcnRpY2lwYW50cyAhPT0gdW5kZWZpbmVkO1xufVxuXG4vKipcbiAqIENoZWNrcyBpZiB0aGUgcHJvdmlkZWQgc291cmNlIGlzIG9mIHR5cGUgYEJsc0tleXNgLlxuICogQHBhcmFtIHNvdXJjZVxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNCbHNLZXkoc291cmNlOiBLZXlQYWlyT3B0aW9ucyk6IHNvdXJjZSBpcyBCbHNLZXlzIHtcbiAgY29uc3QgYmxzID0gc291cmNlIGFzIEJsc0tleXM7XG4gIHJldHVybiBibHMucHVibGljU2hhcmUgIT09IHVuZGVmaW5lZCAmJiBibHMuc2VjcmV0U2hhcmVzICE9PSB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogS2V5IHBhaXIgaW4gdGhlIHByb3RvY29sIGRlZmF1bHQgZm9ybWF0LlxuICovXG5leHBvcnQgdHlwZSBEZWZhdWx0S2V5cyA9IHtcbiAgcHJ2Pzogc3RyaW5nO1xuICBwdWI6IHN0cmluZztcbn07XG5cbi8qKlxuICogS2V5IHBhaXIgaW4gVWludDhBcnJheSBmb3JtYXQuXG4gKi9cbmV4cG9ydCB0eXBlIEJ5dGVLZXlzID0ge1xuICBwcnY/OiBVaW50OEFycmF5O1xuICBwdWI6IFVpbnQ4QXJyYXk7XG59O1xuXG4vKipcbiAqIEtleSBwYWlyIGluIGV4dGVuZGVkIGZvcm1hdC4gVXNlZCBmb3IgY29pbnMgc3VwcG9ydGluZyBzZWNwMjU2azEgZWxsaXB0aWMgY3VydmUuXG4gKi9cbmV4cG9ydCB0eXBlIEV4dGVuZGVkS2V5cyA9IHtcbiAgeHBydj86IHN0cmluZztcbiAgeHB1Yjogc3RyaW5nO1xufTtcblxuLyoqXG4gKiBCTFMgc2lnbmF0dXJlIGtleXMuXG4gKi9cbmV4cG9ydCB0eXBlIEJsc0tleXMgPSB7XG4gIHBydj86IHN0cmluZztcbiAgc2VjcmV0U2hhcmVzOiBzdHJpbmdbXTtcbiAgcHVibGljU2hhcmU6IHN0cmluZztcbiAgc2VlZDogc3RyaW5nO1xuICBjaGFpbmNvZGU6IHN0cmluZztcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFzZUFkZHJlc3Mge1xuICBhZGRyZXNzOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW50cnkgZXh0ZW5kcyBCYXNlQWRkcmVzcyB7XG4gIGNvaW4/OiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFzZUZlZSB7XG4gIGZlZTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zYWN0aW9uUmVjaXBpZW50IHtcbiAgYWRkcmVzczogc3RyaW5nO1xuICBhbW91bnQ6IHN0cmluZyB8IG51bWJlcjtcbiAgbWVtbz86IHN0cmluZztcbiAgdG9rZW5OYW1lPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zYWN0aW9uRmVlIHtcbiAgZmVlOiBzdHJpbmc7XG4gIGZlZVJhdGU/OiBudW1iZXI7XG4gIHNpemU/OiBudW1iZXI7XG4gIHR5cGU/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHJhbnNhY3Rpb25PdXRwdXRzIHtcbiAgb3V0cHV0czogVHJhbnNhY3Rpb25SZWNpcGllbnRbXTtcbiAgb3V0cHV0QW1vdW50OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHJhbnNhY3Rpb25DaGFuZ2VzIHtcbiAgY2hhbmdlT3V0cHV0czogVHJhbnNhY3Rpb25SZWNpcGllbnRbXTtcbiAgY2hhbmdlQW1vdW50OiBzdHJpbmc7XG59XG5cbmV4cG9ydCB0eXBlIFRyYW5zYWN0aW9uRXhwbGFuYXRpb24gPSBJVHJhbnNhY3Rpb25FeHBsYW5hdGlvbjxUcmFuc2FjdGlvbkZlZT47XG4vKipcbiAqIEZlZSBvcHRpb25zLlxuICovXG5leHBvcnQgdHlwZSBGZWVPcHRpb25zID0ge1xuICBhbW91bnQ6IG51bWJlciB8IHN0cmluZztcbiAgdW5pdD86ICdiYXNlVW5pdCcgfCAnY3B1JyB8ICdyYW0nO1xuICBmb3JtdWxhPzogJ2ZpeGVkJyB8ICdmZWVSYXRlJyB8ICdwZXJLQicgfCAnY3VzdG9tJztcbiAgdHlwZT86ICdiYXNlJyB8ICdtYXgnIHwgJ3RpcCc7XG59O1xuXG4vKipcbiAqIFRoZSB2YWxpZGl0eSB3aW5kb3cgc2lnbmFscyB3aGVuIGEgdHJhbnNhY3Rpb24gY2FuIGJlIGluY2x1ZGVkIGluIHRoZSBuZXR3b3JrLlxuICogIFZhbGlkaXR5V2luZG93IGluZm9ybWF0aW9uIGlzIHN0b3JlZCBhcyBwYXJ0IG9mIHRoZSB0cmFuc2FjdGlvbiBkYXRhIGluIHRoZSBpbmRleGVyIGFuZCB3YWxsZXQgcGxhdGZvcm0sIHVubGVzcyBpdCBpcyBhYnNvbHV0ZWx5IG5lY2Vzc2FyeS5cbiAqIGZpcnN0VmFsaWQ6IHRoZSBhYnNvbHV0ZSBibG9jay90aW1lIGFmdGVyIHdoaWNoIHRoZSB0cmFuc2FjdGlvbiBpcyB2YWxpZFxuICogbGFzdFZhbGlkOiB0aGUgYWJzb2x1dGUgYmxvY2svdGltZSBiZWZvcmUgd2hpY2ggdGhlIHRyYW5zYWN0aW9uIGlzIHZhbGlkXG4gKiBtaW5EdXJhdGlvbjogbWluaW11bSBkdXJhdGlvbiBhIHRyYW5zYWN0aW9uIGZvciB0aGlzIGNvaW4gaXMgdmFsaWRcbiAqIG1heER1cmF0aW9uOiBtYXhpbXVtIGR1cmF0aW9uIGEgdHJhbnNhY3Rpb24gZm9yIHRoaXMgY29pbiBpcyB2YWxpZFxuICogbWluRHVyYXRpb24gYW5kIG1heER1cmF0aW9uIGFyZSBkZWZpbmVkIHBlciBibG9ja2NoYWluLCB3aGVyZWFzIGZpcnN0VmFsaWQgYW5kIGxhc3RWYWxpZCBhcmUgZGVmaW5lZCBwZXIgdHJhbnNhY3Rpb25cbiAqIHVuaXQ6IHZhbGlkaXR5IHdpbmRvdyB3aWxsIGJlIG1lYXN1cmUgaW4gYmxvY2toZWlnaCBvciB0aW1lc3RhbXBcbiAqIFRPRE86IHZhbGlkaXR5V2luZG93IGNvbnN0cmFpbnQgbWV0aG9kcyB3aWxsIGJlIHRha2VuIG9uOiBodHRwczovL2JpdGdvaW5jLmF0bGFzc2lhbi5uZXQvYnJvd3NlL1NUTFgtMTA4MDBcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBWYWxpZGl0eVdpbmRvdyB7XG4gIGZpcnN0VmFsaWQ/OiBudW1iZXI7XG4gIGxhc3RWYWxpZD86IG51bWJlcjtcbiAgbWluRHVyYXRpb24/OiBudW1iZXI7XG4gIG1heER1cmF0aW9uPzogbnVtYmVyO1xuICB1bml0PzogJ2Jsb2NraGVpZ2h0JyB8ICd0aW1lc3RhbXAnO1xufVxuXG4vKipcbiAqIFNlcXVlbmNlIElkcyBhcmUgdXNlZCB0byBkaWZmZXJlbnRpYXRlIHBheW1lbnRzIGNvbWluZyBmcm9tIHRoZSBzYW1lIGFjY291bnQgYW5kIHRvIHByZXZlbnQgYWNjaWRlbnRhbCBkb3VibGUgc3BlbmRzIGFuZCByZXBsYXkgYXR0YWNrcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTZXF1ZW5jZUlkIHtcbiAgbmFtZTogJ05vbmNlJyB8ICdTZXF1ZW5jZSBJZCcgfCAnQ291bnRlcic7XG4gIGtleXdvcmQ6ICdub25jZScgfCAnc2VxdWVuY2VJZCcgfCAnY291bnRlcic7XG4gIHZhbHVlOiBzdHJpbmcgfCBudW1iZXI7XG59XG4iXX0=
@@ -1,5 +1,3 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
1
  import { BIP32Interface, ECPairInterface } from '@bitgo-beta/utxo-lib';
4
2
  import { KeyPairOptions, ExtendedKeys } from './iface';
5
3
  import { BaseKeyPair } from './baseKeyPair';
@@ -1 +1 @@
1
- {"version":3,"file":"secp256k1ExtendedKeyPair.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/secp256k1ExtendedKeyPair.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAS,cAAc,EAAU,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAEtF,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAGvC;;GAEG;AACH,8BAAsB,wBAAyB,YAAW,WAAW;IACnE,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,cAAc,GAAG,eAAe;IAUzD,SAAS,CAAC,MAAM,CAAC,EAAE,cAAc,CAAC;IAClC,SAAS,CAAC,OAAO,EAAE,eAAe,CAAC;IACnC,SAAS,CAAC,MAAM,CAAC,EAAE,cAAc,CAAC;IAClC;;;;;OAKG;IACH,SAAS,aAAa,MAAM,CAAC,EAAE,cAAc;IAI7C;;;OAGG;IACH,YAAY,CAAC,EAAE,UAAU,EAAE,EAAE;QAAE,UAAU,EAAE,OAAO,CAAA;KAAE,GAAG,MAAM;IAI7D;;OAEG;IACH,aAAa,IAAI,MAAM,GAAG,SAAS;IAInC;;;;OAIG;IACH,wBAAwB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAW3C;;;;OAIG;IACH,uBAAuB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAW1C;;;;;OAKG;IACH,eAAe,IAAI,YAAY;IAc/B,UAAU,CAAC,MAAM,CAAC,EAAE,aAAa,GAAG,MAAM;IAI1C,OAAO,IAAI,GAAG;CAGf"}
1
+ {"version":3,"file":"secp256k1ExtendedKeyPair.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/secp256k1ExtendedKeyPair.ts"],"names":[],"mappings":"AAAA,OAAO,EAAS,cAAc,EAAU,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAEtF,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAGvC;;GAEG;AACH,8BAAsB,wBAAyB,YAAW,WAAW;IACnE,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,cAAc,GAAG,eAAe;IAUzD,SAAS,CAAC,MAAM,CAAC,EAAE,cAAc,CAAC;IAClC,SAAS,CAAC,OAAO,EAAE,eAAe,CAAC;IACnC,SAAS,CAAC,MAAM,CAAC,EAAE,cAAc,CAAC;IAClC;;;;;OAKG;IACH,SAAS,aAAa,MAAM,CAAC,EAAE,cAAc;IAI7C;;;OAGG;IACH,YAAY,CAAC,EAAE,UAAU,EAAE,EAAE;QAAE,UAAU,EAAE,OAAO,CAAA;KAAE,GAAG,MAAM;IAI7D;;OAEG;IACH,aAAa,IAAI,MAAM,GAAG,SAAS;IAInC;;;;OAIG;IACH,wBAAwB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAW3C;;;;OAIG;IACH,uBAAuB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAW1C;;;;;OAKG;IACH,eAAe,IAAI,YAAY;IAc/B,UAAU,CAAC,MAAM,CAAC,EAAE,aAAa,GAAG,MAAM;IAI1C,OAAO,IAAI,GAAG;CAGf"}