@bitgo-beta/sdk-core 8.2.1-beta.21 → 8.2.1-beta.210

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 (242) hide show
  1. package/CHANGELOG.md +1204 -0
  2. package/dist/src/account-lib/baseCoin/enum.d.ts +6 -1
  3. package/dist/src/account-lib/baseCoin/enum.d.ts.map +1 -1
  4. package/dist/src/account-lib/baseCoin/enum.js +11 -1
  5. package/dist/src/account-lib/mpc/curves/ed25519.d.ts +4 -18
  6. package/dist/src/account-lib/mpc/curves/ed25519.d.ts.map +1 -1
  7. package/dist/src/account-lib/mpc/curves/ed25519.js +6 -60
  8. package/dist/src/account-lib/mpc/index.d.ts +4 -4
  9. package/dist/src/account-lib/mpc/index.d.ts.map +1 -1
  10. package/dist/src/account-lib/mpc/index.js +6 -6
  11. package/dist/src/account-lib/mpc/shamir.d.ts +5 -37
  12. package/dist/src/account-lib/mpc/shamir.d.ts.map +1 -1
  13. package/dist/src/account-lib/mpc/shamir.js +6 -130
  14. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts +39 -9
  15. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -1
  16. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.js +164 -43
  17. package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts +34 -6
  18. package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts.map +1 -1
  19. package/dist/src/account-lib/mpc/tss/ecdsa/types.js +1 -1
  20. package/dist/src/account-lib/mpc/tss/eddsa/eddsa.d.ts +1 -1
  21. package/dist/src/account-lib/mpc/tss/eddsa/eddsa.d.ts.map +1 -1
  22. package/dist/src/account-lib/mpc/tss/eddsa/eddsa.js +1 -1
  23. package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts +0 -3
  24. package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts.map +1 -1
  25. package/dist/src/account-lib/mpc/tss/eddsa/types.js +1 -1
  26. package/dist/src/bitgo/address-book/address-book.d.ts +61 -0
  27. package/dist/src/bitgo/address-book/address-book.d.ts.map +1 -0
  28. package/dist/src/bitgo/address-book/address-book.js +142 -0
  29. package/dist/src/bitgo/address-book/index.d.ts +3 -0
  30. package/dist/src/bitgo/address-book/index.d.ts.map +1 -0
  31. package/dist/src/bitgo/address-book/index.js +15 -0
  32. package/dist/src/bitgo/address-book/types.d.ts +170 -0
  33. package/dist/src/bitgo/address-book/types.d.ts.map +1 -0
  34. package/dist/src/bitgo/address-book/types.js +3 -0
  35. package/dist/src/bitgo/baseCoin/baseCoin.d.ts +18 -1
  36. package/dist/src/bitgo/baseCoin/baseCoin.d.ts.map +1 -1
  37. package/dist/src/bitgo/baseCoin/baseCoin.js +18 -1
  38. package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts +43 -5
  39. package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts.map +1 -1
  40. package/dist/src/bitgo/baseCoin/iBaseCoin.js +1 -1
  41. package/dist/src/bitgo/bitgoBase.d.ts +2 -1
  42. package/dist/src/bitgo/bitgoBase.d.ts.map +1 -1
  43. package/dist/src/bitgo/bitgoBase.js +1 -1
  44. package/dist/src/bitgo/config.d.ts +12 -0
  45. package/dist/src/bitgo/config.d.ts.map +1 -1
  46. package/dist/src/bitgo/enterprise/enterprise.d.ts +13 -10
  47. package/dist/src/bitgo/enterprise/enterprise.d.ts.map +1 -1
  48. package/dist/src/bitgo/enterprise/enterprise.js +29 -14
  49. package/dist/src/bitgo/enterprise/enterprises.d.ts +6 -0
  50. package/dist/src/bitgo/enterprise/enterprises.d.ts.map +1 -1
  51. package/dist/src/bitgo/enterprise/enterprises.js +26 -1
  52. package/dist/src/bitgo/enterprise/iEnterprise.d.ts +4 -4
  53. package/dist/src/bitgo/enterprise/iEnterprise.d.ts.map +1 -1
  54. package/dist/src/bitgo/enterprise/iEnterprise.js +1 -1
  55. package/dist/src/bitgo/enterprise/iEnterprises.d.ts +2 -0
  56. package/dist/src/bitgo/enterprise/iEnterprises.d.ts.map +1 -1
  57. package/dist/src/bitgo/enterprise/iEnterprises.js +1 -1
  58. package/dist/src/bitgo/environments.d.ts +15 -2
  59. package/dist/src/bitgo/environments.d.ts.map +1 -1
  60. package/dist/src/bitgo/environments.js +34 -9
  61. package/dist/src/bitgo/keychain/iKeychains.d.ts +10 -0
  62. package/dist/src/bitgo/keychain/iKeychains.d.ts.map +1 -1
  63. package/dist/src/bitgo/keychain/iKeychains.js +1 -1
  64. package/dist/src/bitgo/keychain/keychains.d.ts.map +1 -1
  65. package/dist/src/bitgo/keychain/keychains.js +31 -24
  66. package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts +124 -89
  67. package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts.map +1 -1
  68. package/dist/src/bitgo/keychain/ovcJsonCodec.js +31 -24
  69. package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts +2 -0
  70. package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts.map +1 -1
  71. package/dist/src/bitgo/pendingApproval/iPendingApproval.js +1 -1
  72. package/dist/src/bitgo/pendingApproval/pendingApproval.d.ts.map +1 -1
  73. package/dist/src/bitgo/pendingApproval/pendingApproval.js +9 -3
  74. package/dist/src/bitgo/recovery/initiate.d.ts +7 -1
  75. package/dist/src/bitgo/recovery/initiate.d.ts.map +1 -1
  76. package/dist/src/bitgo/recovery/initiate.js +1 -1
  77. package/dist/src/bitgo/staking/iStakingWallet.d.ts +38 -2
  78. package/dist/src/bitgo/staking/iStakingWallet.d.ts.map +1 -1
  79. package/dist/src/bitgo/staking/iStakingWallet.js +1 -1
  80. package/dist/src/bitgo/staking/stakingWallet.d.ts +7 -1
  81. package/dist/src/bitgo/staking/stakingWallet.d.ts.map +1 -1
  82. package/dist/src/bitgo/staking/stakingWallet.js +9 -1
  83. package/dist/src/bitgo/trading/iTradingAccount.d.ts +2 -32
  84. package/dist/src/bitgo/trading/iTradingAccount.d.ts.map +1 -1
  85. package/dist/src/bitgo/trading/iTradingAccount.js +1 -1
  86. package/dist/src/bitgo/trading/index.d.ts +0 -15
  87. package/dist/src/bitgo/trading/index.d.ts.map +1 -1
  88. package/dist/src/bitgo/trading/index.js +1 -16
  89. package/dist/src/bitgo/trading/network/index.d.ts +3 -0
  90. package/dist/src/bitgo/trading/network/index.d.ts.map +1 -0
  91. package/dist/src/bitgo/trading/network/index.js +15 -0
  92. package/dist/src/bitgo/trading/network/network.d.ts +35 -0
  93. package/dist/src/bitgo/trading/network/network.d.ts.map +1 -0
  94. package/dist/src/bitgo/trading/network/network.js +97 -0
  95. package/dist/src/bitgo/trading/network/types.d.ts +244 -0
  96. package/dist/src/bitgo/trading/network/types.d.ts.map +1 -0
  97. package/dist/src/bitgo/trading/network/types.js +3 -0
  98. package/dist/src/bitgo/trading/tradingAccount.d.ts +11 -35
  99. package/dist/src/bitgo/trading/tradingAccount.d.ts.map +1 -1
  100. package/dist/src/bitgo/trading/tradingAccount.js +9 -96
  101. package/dist/src/bitgo/tss/common.d.ts +14 -3
  102. package/dist/src/bitgo/tss/common.d.ts.map +1 -1
  103. package/dist/src/bitgo/tss/common.js +21 -2
  104. package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts.map +1 -1
  105. package/dist/src/bitgo/tss/ecdsa/ecdsa.js +8 -16
  106. package/dist/src/bitgo/tss/eddsa/eddsa.d.ts +6 -5
  107. package/dist/src/bitgo/tss/eddsa/eddsa.d.ts.map +1 -1
  108. package/dist/src/bitgo/tss/eddsa/eddsa.js +20 -9
  109. package/dist/src/bitgo/tss/types.d.ts +19 -0
  110. package/dist/src/bitgo/tss/types.d.ts.map +1 -1
  111. package/dist/src/bitgo/tss/types.js +1 -1
  112. package/dist/src/bitgo/utils/abstractUtxoCoinUtil.d.ts +4 -0
  113. package/dist/src/bitgo/utils/abstractUtxoCoinUtil.d.ts.map +1 -1
  114. package/dist/src/bitgo/utils/abstractUtxoCoinUtil.js +17 -2
  115. package/dist/src/bitgo/utils/codecProps.d.ts +7 -0
  116. package/dist/src/bitgo/utils/codecProps.d.ts.map +1 -0
  117. package/dist/src/bitgo/utils/codecProps.js +41 -0
  118. package/dist/src/bitgo/utils/opengpgUtils.d.ts +2 -2
  119. package/dist/src/bitgo/utils/opengpgUtils.d.ts.map +1 -1
  120. package/dist/src/bitgo/utils/opengpgUtils.js +9 -12
  121. package/dist/src/bitgo/utils/postWithCodec.d.ts +18 -0
  122. package/dist/src/bitgo/utils/postWithCodec.d.ts.map +1 -0
  123. package/dist/src/bitgo/utils/postWithCodec.js +59 -0
  124. package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts +59 -12
  125. package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts.map +1 -1
  126. package/dist/src/bitgo/utils/tss/baseTSSUtils.js +71 -9
  127. package/dist/src/bitgo/utils/tss/baseTypes.d.ts +184 -9
  128. package/dist/src/bitgo/utils/tss/baseTypes.d.ts.map +1 -1
  129. package/dist/src/bitgo/utils/tss/baseTypes.js +27 -2
  130. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts +46 -10
  131. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts.map +1 -1
  132. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.js +225 -123
  133. package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts +9 -0
  134. package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts.map +1 -1
  135. package/dist/src/bitgo/utils/tss/ecdsa/types.js +1 -1
  136. package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts +18 -5
  137. package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts.map +1 -1
  138. package/dist/src/bitgo/utils/tss/eddsa/eddsa.js +79 -25
  139. package/dist/src/bitgo/wallet/BuildParams.d.ts +112 -0
  140. package/dist/src/bitgo/wallet/BuildParams.d.ts.map +1 -0
  141. package/dist/src/bitgo/wallet/BuildParams.js +121 -0
  142. package/dist/src/bitgo/wallet/iWallet.d.ts +60 -5
  143. package/dist/src/bitgo/wallet/iWallet.d.ts.map +1 -1
  144. package/dist/src/bitgo/wallet/iWallet.js +1 -1
  145. package/dist/src/bitgo/wallet/iWallets.d.ts +16 -5
  146. package/dist/src/bitgo/wallet/iWallets.d.ts.map +1 -1
  147. package/dist/src/bitgo/wallet/iWallets.js +1 -1
  148. package/dist/src/bitgo/wallet/wallet.d.ts +79 -6
  149. package/dist/src/bitgo/wallet/wallet.d.ts.map +1 -1
  150. package/dist/src/bitgo/wallet/wallet.js +370 -124
  151. package/dist/src/bitgo/wallet/wallets.d.ts +25 -5
  152. package/dist/src/bitgo/wallet/wallets.d.ts.map +1 -1
  153. package/dist/src/bitgo/wallet/wallets.js +168 -51
  154. package/dist/src/index.d.ts +4 -0
  155. package/dist/src/index.d.ts.map +1 -1
  156. package/dist/src/index.js +4 -2
  157. package/dist/src/openssl/index.d.ts +4 -1
  158. package/dist/src/openssl/index.d.ts.map +1 -1
  159. package/dist/src/openssl/index.js +7 -12
  160. package/dist/test/node.utils.d.ts +2 -0
  161. package/dist/test/node.utils.d.ts.map +1 -0
  162. package/dist/test/node.utils.js +5 -0
  163. package/dist/test/unit/account-lib/mpc/tss/ecdsa/ecdsa.d.ts +2 -0
  164. package/dist/test/unit/account-lib/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -0
  165. package/dist/test/unit/account-lib/mpc/tss/ecdsa/ecdsa.js +217 -0
  166. package/dist/test/unit/account-lib/mpc/tss/ecdsa/fixtures.d.ts +3 -0
  167. package/dist/test/unit/account-lib/mpc/tss/ecdsa/fixtures.d.ts.map +1 -0
  168. package/dist/test/unit/account-lib/mpc/tss/ecdsa/fixtures.js +24 -0
  169. package/dist/test/unit/bitgo/utils/abstractUtxoCoinUtil.d.ts +2 -0
  170. package/dist/test/unit/bitgo/utils/abstractUtxoCoinUtil.d.ts.map +1 -0
  171. package/dist/test/unit/bitgo/utils/abstractUtxoCoinUtil.js +25 -0
  172. package/dist/test/unit/bitgo/utils/postWithCodec.d.ts +2 -0
  173. package/dist/test/unit/bitgo/utils/postWithCodec.d.ts.map +1 -0
  174. package/dist/test/unit/bitgo/utils/postWithCodec.js +79 -0
  175. package/dist/test/unit/bitgo/wallet/SendTransactionRequest.d.ts +2 -0
  176. package/dist/test/unit/bitgo/wallet/SendTransactionRequest.d.ts.map +1 -0
  177. package/dist/test/unit/bitgo/wallet/SendTransactionRequest.js +44 -0
  178. package/dist/test/unit/openssl.d.ts +2 -0
  179. package/dist/test/unit/openssl.d.ts.map +1 -0
  180. package/dist/test/unit/openssl.js +39 -0
  181. package/dist/test/unit/units.d.ts +2 -0
  182. package/dist/test/unit/units.d.ts.map +1 -0
  183. package/dist/test/unit/units.js +98 -0
  184. package/dist/tsconfig.tsbuildinfo +1 -8340
  185. package/package.json +21 -17
  186. package/dist/src/account-lib/mpc/hdTree.d.ts +0 -31
  187. package/dist/src/account-lib/mpc/hdTree.d.ts.map +0 -1
  188. package/dist/src/account-lib/mpc/hdTree.js +0 -141
  189. package/dist/src/account-lib/mpc/types.d.ts +0 -5
  190. package/dist/src/account-lib/mpc/types.d.ts.map +0 -1
  191. package/dist/src/account-lib/mpc/types.js +0 -3
  192. package/dist/src/bitgo/trading/affirmation.d.ts +0 -35
  193. package/dist/src/bitgo/trading/affirmation.d.ts.map +0 -1
  194. package/dist/src/bitgo/trading/affirmation.js +0 -53
  195. package/dist/src/bitgo/trading/affirmations.d.ts +0 -23
  196. package/dist/src/bitgo/trading/affirmations.d.ts.map +0 -1
  197. package/dist/src/bitgo/trading/affirmations.js +0 -45
  198. package/dist/src/bitgo/trading/iAffirmation.d.ts +0 -15
  199. package/dist/src/bitgo/trading/iAffirmation.d.ts.map +0 -1
  200. package/dist/src/bitgo/trading/iAffirmation.js +0 -13
  201. package/dist/src/bitgo/trading/iAffirmations.d.ts +0 -10
  202. package/dist/src/bitgo/trading/iAffirmations.d.ts.map +0 -1
  203. package/dist/src/bitgo/trading/iAffirmations.js +0 -3
  204. package/dist/src/bitgo/trading/iSettlement.d.ts +0 -25
  205. package/dist/src/bitgo/trading/iSettlement.d.ts.map +0 -1
  206. package/dist/src/bitgo/trading/iSettlement.js +0 -17
  207. package/dist/src/bitgo/trading/iSettlements.d.ts +0 -19
  208. package/dist/src/bitgo/trading/iSettlements.d.ts.map +0 -1
  209. package/dist/src/bitgo/trading/iSettlements.js +0 -3
  210. package/dist/src/bitgo/trading/iTradingPartner.d.ts +0 -14
  211. package/dist/src/bitgo/trading/iTradingPartner.d.ts.map +0 -1
  212. package/dist/src/bitgo/trading/iTradingPartner.js +0 -17
  213. package/dist/src/bitgo/trading/iTradingPartners.d.ts +0 -15
  214. package/dist/src/bitgo/trading/iTradingPartners.d.ts.map +0 -1
  215. package/dist/src/bitgo/trading/iTradingPartners.js +0 -9
  216. package/dist/src/bitgo/trading/lock.d.ts +0 -16
  217. package/dist/src/bitgo/trading/lock.d.ts.map +0 -1
  218. package/dist/src/bitgo/trading/lock.js +0 -12
  219. package/dist/src/bitgo/trading/payload.d.ts +0 -22
  220. package/dist/src/bitgo/trading/payload.d.ts.map +0 -1
  221. package/dist/src/bitgo/trading/payload.js +0 -3
  222. package/dist/src/bitgo/trading/settlement.d.ts +0 -16
  223. package/dist/src/bitgo/trading/settlement.d.ts.map +0 -1
  224. package/dist/src/bitgo/trading/settlement.js +0 -21
  225. package/dist/src/bitgo/trading/settlements.d.ts +0 -32
  226. package/dist/src/bitgo/trading/settlements.d.ts.map +0 -1
  227. package/dist/src/bitgo/trading/settlements.js +0 -61
  228. package/dist/src/bitgo/trading/trade.d.ts +0 -29
  229. package/dist/src/bitgo/trading/trade.d.ts.map +0 -1
  230. package/dist/src/bitgo/trading/trade.js +0 -11
  231. package/dist/src/bitgo/trading/tradingPartner.d.ts +0 -26
  232. package/dist/src/bitgo/trading/tradingPartner.d.ts.map +0 -1
  233. package/dist/src/bitgo/trading/tradingPartner.js +0 -31
  234. package/dist/src/bitgo/trading/tradingPartners.d.ts +0 -24
  235. package/dist/src/bitgo/trading/tradingPartners.d.ts.map +0 -1
  236. package/dist/src/bitgo/trading/tradingPartners.js +0 -32
  237. package/dist/src/openssl/openssl.d.ts +0 -12
  238. package/dist/src/openssl/openssl.d.ts.map +0 -1
  239. package/dist/src/openssl/openssl.js +0 -48
  240. package/dist/src/openssl/opensslbytes.d.ts +0 -4
  241. package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
  242. package/dist/src/openssl/opensslbytes.js +0 -20
@@ -0,0 +1,18 @@
1
+ import * as t from 'io-ts';
2
+ import { BitGoBase } from '../bitgoBase';
3
+ import { BitGoRequest } from '../../api';
4
+ import { SuperAgent, SuperAgentRequest } from 'superagent';
5
+ /**
6
+ * Try to encode the body with the codec and send the request.
7
+ * If the codec fails to encode the body, send the request with the body as is and set the 'codec-error' header to true.
8
+ * Set the 'io-ts-unknown-properties' header to the list of unknown properties that are present in the body but not the codec.
9
+ * @param bitgo
10
+ * @param url
11
+ * @param codec
12
+ * @param body
13
+ * @param [useEncodedBody=true] - when false, send the original body. Useful when writing new codecs.
14
+ */
15
+ export declare function postWithCodec<TAgent extends BitGoBase | SuperAgent<any>, A extends Record<string, unknown>, O extends Record<string, unknown>>(agent: TAgent, url: string, codec: t.Type<A, O>, body: A, { useEncodedBody, }?: {
16
+ useEncodedBody?: boolean;
17
+ }): TAgent extends BitGoBase ? BitGoRequest : SuperAgentRequest;
18
+ //# sourceMappingURL=postWithCodec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"postWithCodec.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/utils/postWithCodec.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,OAAO,CAAC;AAC3B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAiC3D;;;;;;;;;GASG;AACH,wBAAgB,aAAa,CAC3B,MAAM,SAAS,SAAS,GAAG,UAAU,CAAC,GAAG,CAAC,EAC1C,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACjC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAEjC,KAAK,EAAE,MAAM,EACb,GAAG,EAAE,MAAM,EACX,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,EACnB,IAAI,EAAE,CAAC,EACP,EACE,cAAqB,GACtB,GAAE;IACD,cAAc,CAAC,EAAE,OAAO,CAAC;CACrB,GACL,MAAM,SAAS,SAAS,GAAG,YAAY,GAAG,iBAAiB,CAgB7D"}
@@ -0,0 +1,59 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.postWithCodec = void 0;
4
+ const Either_1 = require("fp-ts/Either");
5
+ /**
6
+ * @param body
7
+ * @param encodedBody
8
+ * @returns a list of unknown properties that are present in the body but not the codec.
9
+ */
10
+ function getUnknownProperties(body, encodedBody) {
11
+ const unknownProperties = [];
12
+ if (body && encodedBody) {
13
+ const bodyKeys = Object.keys(body);
14
+ const encodedBodyKeys = Object.keys(encodedBody);
15
+ const unknownKeys = bodyKeys.filter((key) => !encodedBodyKeys.includes(key));
16
+ unknownProperties.push(...unknownKeys);
17
+ }
18
+ return unknownProperties;
19
+ }
20
+ function getDecodeErrorKeys(codec, body) {
21
+ function toKeyPath(context) {
22
+ return context.flatMap((c) => (c.key ? [c.key] : [])).join('.');
23
+ }
24
+ const errors = codec.decode(body);
25
+ if (Either_1.isLeft(errors)) {
26
+ return errors.left.map((error) => toKeyPath(error.context));
27
+ }
28
+ return [];
29
+ }
30
+ /**
31
+ * Try to encode the body with the codec and send the request.
32
+ * If the codec fails to encode the body, send the request with the body as is and set the 'codec-error' header to true.
33
+ * Set the 'io-ts-unknown-properties' header to the list of unknown properties that are present in the body but not the codec.
34
+ * @param bitgo
35
+ * @param url
36
+ * @param codec
37
+ * @param body
38
+ * @param [useEncodedBody=true] - when false, send the original body. Useful when writing new codecs.
39
+ */
40
+ function postWithCodec(agent, url, codec, body, { useEncodedBody = true, } = {}) {
41
+ let encodedBody;
42
+ let codecError;
43
+ try {
44
+ encodedBody = codec.encode(body);
45
+ codecError = false;
46
+ }
47
+ catch (e) {
48
+ console.error('error encoding request body for url', url, e);
49
+ codecError = true;
50
+ }
51
+ return agent
52
+ .post(url)
53
+ .set('io-ts-codec-encode-error', codecError ? 'true' : 'false')
54
+ .set('io-ts-codec-decode-error', getDecodeErrorKeys(codec, body).join(','))
55
+ .set('io-ts-unknown-properties', encodedBody ? getUnknownProperties(body, encodedBody).join(',') : 'NA')
56
+ .send(useEncodedBody && encodedBody ? encodedBody : body);
57
+ }
58
+ exports.postWithCodec = postWithCodec;
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zdFdpdGhDb2RlYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iaXRnby91dGlscy9wb3N0V2l0aENvZGVjLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUlBLHlDQUFzQztBQUV0Qzs7OztHQUlHO0FBQ0gsU0FBUyxvQkFBb0IsQ0FBQyxJQUE2QixFQUFFLFdBQW9DO0lBQy9GLE1BQU0saUJBQWlCLEdBQWEsRUFBRSxDQUFDO0lBQ3ZDLElBQUksSUFBSSxJQUFJLFdBQVcsRUFBRTtRQUN2QixNQUFNLFFBQVEsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ25DLE1BQU0sZUFBZSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDakQsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDN0UsaUJBQWlCLENBQUMsSUFBSSxDQUFDLEdBQUcsV0FBVyxDQUFDLENBQUM7S0FDeEM7SUFDRCxPQUFPLGlCQUFpQixDQUFDO0FBQzNCLENBQUM7QUFFRCxTQUFTLGtCQUFrQixDQUN6QixLQUFtQixFQUNuQixJQUFPO0lBRVAsU0FBUyxTQUFTLENBQUMsT0FBa0I7UUFDbkMsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsRSxDQUFDO0lBQ0QsTUFBTSxNQUFNLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNsQyxJQUFJLGVBQU0sQ0FBQyxNQUFNLENBQUMsRUFBRTtRQUNsQixPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7S0FDN0Q7SUFDRCxPQUFPLEVBQUUsQ0FBQztBQUNaLENBQUM7QUFFRDs7Ozs7Ozs7O0dBU0c7QUFDSCxTQUFnQixhQUFhLENBSzNCLEtBQWEsRUFDYixHQUFXLEVBQ1gsS0FBbUIsRUFDbkIsSUFBTyxFQUNQLEVBQ0UsY0FBYyxHQUFHLElBQUksTUFHbkIsRUFBRTtJQUVOLElBQUksV0FBMEIsQ0FBQztJQUMvQixJQUFJLFVBQVUsQ0FBQztJQUNmLElBQUk7UUFDRixXQUFXLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNqQyxVQUFVLEdBQUcsS0FBSyxDQUFDO0tBQ3BCO0lBQUMsT0FBTyxDQUFDLEVBQUU7UUFDVixPQUFPLENBQUMsS0FBSyxDQUFDLHFDQUFxQyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUM3RCxVQUFVLEdBQUcsSUFBSSxDQUFDO0tBQ25CO0lBQ0QsT0FBTyxLQUFLO1NBQ1QsSUFBSSxDQUFDLEdBQUcsQ0FBQztTQUNULEdBQUcsQ0FBQywwQkFBMEIsRUFBRSxVQUFVLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDO1NBQzlELEdBQUcsQ0FBQywwQkFBMEIsRUFBRSxrQkFBa0IsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQzFFLEdBQUcsQ0FBQywwQkFBMEIsRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLG9CQUFvQixDQUFDLElBQUksRUFBRSxXQUFXLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztTQUN2RyxJQUFJLENBQUMsY0FBYyxJQUFJLFdBQVcsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQztBQUM5RCxDQUFDO0FBOUJELHNDQThCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHQgZnJvbSAnaW8tdHMnO1xuaW1wb3J0IHsgQml0R29CYXNlIH0gZnJvbSAnLi4vYml0Z29CYXNlJztcbmltcG9ydCB7IEJpdEdvUmVxdWVzdCB9IGZyb20gJy4uLy4uL2FwaSc7XG5pbXBvcnQgeyBTdXBlckFnZW50LCBTdXBlckFnZW50UmVxdWVzdCB9IGZyb20gJ3N1cGVyYWdlbnQnO1xuaW1wb3J0IHsgaXNMZWZ0IH0gZnJvbSAnZnAtdHMvRWl0aGVyJztcblxuLyoqXG4gKiBAcGFyYW0gYm9keVxuICogQHBhcmFtIGVuY29kZWRCb2R5XG4gKiBAcmV0dXJucyBhIGxpc3Qgb2YgdW5rbm93biBwcm9wZXJ0aWVzIHRoYXQgYXJlIHByZXNlbnQgaW4gdGhlIGJvZHkgYnV0IG5vdCB0aGUgY29kZWMuXG4gKi9cbmZ1bmN0aW9uIGdldFVua25vd25Qcm9wZXJ0aWVzKGJvZHk6IFJlY29yZDxzdHJpbmcsIHVua25vd24+LCBlbmNvZGVkQm9keTogUmVjb3JkPHN0cmluZywgdW5rbm93bj4pOiBzdHJpbmdbXSB7XG4gIGNvbnN0IHVua25vd25Qcm9wZXJ0aWVzOiBzdHJpbmdbXSA9IFtdO1xuICBpZiAoYm9keSAmJiBlbmNvZGVkQm9keSkge1xuICAgIGNvbnN0IGJvZHlLZXlzID0gT2JqZWN0LmtleXMoYm9keSk7XG4gICAgY29uc3QgZW5jb2RlZEJvZHlLZXlzID0gT2JqZWN0LmtleXMoZW5jb2RlZEJvZHkpO1xuICAgIGNvbnN0IHVua25vd25LZXlzID0gYm9keUtleXMuZmlsdGVyKChrZXkpID0+ICFlbmNvZGVkQm9keUtleXMuaW5jbHVkZXMoa2V5KSk7XG4gICAgdW5rbm93blByb3BlcnRpZXMucHVzaCguLi51bmtub3duS2V5cyk7XG4gIH1cbiAgcmV0dXJuIHVua25vd25Qcm9wZXJ0aWVzO1xufVxuXG5mdW5jdGlvbiBnZXREZWNvZGVFcnJvcktleXM8QSBleHRlbmRzIFJlY29yZDxzdHJpbmcsIHVua25vd24+LCBPIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgdW5rbm93bj4+KFxuICBjb2RlYzogdC5UeXBlPEEsIE8+LFxuICBib2R5OiBBXG4pOiBzdHJpbmdbXSB7XG4gIGZ1bmN0aW9uIHRvS2V5UGF0aChjb250ZXh0OiB0LkNvbnRleHQpOiBzdHJpbmcge1xuICAgIHJldHVybiBjb250ZXh0LmZsYXRNYXAoKGMpID0+IChjLmtleSA/IFtjLmtleV0gOiBbXSkpLmpvaW4oJy4nKTtcbiAgfVxuICBjb25zdCBlcnJvcnMgPSBjb2RlYy5kZWNvZGUoYm9keSk7XG4gIGlmIChpc0xlZnQoZXJyb3JzKSkge1xuICAgIHJldHVybiBlcnJvcnMubGVmdC5tYXAoKGVycm9yKSA9PiB0b0tleVBhdGgoZXJyb3IuY29udGV4dCkpO1xuICB9XG4gIHJldHVybiBbXTtcbn1cblxuLyoqXG4gKiBUcnkgdG8gZW5jb2RlIHRoZSBib2R5IHdpdGggdGhlIGNvZGVjIGFuZCBzZW5kIHRoZSByZXF1ZXN0LlxuICogSWYgdGhlIGNvZGVjIGZhaWxzIHRvIGVuY29kZSB0aGUgYm9keSwgc2VuZCB0aGUgcmVxdWVzdCB3aXRoIHRoZSBib2R5IGFzIGlzIGFuZCBzZXQgdGhlICdjb2RlYy1lcnJvcicgaGVhZGVyIHRvIHRydWUuXG4gKiBTZXQgdGhlICdpby10cy11bmtub3duLXByb3BlcnRpZXMnIGhlYWRlciB0byB0aGUgbGlzdCBvZiB1bmtub3duIHByb3BlcnRpZXMgdGhhdCBhcmUgcHJlc2VudCBpbiB0aGUgYm9keSBidXQgbm90IHRoZSBjb2RlYy5cbiAqIEBwYXJhbSBiaXRnb1xuICogQHBhcmFtIHVybFxuICogQHBhcmFtIGNvZGVjXG4gKiBAcGFyYW0gYm9keVxuICogQHBhcmFtIFt1c2VFbmNvZGVkQm9keT10cnVlXSAtIHdoZW4gZmFsc2UsIHNlbmQgdGhlIG9yaWdpbmFsIGJvZHkuIFVzZWZ1bCB3aGVuIHdyaXRpbmcgbmV3IGNvZGVjcy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHBvc3RXaXRoQ29kZWM8XG4gIFRBZ2VudCBleHRlbmRzIEJpdEdvQmFzZSB8IFN1cGVyQWdlbnQ8YW55PixcbiAgQSBleHRlbmRzIFJlY29yZDxzdHJpbmcsIHVua25vd24+LFxuICBPIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbj4oXG4gIGFnZW50OiBUQWdlbnQsXG4gIHVybDogc3RyaW5nLFxuICBjb2RlYzogdC5UeXBlPEEsIE8+LFxuICBib2R5OiBBLFxuICB7XG4gICAgdXNlRW5jb2RlZEJvZHkgPSB0cnVlLFxuICB9OiB7XG4gICAgdXNlRW5jb2RlZEJvZHk/OiBib29sZWFuO1xuICB9ID0ge31cbik6IFRBZ2VudCBleHRlbmRzIEJpdEdvQmFzZSA/IEJpdEdvUmVxdWVzdCA6IFN1cGVyQWdlbnRSZXF1ZXN0IHtcbiAgbGV0IGVuY29kZWRCb2R5OiBPIHwgdW5kZWZpbmVkO1xuICBsZXQgY29kZWNFcnJvcjtcbiAgdHJ5IHtcbiAgICBlbmNvZGVkQm9keSA9IGNvZGVjLmVuY29kZShib2R5KTtcbiAgICBjb2RlY0Vycm9yID0gZmFsc2U7XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICBjb25zb2xlLmVycm9yKCdlcnJvciBlbmNvZGluZyByZXF1ZXN0IGJvZHkgZm9yIHVybCcsIHVybCwgZSk7XG4gICAgY29kZWNFcnJvciA9IHRydWU7XG4gIH1cbiAgcmV0dXJuIGFnZW50XG4gICAgLnBvc3QodXJsKVxuICAgIC5zZXQoJ2lvLXRzLWNvZGVjLWVuY29kZS1lcnJvcicsIGNvZGVjRXJyb3IgPyAndHJ1ZScgOiAnZmFsc2UnKVxuICAgIC5zZXQoJ2lvLXRzLWNvZGVjLWRlY29kZS1lcnJvcicsIGdldERlY29kZUVycm9yS2V5cyhjb2RlYywgYm9keSkuam9pbignLCcpKVxuICAgIC5zZXQoJ2lvLXRzLXVua25vd24tcHJvcGVydGllcycsIGVuY29kZWRCb2R5ID8gZ2V0VW5rbm93blByb3BlcnRpZXMoYm9keSwgZW5jb2RlZEJvZHkpLmpvaW4oJywnKSA6ICdOQScpXG4gICAgLnNlbmQodXNlRW5jb2RlZEJvZHkgJiYgZW5jb2RlZEJvZHkgPyBlbmNvZGVkQm9keSA6IGJvZHkpO1xufVxuIl19
@@ -5,8 +5,8 @@ import { BitGoBase } from '../../bitgoBase';
5
5
  import { Keychain } from '../../keychain';
6
6
  import { IWallet, BackupProvider } from '../../wallet';
7
7
  import { MpcUtils } from '../mpcUtils';
8
- import { BitgoHeldBackupKeyShare, CustomGShareGeneratingFunction, CustomRShareGeneratingFunction, ITssUtils, PrebuildTransactionWithIntentOptions, SignatureShareRecord, TSSParams, TxRequest, TxRequestVersion, CreateKeychainParamsBase, IntentOptionsForMessage, IntentOptionsForTypedData, CreateBitGoKeychainParamsBase } from './baseTypes';
9
- import { GShare, SignShare, YShare } from '../../../account-lib/mpc/tss';
8
+ import { BitgoHeldBackupKeyShare, CustomGShareGeneratingFunction, CustomRShareGeneratingFunction, ITssUtils, PrebuildTransactionWithIntentOptions, SignatureShareRecord, TSSParams, TxRequest, TxRequestVersion, CreateKeychainParamsBase, IntentOptionsForMessage, IntentOptionsForTypedData, CreateBitGoKeychainParamsBase, CommitmentShareRecord, EncryptedSignerShareRecord, CustomCommitmentGeneratingFunction, TSSParamsForMessage, RequestType, CustomPaillierModulusGetterFunction, CustomKShareGeneratingFunction, CustomMuDeltaShareGeneratingFunction, CustomSShareGeneratingFunction } from './baseTypes';
9
+ import { GShare, SignShare } from '../../../account-lib/mpc/tss';
10
10
  /**
11
11
  * BaseTssUtil class which different signature schemes have to extend
12
12
  */
@@ -36,28 +36,64 @@ export default class BaseTssUtils<KeyShare> extends MpcUtils implements ITssUtil
36
36
  * @param {CustomGShareGeneratingFunction} externalSignerGShareGenerator a function that creates G shares in the EdDSA TSS flow
37
37
  * @returns {Promise<TxRequest>} - a signed tx request
38
38
  */
39
- signUsingExternalSigner(txRequest: string | TxRequest, externalSignerRShareGenerator: CustomRShareGeneratingFunction, externalSignerGShareGenerator: CustomGShareGeneratingFunction): Promise<TxRequest>;
39
+ signEddsaTssUsingExternalSigner(txRequest: string | TxRequest, externalSignerCommitmentGenerator: CustomCommitmentGeneratingFunction, externalSignerRShareGenerator: CustomRShareGeneratingFunction, externalSignerGShareGenerator: CustomGShareGeneratingFunction): Promise<TxRequest>;
40
+ /**
41
+ * Signs a transaction using TSS for ECDSA and through utilization of custom share generators
42
+ *
43
+ * @param {params: TSSParams | TSSParamsForMessage} params - params object that represents parameters to sign a transaction or a message.
44
+ * @param {RequestType} requestType - the type of the request to sign (transaction or message).
45
+ * @param {CustomPaillierModulusGetterFunction} externalSignerPaillierModulusGetter a function that creates Paillier Modulus shares in the ECDSA TSS flow.
46
+ * @param {CustomKShareGeneratingFunction} externalSignerKShareGenerator a function that creates K shares in the ECDSA TSS flow.
47
+ * @param {CustomMuDeltaShareGeneratingFunction} externalSignerMuDeltaShareGenerator a function that creates Mu and Delta shares in the ECDSA TSS flow.
48
+ * @param {CustomSShareGeneratingFunction} externalSignerSShareGenerator a function that creates S shares in the ECDSA TSS flow.
49
+ */
50
+ signEcdsaTssUsingExternalSigner(params: TSSParams | TSSParamsForMessage, requestType: RequestType, externalSignerPaillierModulusGetter: CustomPaillierModulusGetterFunction, externalSignerKShareGenerator: CustomKShareGeneratingFunction, externalSignerMuDeltaShareGenerator: CustomMuDeltaShareGeneratingFunction, externalSignerSShareGenerator: CustomSShareGeneratingFunction): Promise<TxRequest>;
51
+ /**
52
+ * Create an Commitment (User to BitGo) share from an unsigned transaction and private user signing material
53
+ * EDDSA only
54
+ *
55
+ * @param {Object} params - params object
56
+ * @param {TxRequest} params.txRequest - transaction request with unsigned transaction
57
+ * @param {string} params.prv - user signing material
58
+ * @param {string} params.walletPassphrase - wallet passphrase
59
+ *
60
+ * @returns {Promise<{ userToBitgoCommitment: CommitmentShareRecor, encryptedSignerShare: EncryptedSignerShareRecord }>} - Commitment Share and the Encrypted Signer Share to BitGo
61
+ */
62
+ createCommitmentShareFromTxRequest(params: {
63
+ txRequest: TxRequest;
64
+ prv: string;
65
+ walletPassphrase: string;
66
+ }): Promise<{
67
+ userToBitgoCommitment: CommitmentShareRecord;
68
+ encryptedSignerShare: EncryptedSignerShareRecord;
69
+ encryptedUserToBitgoRShare: EncryptedSignerShareRecord;
70
+ }>;
40
71
  /**
41
72
  * Create an R (User to BitGo) share from an unsigned transaction and private user signing material
42
73
  *
43
- * @param {TxRequest} txRequest - transaction request with unsigned transaction
44
- * @param {string} prv - user signing material
45
- * @returns {Promise<{ rShare: SignShare; signingKeyYShare: YShare }>} - R Share and the Signing Key's Y share to BitGo
74
+ * @param {Object} params - params object
75
+ * @param {TxRequest} params.txRequest - transaction request with unsigned transaction
76
+ * @param {string} params.prv - user signing material
77
+ * @param {string} [params.walletPassphrase] - wallet passphrase
78
+ * @param {EncryptedSignerShareRecord} [params.encryptedUserToBitgoRShare] - encrypted user to bitgo R share generated in the commitment phase
79
+ * @returns {Promise<{ rShare: SignShare }>} - R Share to BitGo
46
80
  */
47
81
  createRShareFromTxRequest(params: {
48
82
  txRequest: TxRequest;
49
- prv: string;
83
+ walletPassphrase: string;
84
+ encryptedUserToBitgoRShare: EncryptedSignerShareRecord;
50
85
  }): Promise<{
51
86
  rShare: SignShare;
52
- signingKeyYShare: YShare;
53
87
  }>;
54
88
  /**
55
89
  * Create a G (User to BitGo) share from an unsigned transaction and private user signing material
56
90
  *
57
- * @param {TxRequest} txRequest - transaction request with unsigned transaction
58
- * @param {string} prv - user signing material
59
- * @param {SignatureShareRecord} bitgoToUserRShare - BitGo to User R Share
60
- * @param {SignShare} userToBitgoRShare - User to BitGo R Share
91
+ * @param {Object} params - params object
92
+ * @param {TxRequest} params.txRequest - transaction request with unsigned transaction
93
+ * @param {string} params.prv - user signing material
94
+ * @param {SignatureShareRecord} params.bitgoToUserRShare - BitGo to User R Share
95
+ * @param {SignShare} params.userToBitgoRShare - User to BitGo R Share
96
+ * @param {CommitmentShareRecord} params.bitgoToUserCommitment - BitGo to User Commitment
61
97
  * @returns {Promise<GShare>} - GShare from User to BitGo
62
98
  */
63
99
  createGShareFromTxRequest(params: {
@@ -65,6 +101,7 @@ export default class BaseTssUtils<KeyShare> extends MpcUtils implements ITssUtil
65
101
  prv: string;
66
102
  bitgoToUserRShare: SignatureShareRecord;
67
103
  userToBitgoRShare: SignShare;
104
+ bitgoToUserCommitment: CommitmentShareRecord;
68
105
  }): Promise<GShare>;
69
106
  /**
70
107
  * Builds a tx request from params and verify it
@@ -140,5 +177,15 @@ export default class BaseTssUtils<KeyShare> extends MpcUtils implements ITssUtil
140
177
  * @param enterpriseId - enterprise under which user wants to create the wallet
141
178
  */
142
179
  getBitgoGpgPubkeyBasedOnFeatureFlags(enterpriseId: string | undefined): Promise<Key>;
180
+ /**
181
+ * Returns supported TxRequest versions for this wallet
182
+ */
183
+ supportedTxRequestVersions(): TxRequestVersion[];
184
+ /**
185
+ * Returns true if the txRequest is using apiVersion == full and is pending approval
186
+ * @param txRequest
187
+ * @returns boolean
188
+ */
189
+ isPendingApprovalTxRequestFull(txRequest: TxRequest): boolean;
143
190
  }
144
191
  //# sourceMappingURL=baseTSSUtils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"baseTSSUtils.d.ts","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTSSUtils.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"baseTSSUtils.d.ts","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTSSUtils.ts"],"names":[],"mappings":"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"}
@@ -82,15 +82,45 @@ class BaseTssUtils extends mpcUtils_1.MpcUtils {
82
82
  * @param {CustomGShareGeneratingFunction} externalSignerGShareGenerator a function that creates G shares in the EdDSA TSS flow
83
83
  * @returns {Promise<TxRequest>} - a signed tx request
84
84
  */
85
- signUsingExternalSigner(txRequest, externalSignerRShareGenerator, externalSignerGShareGenerator) {
85
+ signEddsaTssUsingExternalSigner(txRequest, externalSignerCommitmentGenerator, externalSignerRShareGenerator, externalSignerGShareGenerator) {
86
+ throw new Error('Method not implemented.');
87
+ }
88
+ /**
89
+ * Signs a transaction using TSS for ECDSA and through utilization of custom share generators
90
+ *
91
+ * @param {params: TSSParams | TSSParamsForMessage} params - params object that represents parameters to sign a transaction or a message.
92
+ * @param {RequestType} requestType - the type of the request to sign (transaction or message).
93
+ * @param {CustomPaillierModulusGetterFunction} externalSignerPaillierModulusGetter a function that creates Paillier Modulus shares in the ECDSA TSS flow.
94
+ * @param {CustomKShareGeneratingFunction} externalSignerKShareGenerator a function that creates K shares in the ECDSA TSS flow.
95
+ * @param {CustomMuDeltaShareGeneratingFunction} externalSignerMuDeltaShareGenerator a function that creates Mu and Delta shares in the ECDSA TSS flow.
96
+ * @param {CustomSShareGeneratingFunction} externalSignerSShareGenerator a function that creates S shares in the ECDSA TSS flow.
97
+ */
98
+ signEcdsaTssUsingExternalSigner(params, requestType, externalSignerPaillierModulusGetter, externalSignerKShareGenerator, externalSignerMuDeltaShareGenerator, externalSignerSShareGenerator) {
99
+ throw new Error('Method not implemented.');
100
+ }
101
+ /**
102
+ * Create an Commitment (User to BitGo) share from an unsigned transaction and private user signing material
103
+ * EDDSA only
104
+ *
105
+ * @param {Object} params - params object
106
+ * @param {TxRequest} params.txRequest - transaction request with unsigned transaction
107
+ * @param {string} params.prv - user signing material
108
+ * @param {string} params.walletPassphrase - wallet passphrase
109
+ *
110
+ * @returns {Promise<{ userToBitgoCommitment: CommitmentShareRecor, encryptedSignerShare: EncryptedSignerShareRecord }>} - Commitment Share and the Encrypted Signer Share to BitGo
111
+ */
112
+ createCommitmentShareFromTxRequest(params) {
86
113
  throw new Error('Method not implemented.');
87
114
  }
88
115
  /**
89
116
  * Create an R (User to BitGo) share from an unsigned transaction and private user signing material
90
117
  *
91
- * @param {TxRequest} txRequest - transaction request with unsigned transaction
92
- * @param {string} prv - user signing material
93
- * @returns {Promise<{ rShare: SignShare; signingKeyYShare: YShare }>} - R Share and the Signing Key's Y share to BitGo
118
+ * @param {Object} params - params object
119
+ * @param {TxRequest} params.txRequest - transaction request with unsigned transaction
120
+ * @param {string} params.prv - user signing material
121
+ * @param {string} [params.walletPassphrase] - wallet passphrase
122
+ * @param {EncryptedSignerShareRecord} [params.encryptedUserToBitgoRShare] - encrypted user to bitgo R share generated in the commitment phase
123
+ * @returns {Promise<{ rShare: SignShare }>} - R Share to BitGo
94
124
  */
95
125
  createRShareFromTxRequest(params) {
96
126
  throw new Error('Method not implemented.');
@@ -98,10 +128,12 @@ class BaseTssUtils extends mpcUtils_1.MpcUtils {
98
128
  /**
99
129
  * Create a G (User to BitGo) share from an unsigned transaction and private user signing material
100
130
  *
101
- * @param {TxRequest} txRequest - transaction request with unsigned transaction
102
- * @param {string} prv - user signing material
103
- * @param {SignatureShareRecord} bitgoToUserRShare - BitGo to User R Share
104
- * @param {SignShare} userToBitgoRShare - User to BitGo R Share
131
+ * @param {Object} params - params object
132
+ * @param {TxRequest} params.txRequest - transaction request with unsigned transaction
133
+ * @param {string} params.prv - user signing material
134
+ * @param {SignatureShareRecord} params.bitgoToUserRShare - BitGo to User R Share
135
+ * @param {SignShare} params.userToBitgoRShare - User to BitGo R Share
136
+ * @param {CommitmentShareRecord} params.bitgoToUserCommitment - BitGo to User Commitment
105
137
  * @returns {Promise<GShare>} - GShare from User to BitGo
106
138
  */
107
139
  createGShareFromTxRequest(params) {
@@ -261,6 +293,36 @@ class BaseTssUtils extends mpcUtils_1.MpcUtils {
261
293
  const bitgoPublicKeyStr = response.publicKey;
262
294
  return openpgp_1.readKey({ armoredKey: bitgoPublicKeyStr });
263
295
  }
296
+ /**
297
+ * Returns supported TxRequest versions for this wallet
298
+ */
299
+ supportedTxRequestVersions() {
300
+ var _a, _b, _c, _d;
301
+ const walletType = (_a = this._wallet) === null || _a === void 0 ? void 0 : _a.type();
302
+ const supportedWalletTypes = ['custodial', 'cold', 'hot'];
303
+ if (!walletType || ((_b = this._wallet) === null || _b === void 0 ? void 0 : _b.multisigType()) !== 'tss' || !supportedWalletTypes.includes(walletType)) {
304
+ return [];
305
+ }
306
+ else if (((_c = this._wallet) === null || _c === void 0 ? void 0 : _c.baseCoin.getMPCAlgorithm()) === 'ecdsa') {
307
+ return ['full'];
308
+ }
309
+ else if (walletType === 'custodial' || walletType === 'cold') {
310
+ return ['full'];
311
+ }
312
+ else if (((_d = this._wallet) === null || _d === void 0 ? void 0 : _d.baseCoin.getMPCAlgorithm()) === 'eddsa' && walletType === 'hot') {
313
+ return ['lite', 'full'];
314
+ }
315
+ return [];
316
+ }
317
+ /**
318
+ * Returns true if the txRequest is using apiVersion == full and is pending approval
319
+ * @param txRequest
320
+ * @returns boolean
321
+ */
322
+ isPendingApprovalTxRequestFull(txRequest) {
323
+ const { apiVersion, state } = txRequest;
324
+ return apiVersion === 'full' && 'pendingApproval' === state;
325
+ }
264
326
  }
265
327
  exports.default = BaseTssUtils;
266
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTSSUtils.js","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTSSUtils.ts"],"names":[],"mappings":"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","sourcesContent":["import { IRequestTracer } from '../../../api';\nimport { Key, readKey, SerializedKeyPair } from 'openpgp';\nimport { IBaseCoin, KeychainsTriplet } from '../../baseCoin';\nimport { BitGoBase } from '../../bitgoBase';\nimport { Keychain } from '../../keychain';\nimport { getTxRequest } from '../../tss';\nimport { IWallet, BackupProvider } from '../../wallet';\nimport { MpcUtils } from '../mpcUtils';\nimport * as _ from 'lodash';\nimport {\n  BitgoGPGPublicKey,\n  BitgoHeldBackupKeyShare,\n  CustomGShareGeneratingFunction,\n  CustomRShareGeneratingFunction,\n  ITssUtils,\n  PrebuildTransactionWithIntentOptions,\n  SignatureShareRecord,\n  TSSParams,\n  TxRequest,\n  TxRequestVersion,\n  CreateKeychainParamsBase,\n  IntentOptionsForMessage,\n  PopulatedIntentForMessageSigning,\n  IntentOptionsForTypedData,\n  PopulatedIntentForTypedDataSigning,\n  CreateBitGoKeychainParamsBase,\n} from './baseTypes';\nimport { GShare, SignShare, YShare } from '../../../account-lib/mpc/tss';\n\n/**\n * BaseTssUtil class which different signature schemes have to extend\n */\nexport default class BaseTssUtils<KeyShare> extends MpcUtils implements ITssUtils<KeyShare> {\n  private _wallet?: IWallet;\n\n  constructor(bitgo: BitGoBase, baseCoin: IBaseCoin, wallet?: IWallet) {\n    super(bitgo, baseCoin);\n    this._wallet = wallet;\n  }\n\n  get wallet(): IWallet {\n    if (_.isNil(this._wallet)) {\n      throw new Error('Wallet not defined');\n    }\n    return this._wallet;\n  }\n\n  async createBitgoHeldBackupKeyShare(\n    userGpgKey: SerializedKeyPair<string>,\n    enterprise: string | undefined\n  ): Promise<BitgoHeldBackupKeyShare> {\n    const keyResponse = await this.bitgo\n      .post(this.baseCoin.url('/krs/backupkeys'))\n      .send({\n        enterprise,\n        userGPGPublicKey: userGpgKey.publicKey,\n      })\n      .result();\n    if (!keyResponse || !keyResponse.keyShares) {\n      throw new Error('Failed to get backup shares from BitGo.');\n    }\n    return {\n      id: keyResponse.id,\n      keyShares: keyResponse.keyShares,\n    };\n  }\n\n  public finalizeBitgoHeldBackupKeyShare(\n    keyId: string,\n    commonKeychain: string,\n    userKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    userGpgKey: SerializedKeyPair<string>,\n    backupGpgKey: Key\n  ): Promise<BitgoHeldBackupKeyShare> {\n    throw new Error('Method not implemented.');\n  }\n\n  createUserKeychain(params: CreateKeychainParamsBase): Promise<Keychain> {\n    throw new Error('Method not implemented.');\n  }\n\n  createBackupKeychain(params: CreateKeychainParamsBase): Promise<Keychain> {\n    throw new Error('Method not implemented.');\n  }\n\n  createBitgoKeychain(params: CreateBitGoKeychainParamsBase): Promise<Keychain> {\n    throw new Error('Method not implemented.');\n  }\n\n  createKeychains(params: {\n    passphrase: string;\n    enterprise?: string | undefined;\n    originalPasscodeEncryptionCode?: string | undefined;\n    isThirdPartyBackup?: boolean;\n    backupProvider?: BackupProvider;\n  }): Promise<KeychainsTriplet> {\n    throw new Error('Method not implemented.');\n  }\n\n  signTxRequest(params: TSSParams): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  signTxRequestForMessage(params: TSSParams): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Signs a transaction using TSS for EdDSA and through utilization of custom share generators\n   *\n   * @param {string | TxRequest} txRequest - transaction request with unsigned transaction\n   * @param {CustomRShareGeneratingFunction} externalSignerRShareGenerator a function that creates R shares in the EdDSA TSS flow\n   * @param {CustomGShareGeneratingFunction} externalSignerGShareGenerator a function that creates G shares in the EdDSA TSS flow\n   * @returns {Promise<TxRequest>} - a signed tx request\n   */\n  signUsingExternalSigner(\n    txRequest: string | TxRequest,\n    externalSignerRShareGenerator: CustomRShareGeneratingFunction,\n    externalSignerGShareGenerator: CustomGShareGeneratingFunction\n  ): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Create an R (User to BitGo) share from an unsigned transaction and private user signing material\n   *\n   * @param {TxRequest} txRequest - transaction request with unsigned transaction\n   * @param {string} prv - user signing material\n   * @returns {Promise<{ rShare: SignShare; signingKeyYShare: YShare }>} - R Share and the Signing Key's Y share to BitGo\n   */\n  createRShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    prv: string;\n  }): Promise<{ rShare: SignShare; signingKeyYShare: YShare }> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Create a G (User to BitGo) share from an unsigned transaction and private user signing material\n   *\n   * @param {TxRequest} txRequest - transaction request with unsigned transaction\n   * @param {string} prv - user signing material\n   * @param {SignatureShareRecord} bitgoToUserRShare - BitGo to User R Share\n   * @param {SignShare} userToBitgoRShare - User to BitGo R Share\n   * @returns {Promise<GShare>} - GShare from User to BitGo\n   */\n  createGShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    prv: string;\n    bitgoToUserRShare: SignatureShareRecord;\n    userToBitgoRShare: SignShare;\n  }): Promise<GShare> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Builds a tx request from params and verify it\n   *\n   * @param {PrebuildTransactionWithIntentOptions} params - parameters to build the tx\n   * @param {TxRequestVersion} apiVersion lite or full\n   * @param {boolean} preview boolean indicating if this is to preview a tx request, which will not initiate policy checks or pending approvals\n   * @returns {Promise<TxRequest>} - a built tx request\n   */\n  async prebuildTxWithIntent(\n    params: PrebuildTransactionWithIntentOptions,\n    apiVersion: TxRequestVersion = 'lite',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const intentOptions = this.populateIntent(this.baseCoin, params);\n\n    const whitelistedParams = {\n      intent: {\n        ...intentOptions,\n      },\n      apiVersion: apiVersion,\n      preview,\n    };\n\n    const unsignedTx = (await this.bitgo\n      .post(this.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests', 2))\n      .send(whitelistedParams)\n      .result()) as TxRequest;\n\n    return unsignedTx;\n  }\n\n  /**\n   * Create a tx request from params for message signing\n   *\n   * @param params\n   * @param apiVersion\n   * @param preview\n   */\n  async createTxRequestWithIntentForMessageSigning(\n    params: IntentOptionsForMessage,\n    apiVersion: TxRequestVersion = 'full',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const intentOptions: PopulatedIntentForMessageSigning = {\n      custodianMessageId: params.custodianMessageId,\n      intentType: params.intentType,\n      sequenceId: params.sequenceId,\n      comment: params.comment,\n      memo: params.memo?.value,\n      isTss: params.isTss,\n      messageRaw: params.messageRaw,\n      messageEncoded: params.messageEncoded ?? '',\n    };\n\n    return this.createTxRequestBase(intentOptions, apiVersion, preview);\n  }\n\n  /**\n   * Create a tx request from params for type data signing\n   *\n   * @param params\n   * @param apiVersion\n   * @param preview\n   */\n  async createTxRequestWithIntentForTypedDataSigning(\n    params: IntentOptionsForTypedData,\n    apiVersion: TxRequestVersion = 'full',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const intentOptions: PopulatedIntentForTypedDataSigning = {\n      custodianMessageId: params.custodianMessageId,\n      intentType: params.intentType,\n      sequenceId: params.sequenceId,\n      comment: params.comment,\n      memo: params.memo?.value,\n      isTss: params.isTss,\n      messageRaw: params.typedDataRaw,\n      messageEncoded: params.typedDataEncoded ?? '',\n    };\n\n    return this.createTxRequestBase(intentOptions, apiVersion, preview);\n  }\n\n  /**\n   * Calls Bitgo API to create tx request.\n   *\n   * @private\n   */\n  private async createTxRequestBase(\n    intentOptions: PopulatedIntentForTypedDataSigning | PopulatedIntentForMessageSigning,\n    apiVersion: TxRequestVersion,\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const whitelistedParams = {\n      intent: {\n        ...intentOptions,\n      },\n      apiVersion,\n      preview,\n    };\n\n    return this.bitgo\n      .post(this.bitgo.url(`/wallet/${this.wallet.id()}/txrequests`, 2))\n      .send(whitelistedParams)\n      .result();\n  }\n\n  /**\n   * Call delete signature shares for a txRequest, the endpoint delete the signatures and return them\n   *\n   * @param {string} txRequestId tx id reference to delete signature shares\n   * @returns {SignatureShareRecord[]}\n   */\n  async deleteSignatureShares(txRequestId: string): Promise<SignatureShareRecord[]> {\n    return this.bitgo\n      .del(this.bitgo.url(`/wallet/${this.wallet.id()}/txrequests/${txRequestId}/signatureshares`, 2))\n      .send()\n      .result();\n  }\n\n  /**\n   * Initialize the send procedure once Bitgo has the User To Bitgo GShare\n   *\n   * @param {String} txRequestId - the txRequest Id\n   * @returns {Promise<any>}\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  async sendTxRequest(txRequestId: string): Promise<any> {\n    return this.bitgo\n      .post(this.baseCoin.url('/wallet/' + this.wallet.id() + '/tx/send'))\n      .send({ txRequestId })\n      .result();\n  }\n\n  /**\n   * Delete signature shares, get the tx request without them from the db and sign it to finally send it.\n   *\n   * Note : This can be performed in order to reach latest network conditions required on pending approval flow.\n   *\n   * @param {String} txRequestId - the txRequest Id to make the requests.\n   * @param {String} decryptedPrv - decrypted prv to sign the tx request.\n   * @param {RequestTracer} reqId id tracer.\n   * @returns {Promise<any>}\n   */\n  async recreateTxRequest(txRequestId: string, decryptedPrv: string, reqId: IRequestTracer): Promise<TxRequest> {\n    await this.deleteSignatureShares(txRequestId);\n    // after delete signatures shares get the tx without them\n    const txRequest = await getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n    return await this.signTxRequest({ txRequest, prv: decryptedPrv, reqId });\n  }\n\n  /**\n   * Gets the latest Tx Request by id\n   *\n   * @param {String} txRequestId - the txRequest Id\n   * @returns {Promise<TxRequest>}\n   */\n  async getTxRequest(txRequestId: string): Promise<TxRequest> {\n    return getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n  }\n\n  /**\n   * Checks whether the third party backup provider is valid/supported\n   * @param backupProvider - the backup provider client selected\n   */\n  isValidThirdPartyBackupProvider(\n    backupProvider: BackupProvider | string | undefined\n  ): backupProvider is BackupProvider {\n    // As of now, BitGo is the only supported KRS provider for TSS\n    return !!(backupProvider && backupProvider === 'BitGoTrustAsKrs');\n  }\n\n  /**\n   * It gets the appropriate BitGo GPG public key for key creation based on a\n   * combination of coin and the feature flags on the user and their enterprise if set.\n   * @param enterpriseId - enterprise under which user wants to create the wallet\n   */\n  public async getBitgoGpgPubkeyBasedOnFeatureFlags(enterpriseId: string | undefined): Promise<Key> {\n    const response: BitgoGPGPublicKey = await this.bitgo\n      .get(this.baseCoin.url('/tss/pubkey'))\n      .query({ enterpriseId })\n      .result();\n    const bitgoPublicKeyStr = response.publicKey as string;\n    return readKey({ armoredKey: bitgoPublicKeyStr });\n  }\n}\n"]}
328
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTSSUtils.js","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTSSUtils.ts"],"names":[],"mappings":"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","sourcesContent":["import { IRequestTracer } from '../../../api';\nimport { Key, readKey, SerializedKeyPair } from 'openpgp';\nimport { IBaseCoin, KeychainsTriplet } from '../../baseCoin';\nimport { BitGoBase } from '../../bitgoBase';\nimport { Keychain } from '../../keychain';\nimport { getTxRequest } from '../../tss';\nimport { IWallet, BackupProvider } from '../../wallet';\nimport { MpcUtils } from '../mpcUtils';\nimport * as _ from 'lodash';\nimport {\n  BitgoGPGPublicKey,\n  BitgoHeldBackupKeyShare,\n  CustomGShareGeneratingFunction,\n  CustomRShareGeneratingFunction,\n  ITssUtils,\n  PrebuildTransactionWithIntentOptions,\n  SignatureShareRecord,\n  TSSParams,\n  TxRequest,\n  TxRequestVersion,\n  CreateKeychainParamsBase,\n  IntentOptionsForMessage,\n  PopulatedIntentForMessageSigning,\n  IntentOptionsForTypedData,\n  PopulatedIntentForTypedDataSigning,\n  CreateBitGoKeychainParamsBase,\n  CommitmentShareRecord,\n  EncryptedSignerShareRecord,\n  CustomCommitmentGeneratingFunction,\n  TSSParamsForMessage,\n  RequestType,\n  CustomPaillierModulusGetterFunction,\n  CustomKShareGeneratingFunction,\n  CustomMuDeltaShareGeneratingFunction,\n  CustomSShareGeneratingFunction,\n} from './baseTypes';\nimport { GShare, SignShare } from '../../../account-lib/mpc/tss';\n\n/**\n * BaseTssUtil class which different signature schemes have to extend\n */\nexport default class BaseTssUtils<KeyShare> extends MpcUtils implements ITssUtils<KeyShare> {\n  private _wallet?: IWallet;\n\n  constructor(bitgo: BitGoBase, baseCoin: IBaseCoin, wallet?: IWallet) {\n    super(bitgo, baseCoin);\n    this._wallet = wallet;\n  }\n\n  get wallet(): IWallet {\n    if (_.isNil(this._wallet)) {\n      throw new Error('Wallet not defined');\n    }\n    return this._wallet;\n  }\n\n  async createBitgoHeldBackupKeyShare(\n    userGpgKey: SerializedKeyPair<string>,\n    enterprise: string | undefined\n  ): Promise<BitgoHeldBackupKeyShare> {\n    const keyResponse = await this.bitgo\n      .post(this.baseCoin.url('/krs/backupkeys'))\n      .send({\n        enterprise,\n        userGPGPublicKey: userGpgKey.publicKey,\n      })\n      .result();\n    if (!keyResponse || !keyResponse.keyShares) {\n      throw new Error('Failed to get backup shares from BitGo.');\n    }\n    return {\n      id: keyResponse.id,\n      keyShares: keyResponse.keyShares,\n    };\n  }\n\n  public finalizeBitgoHeldBackupKeyShare(\n    keyId: string,\n    commonKeychain: string,\n    userKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    userGpgKey: SerializedKeyPair<string>,\n    backupGpgKey: Key\n  ): Promise<BitgoHeldBackupKeyShare> {\n    throw new Error('Method not implemented.');\n  }\n\n  createUserKeychain(params: CreateKeychainParamsBase): Promise<Keychain> {\n    throw new Error('Method not implemented.');\n  }\n\n  createBackupKeychain(params: CreateKeychainParamsBase): Promise<Keychain> {\n    throw new Error('Method not implemented.');\n  }\n\n  createBitgoKeychain(params: CreateBitGoKeychainParamsBase): Promise<Keychain> {\n    throw new Error('Method not implemented.');\n  }\n\n  createKeychains(params: {\n    passphrase: string;\n    enterprise?: string | undefined;\n    originalPasscodeEncryptionCode?: string | undefined;\n    isThirdPartyBackup?: boolean;\n    backupProvider?: BackupProvider;\n  }): Promise<KeychainsTriplet> {\n    throw new Error('Method not implemented.');\n  }\n\n  signTxRequest(params: TSSParams): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  signTxRequestForMessage(params: TSSParams): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Signs a transaction using TSS for EdDSA and through utilization of custom share generators\n   *\n   * @param {string | TxRequest} txRequest - transaction request with unsigned transaction\n   * @param {CustomRShareGeneratingFunction} externalSignerRShareGenerator a function that creates R shares in the EdDSA TSS flow\n   * @param {CustomGShareGeneratingFunction} externalSignerGShareGenerator a function that creates G shares in the EdDSA TSS flow\n   * @returns {Promise<TxRequest>} - a signed tx request\n   */\n  signEddsaTssUsingExternalSigner(\n    txRequest: string | TxRequest,\n    externalSignerCommitmentGenerator: CustomCommitmentGeneratingFunction,\n    externalSignerRShareGenerator: CustomRShareGeneratingFunction,\n    externalSignerGShareGenerator: CustomGShareGeneratingFunction\n  ): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Signs a transaction using TSS for ECDSA and through utilization of custom share generators\n   *\n   * @param {params: TSSParams | TSSParamsForMessage} params - params object that represents parameters to sign a transaction or a message.\n   * @param {RequestType} requestType - the type of the request to sign (transaction or message).\n   * @param {CustomPaillierModulusGetterFunction} externalSignerPaillierModulusGetter a function that creates Paillier Modulus shares in the ECDSA TSS flow.\n   * @param {CustomKShareGeneratingFunction} externalSignerKShareGenerator a function that creates K shares in the ECDSA TSS flow.\n   * @param {CustomMuDeltaShareGeneratingFunction} externalSignerMuDeltaShareGenerator a function that creates Mu and Delta shares in the ECDSA TSS flow.\n   * @param {CustomSShareGeneratingFunction} externalSignerSShareGenerator a function that creates S shares in the ECDSA TSS flow.\n   */\n  signEcdsaTssUsingExternalSigner(\n    params: TSSParams | TSSParamsForMessage,\n    requestType: RequestType,\n    externalSignerPaillierModulusGetter: CustomPaillierModulusGetterFunction,\n    externalSignerKShareGenerator: CustomKShareGeneratingFunction,\n    externalSignerMuDeltaShareGenerator: CustomMuDeltaShareGeneratingFunction,\n    externalSignerSShareGenerator: CustomSShareGeneratingFunction\n  ): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Create an Commitment (User to BitGo) share from an unsigned transaction and private user signing material\n   * EDDSA only\n   *\n   * @param {Object} params - params object\n   * @param {TxRequest} params.txRequest - transaction request with unsigned transaction\n   * @param {string} params.prv - user signing material\n   * @param {string} params.walletPassphrase - wallet passphrase\n   *\n   * @returns {Promise<{ userToBitgoCommitment: CommitmentShareRecor, encryptedSignerShare: EncryptedSignerShareRecord }>} - Commitment Share and the Encrypted Signer Share to BitGo\n   */\n  createCommitmentShareFromTxRequest(params: { txRequest: TxRequest; prv: string; walletPassphrase: string }): Promise<{\n    userToBitgoCommitment: CommitmentShareRecord;\n    encryptedSignerShare: EncryptedSignerShareRecord;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Create an R (User to BitGo) share from an unsigned transaction and private user signing material\n   *\n   * @param {Object} params - params object\n   * @param {TxRequest} params.txRequest - transaction request with unsigned transaction\n   * @param {string} params.prv - user signing material\n   * @param {string} [params.walletPassphrase] - wallet passphrase\n   * @param {EncryptedSignerShareRecord} [params.encryptedUserToBitgoRShare] - encrypted user to bitgo R share generated in the commitment phase\n   * @returns {Promise<{ rShare: SignShare }>} - R Share to BitGo\n   */\n  createRShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    walletPassphrase: string;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }): Promise<{ rShare: SignShare }> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Create a G (User to BitGo) share from an unsigned transaction and private user signing material\n   *\n   * @param {Object} params - params object\n   * @param {TxRequest} params.txRequest - transaction request with unsigned transaction\n   * @param {string} params.prv - user signing material\n   * @param {SignatureShareRecord} params.bitgoToUserRShare - BitGo to User R Share\n   * @param {SignShare} params.userToBitgoRShare - User to BitGo R Share\n   * @param {CommitmentShareRecord} params.bitgoToUserCommitment - BitGo to User Commitment\n   * @returns {Promise<GShare>} - GShare from User to BitGo\n   */\n  createGShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    prv: string;\n    bitgoToUserRShare: SignatureShareRecord;\n    userToBitgoRShare: SignShare;\n    bitgoToUserCommitment: CommitmentShareRecord;\n  }): Promise<GShare> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Builds a tx request from params and verify it\n   *\n   * @param {PrebuildTransactionWithIntentOptions} params - parameters to build the tx\n   * @param {TxRequestVersion} apiVersion lite or full\n   * @param {boolean} preview boolean indicating if this is to preview a tx request, which will not initiate policy checks or pending approvals\n   * @returns {Promise<TxRequest>} - a built tx request\n   */\n  async prebuildTxWithIntent(\n    params: PrebuildTransactionWithIntentOptions,\n    apiVersion: TxRequestVersion = 'lite',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const intentOptions = this.populateIntent(this.baseCoin, params);\n\n    const whitelistedParams = {\n      intent: {\n        ...intentOptions,\n      },\n      apiVersion: apiVersion,\n      preview,\n    };\n\n    const unsignedTx = (await this.bitgo\n      .post(this.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests', 2))\n      .send(whitelistedParams)\n      .result()) as TxRequest;\n\n    return unsignedTx;\n  }\n\n  /**\n   * Create a tx request from params for message signing\n   *\n   * @param params\n   * @param apiVersion\n   * @param preview\n   */\n  async createTxRequestWithIntentForMessageSigning(\n    params: IntentOptionsForMessage,\n    apiVersion: TxRequestVersion = 'full',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const intentOptions: PopulatedIntentForMessageSigning = {\n      custodianMessageId: params.custodianMessageId,\n      intentType: params.intentType,\n      sequenceId: params.sequenceId,\n      comment: params.comment,\n      memo: params.memo?.value,\n      isTss: params.isTss,\n      messageRaw: params.messageRaw,\n      messageEncoded: params.messageEncoded ?? '',\n    };\n\n    return this.createTxRequestBase(intentOptions, apiVersion, preview);\n  }\n\n  /**\n   * Create a tx request from params for type data signing\n   *\n   * @param params\n   * @param apiVersion\n   * @param preview\n   */\n  async createTxRequestWithIntentForTypedDataSigning(\n    params: IntentOptionsForTypedData,\n    apiVersion: TxRequestVersion = 'full',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const intentOptions: PopulatedIntentForTypedDataSigning = {\n      custodianMessageId: params.custodianMessageId,\n      intentType: params.intentType,\n      sequenceId: params.sequenceId,\n      comment: params.comment,\n      memo: params.memo?.value,\n      isTss: params.isTss,\n      messageRaw: params.typedDataRaw,\n      messageEncoded: params.typedDataEncoded ?? '',\n    };\n\n    return this.createTxRequestBase(intentOptions, apiVersion, preview);\n  }\n\n  /**\n   * Calls Bitgo API to create tx request.\n   *\n   * @private\n   */\n  private async createTxRequestBase(\n    intentOptions: PopulatedIntentForTypedDataSigning | PopulatedIntentForMessageSigning,\n    apiVersion: TxRequestVersion,\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const whitelistedParams = {\n      intent: {\n        ...intentOptions,\n      },\n      apiVersion,\n      preview,\n    };\n\n    return this.bitgo\n      .post(this.bitgo.url(`/wallet/${this.wallet.id()}/txrequests`, 2))\n      .send(whitelistedParams)\n      .result();\n  }\n\n  /**\n   * Call delete signature shares for a txRequest, the endpoint delete the signatures and return them\n   *\n   * @param {string} txRequestId tx id reference to delete signature shares\n   * @returns {SignatureShareRecord[]}\n   */\n  async deleteSignatureShares(txRequestId: string): Promise<SignatureShareRecord[]> {\n    return this.bitgo\n      .del(this.bitgo.url(`/wallet/${this.wallet.id()}/txrequests/${txRequestId}/signatureshares`, 2))\n      .send()\n      .result();\n  }\n\n  /**\n   * Initialize the send procedure once Bitgo has the User To Bitgo GShare\n   *\n   * @param {String} txRequestId - the txRequest Id\n   * @returns {Promise<any>}\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  async sendTxRequest(txRequestId: string): Promise<any> {\n    return this.bitgo\n      .post(this.baseCoin.url('/wallet/' + this.wallet.id() + '/tx/send'))\n      .send({ txRequestId })\n      .result();\n  }\n\n  /**\n   * Delete signature shares, get the tx request without them from the db and sign it to finally send it.\n   *\n   * Note : This can be performed in order to reach latest network conditions required on pending approval flow.\n   *\n   * @param {String} txRequestId - the txRequest Id to make the requests.\n   * @param {String} decryptedPrv - decrypted prv to sign the tx request.\n   * @param {RequestTracer} reqId id tracer.\n   * @returns {Promise<any>}\n   */\n  async recreateTxRequest(txRequestId: string, decryptedPrv: string, reqId: IRequestTracer): Promise<TxRequest> {\n    await this.deleteSignatureShares(txRequestId);\n    // after delete signatures shares get the tx without them\n    const txRequest = await getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n    return await this.signTxRequest({ txRequest, prv: decryptedPrv, reqId });\n  }\n\n  /**\n   * Gets the latest Tx Request by id\n   *\n   * @param {String} txRequestId - the txRequest Id\n   * @returns {Promise<TxRequest>}\n   */\n  async getTxRequest(txRequestId: string): Promise<TxRequest> {\n    return getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n  }\n\n  /**\n   * Checks whether the third party backup provider is valid/supported\n   * @param backupProvider - the backup provider client selected\n   */\n  isValidThirdPartyBackupProvider(\n    backupProvider: BackupProvider | string | undefined\n  ): backupProvider is BackupProvider {\n    // As of now, BitGo is the only supported KRS provider for TSS\n    return !!(backupProvider && backupProvider === 'BitGoTrustAsKrs');\n  }\n\n  /**\n   * It gets the appropriate BitGo GPG public key for key creation based on a\n   * combination of coin and the feature flags on the user and their enterprise if set.\n   * @param enterpriseId - enterprise under which user wants to create the wallet\n   */\n  public async getBitgoGpgPubkeyBasedOnFeatureFlags(enterpriseId: string | undefined): Promise<Key> {\n    const response: BitgoGPGPublicKey = await this.bitgo\n      .get(this.baseCoin.url('/tss/pubkey'))\n      .query({ enterpriseId })\n      .result();\n    const bitgoPublicKeyStr = response.publicKey as string;\n    return readKey({ armoredKey: bitgoPublicKeyStr });\n  }\n\n  /**\n   * Returns supported TxRequest versions for this wallet\n   */\n  public supportedTxRequestVersions(): TxRequestVersion[] {\n    const walletType = this._wallet?.type();\n    const supportedWalletTypes = ['custodial', 'cold', 'hot'];\n    if (!walletType || this._wallet?.multisigType() !== 'tss' || !supportedWalletTypes.includes(walletType)) {\n      return [];\n    } else if (this._wallet?.baseCoin.getMPCAlgorithm() === 'ecdsa') {\n      return ['full'];\n    } else if (walletType === 'custodial' || walletType === 'cold') {\n      return ['full'];\n    } else if (this._wallet?.baseCoin.getMPCAlgorithm() === 'eddsa' && walletType === 'hot') {\n      return ['lite', 'full'];\n    }\n    return [];\n  }\n\n  /**\n   * Returns true if the txRequest is using apiVersion == full and is pending approval\n   * @param txRequest\n   * @returns boolean\n   */\n  isPendingApprovalTxRequestFull(txRequest: TxRequest): boolean {\n    const { apiVersion, state } = txRequest;\n    return apiVersion === 'full' && 'pendingApproval' === state;\n  }\n}\n"]}