@bitgo-beta/sdk-core 8.2.1-beta.11 → 8.2.1-beta.111

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 (159) hide show
  1. package/CHANGELOG.md +302 -0
  2. package/dist/src/account-lib/baseCoin/enum.d.ts +4 -1
  3. package/dist/src/account-lib/baseCoin/enum.d.ts.map +1 -1
  4. package/dist/src/account-lib/baseCoin/enum.js +7 -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 +34 -12
  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 +555 -146
  17. package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.d.ts +2 -2
  18. package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.d.ts.map +1 -1
  19. package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.js +3 -3
  20. package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts +70 -55
  21. package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts.map +1 -1
  22. package/dist/src/account-lib/mpc/tss/ecdsa/types.js +1 -1
  23. package/dist/src/account-lib/mpc/tss/eddsa/eddsa.d.ts +1 -1
  24. package/dist/src/account-lib/mpc/tss/eddsa/eddsa.d.ts.map +1 -1
  25. package/dist/src/account-lib/mpc/tss/eddsa/eddsa.js +1 -1
  26. package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts +0 -3
  27. package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts.map +1 -1
  28. package/dist/src/account-lib/mpc/tss/eddsa/types.js +1 -1
  29. package/dist/src/bitgo/baseCoin/baseCoin.d.ts +16 -0
  30. package/dist/src/bitgo/baseCoin/baseCoin.d.ts.map +1 -1
  31. package/dist/src/bitgo/baseCoin/baseCoin.js +15 -1
  32. package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts +20 -4
  33. package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts.map +1 -1
  34. package/dist/src/bitgo/baseCoin/iBaseCoin.js +1 -1
  35. package/dist/src/bitgo/bitgoBase.d.ts +2 -1
  36. package/dist/src/bitgo/bitgoBase.d.ts.map +1 -1
  37. package/dist/src/bitgo/bitgoBase.js +1 -1
  38. package/dist/src/bitgo/enterprise/enterprise.d.ts +13 -1
  39. package/dist/src/bitgo/enterprise/enterprise.d.ts.map +1 -1
  40. package/dist/src/bitgo/enterprise/enterprise.js +29 -1
  41. package/dist/src/bitgo/enterprise/enterprises.d.ts +6 -0
  42. package/dist/src/bitgo/enterprise/enterprises.d.ts.map +1 -1
  43. package/dist/src/bitgo/enterprise/enterprises.js +26 -1
  44. package/dist/src/bitgo/enterprise/iEnterprise.d.ts +4 -1
  45. package/dist/src/bitgo/enterprise/iEnterprise.d.ts.map +1 -1
  46. package/dist/src/bitgo/enterprise/iEnterprise.js +1 -1
  47. package/dist/src/bitgo/enterprise/iEnterprises.d.ts +2 -0
  48. package/dist/src/bitgo/enterprise/iEnterprises.d.ts.map +1 -1
  49. package/dist/src/bitgo/enterprise/iEnterprises.js +1 -1
  50. package/dist/src/bitgo/environments.d.ts +7 -0
  51. package/dist/src/bitgo/environments.d.ts.map +1 -1
  52. package/dist/src/bitgo/environments.js +17 -3
  53. package/dist/src/bitgo/keychain/iKeychains.d.ts +6 -0
  54. package/dist/src/bitgo/keychain/iKeychains.d.ts.map +1 -1
  55. package/dist/src/bitgo/keychain/iKeychains.js +1 -1
  56. package/dist/src/bitgo/keychain/keychains.d.ts.map +1 -1
  57. package/dist/src/bitgo/keychain/keychains.js +30 -24
  58. package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts +124 -89
  59. package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts.map +1 -1
  60. package/dist/src/bitgo/keychain/ovcJsonCodec.js +31 -24
  61. package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts +2 -0
  62. package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts.map +1 -1
  63. package/dist/src/bitgo/pendingApproval/iPendingApproval.js +1 -1
  64. package/dist/src/bitgo/pendingApproval/pendingApproval.d.ts.map +1 -1
  65. package/dist/src/bitgo/pendingApproval/pendingApproval.js +13 -1
  66. package/dist/src/bitgo/recovery/initiate.d.ts +7 -1
  67. package/dist/src/bitgo/recovery/initiate.d.ts.map +1 -1
  68. package/dist/src/bitgo/recovery/initiate.js +1 -1
  69. package/dist/src/bitgo/staking/iStakingWallet.d.ts +11 -1
  70. package/dist/src/bitgo/staking/iStakingWallet.d.ts.map +1 -1
  71. package/dist/src/bitgo/staking/iStakingWallet.js +1 -1
  72. package/dist/src/bitgo/staking/stakingWallet.d.ts +7 -1
  73. package/dist/src/bitgo/staking/stakingWallet.d.ts.map +1 -1
  74. package/dist/src/bitgo/staking/stakingWallet.js +9 -1
  75. package/dist/src/bitgo/tss/common.d.ts +15 -4
  76. package/dist/src/bitgo/tss/common.d.ts.map +1 -1
  77. package/dist/src/bitgo/tss/common.js +26 -11
  78. package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts +11 -8
  79. package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts.map +1 -1
  80. package/dist/src/bitgo/tss/ecdsa/ecdsa.js +36 -33
  81. package/dist/src/bitgo/tss/ecdsa/types.d.ts +2 -2
  82. package/dist/src/bitgo/tss/ecdsa/types.d.ts.map +1 -1
  83. package/dist/src/bitgo/tss/ecdsa/types.js +1 -1
  84. package/dist/src/bitgo/tss/eddsa/eddsa.d.ts +6 -5
  85. package/dist/src/bitgo/tss/eddsa/eddsa.d.ts.map +1 -1
  86. package/dist/src/bitgo/tss/eddsa/eddsa.js +20 -9
  87. package/dist/src/bitgo/tss/types.d.ts +19 -0
  88. package/dist/src/bitgo/tss/types.d.ts.map +1 -1
  89. package/dist/src/bitgo/tss/types.js +1 -1
  90. package/dist/src/bitgo/utils/codecProps.d.ts +7 -0
  91. package/dist/src/bitgo/utils/codecProps.d.ts.map +1 -0
  92. package/dist/src/bitgo/utils/codecProps.js +41 -0
  93. package/dist/src/bitgo/utils/opengpgUtils.d.ts.map +1 -1
  94. package/dist/src/bitgo/utils/opengpgUtils.js +7 -10
  95. package/dist/src/bitgo/utils/postWithCodec.d.ts +18 -0
  96. package/dist/src/bitgo/utils/postWithCodec.d.ts.map +1 -0
  97. package/dist/src/bitgo/utils/postWithCodec.js +59 -0
  98. package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts +54 -12
  99. package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts.map +1 -1
  100. package/dist/src/bitgo/utils/tss/baseTSSUtils.js +66 -9
  101. package/dist/src/bitgo/utils/tss/baseTypes.d.ts +99 -8
  102. package/dist/src/bitgo/utils/tss/baseTypes.d.ts.map +1 -1
  103. package/dist/src/bitgo/utils/tss/baseTypes.js +26 -2
  104. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts +47 -7
  105. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts.map +1 -1
  106. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.js +242 -128
  107. package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts +9 -0
  108. package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts.map +1 -1
  109. package/dist/src/bitgo/utils/tss/ecdsa/types.js +1 -1
  110. package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts +18 -5
  111. package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts.map +1 -1
  112. package/dist/src/bitgo/utils/tss/eddsa/eddsa.js +79 -25
  113. package/dist/src/bitgo/wallet/BuildParams.d.ts +110 -0
  114. package/dist/src/bitgo/wallet/BuildParams.d.ts.map +1 -0
  115. package/dist/src/bitgo/wallet/BuildParams.js +119 -0
  116. package/dist/src/bitgo/wallet/SendTransactionRequest.d.ts +92 -0
  117. package/dist/src/bitgo/wallet/SendTransactionRequest.d.ts.map +1 -0
  118. package/dist/src/bitgo/wallet/SendTransactionRequest.js +41 -0
  119. package/dist/src/bitgo/wallet/iWallet.d.ts +13 -1
  120. package/dist/src/bitgo/wallet/iWallet.d.ts.map +1 -1
  121. package/dist/src/bitgo/wallet/iWallet.js +1 -1
  122. package/dist/src/bitgo/wallet/wallet.d.ts +11 -2
  123. package/dist/src/bitgo/wallet/wallet.d.ts.map +1 -1
  124. package/dist/src/bitgo/wallet/wallet.js +136 -80
  125. package/dist/src/index.d.ts +5 -1
  126. package/dist/src/index.d.ts.map +1 -1
  127. package/dist/src/index.js +4 -2
  128. package/dist/src/openssl/index.d.ts +4 -1
  129. package/dist/src/openssl/index.d.ts.map +1 -1
  130. package/dist/src/openssl/index.js +7 -12
  131. package/dist/test/node.utils.d.ts +2 -0
  132. package/dist/test/node.utils.d.ts.map +1 -0
  133. package/dist/test/node.utils.js +5 -0
  134. package/dist/test/unit/bitgo/utils/postWithCodec.d.ts +2 -0
  135. package/dist/test/unit/bitgo/utils/postWithCodec.d.ts.map +1 -0
  136. package/dist/test/unit/bitgo/utils/postWithCodec.js +79 -0
  137. package/dist/test/unit/bitgo/wallet/SendTransactionRequest.d.ts +2 -0
  138. package/dist/test/unit/bitgo/wallet/SendTransactionRequest.d.ts.map +1 -0
  139. package/dist/test/unit/bitgo/wallet/SendTransactionRequest.js +49 -0
  140. package/dist/test/unit/openssl.d.ts +2 -0
  141. package/dist/test/unit/openssl.d.ts.map +1 -0
  142. package/dist/test/unit/openssl.js +39 -0
  143. package/dist/test/unit/units.d.ts +2 -0
  144. package/dist/test/unit/units.d.ts.map +1 -0
  145. package/dist/test/unit/units.js +98 -0
  146. package/dist/tsconfig.tsbuildinfo +1 -8272
  147. package/package.json +11 -10
  148. package/dist/src/account-lib/mpc/hdTree.d.ts +0 -31
  149. package/dist/src/account-lib/mpc/hdTree.d.ts.map +0 -1
  150. package/dist/src/account-lib/mpc/hdTree.js +0 -141
  151. package/dist/src/account-lib/mpc/types.d.ts +0 -5
  152. package/dist/src/account-lib/mpc/types.d.ts.map +0 -1
  153. package/dist/src/account-lib/mpc/types.js +0 -3
  154. package/dist/src/openssl/openssl.d.ts +0 -12
  155. package/dist/src/openssl/openssl.d.ts.map +0 -1
  156. package/dist/src/openssl/openssl.js +0 -48
  157. package/dist/src/openssl/opensslbytes.d.ts +0 -4
  158. package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
  159. package/dist/src/openssl/opensslbytes.js +0 -20
@@ -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,10 @@ 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
+ isPendingApprovalTxRequestFull(txRequest: TxRequest): boolean;
143
185
  }
144
186
  //# 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,31 @@ 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
+ isPendingApprovalTxRequestFull(txRequest) {
318
+ const { apiVersion, state } = txRequest;
319
+ return apiVersion === 'full' && 'pendingApproval' === state;
320
+ }
264
321
  }
265
322
  exports.default = BaseTssUtils;
266
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTSSUtils.js","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTSSUtils.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AACA,qCAA0D;AAI1D,mCAAyC;AAEzC,0CAAuC;AACvC,0CAA4B;AAqB5B;;GAEG;AACH,MAAqB,YAAuB,SAAQ,mBAAQ;IAG1D,YAAY,KAAgB,EAAE,QAAmB,EAAE,MAAgB;QACjE,KAAK,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QACvB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;IACxB,CAAC;IAED,IAAI,MAAM;QACR,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YACzB,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;SACvC;QACD,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,KAAK,CAAC,6BAA6B,CACjC,UAAqC,EACrC,UAA8B;QAE9B,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,KAAK;aACjC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;aAC1C,IAAI,CAAC;YACJ,UAAU;YACV,gBAAgB,EAAE,UAAU,CAAC,SAAS;SACvC,CAAC;aACD,MAAM,EAAE,CAAC;QACZ,IAAI,CAAC,WAAW,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE;YAC1C,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;SAC5D;QACD,OAAO;YACL,EAAE,EAAE,WAAW,CAAC,EAAE;YAClB,SAAS,EAAE,WAAW,CAAC,SAAS;SACjC,CAAC;IACJ,CAAC;IAEM,+BAA+B,CACpC,KAAa,EACb,cAAsB,EACtB,YAAsB,EACtB,aAAuB,EACvB,UAAqC,EACrC,YAAiB;QAEjB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED,kBAAkB,CAAC,MAAgC;QACjD,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED,oBAAoB,CAAC,MAAgC;QACnD,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED,mBAAmB,CAAC,MAAqC;QACvD,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED,eAAe,CAAC,MAMf;QACC,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED,aAAa,CAAC,MAAiB;QAC7B,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED,uBAAuB,CAAC,MAAiB;QACvC,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED;;;;;;;OAOG;IACH,uBAAuB,CACrB,SAA6B,EAC7B,6BAA6D,EAC7D,6BAA6D;QAE7D,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED;;;;;;OAMG;IACH,yBAAyB,CAAC,MAGzB;QACC,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED;;;;;;;;OAQG;IACH,yBAAyB,CAAC,MAKzB;QACC,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,oBAAoB,CACxB,MAA4C,EAC5C,aAA+B,MAAM,EACrC,OAAiB;QAEjB,MAAM,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAEjE,MAAM,iBAAiB,GAAG;YACxB,MAAM,EAAE;gBACN,GAAG,aAAa;aACjB;YACD,UAAU,EAAE,UAAU;YACtB,OAAO;SACR,CAAC;QAEF,MAAM,UAAU,GAAG,CAAC,MAAM,IAAI,CAAC,KAAK;aACjC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,aAAa,EAAE,CAAC,CAAC,CAAC;aACtE,IAAI,CAAC,iBAAiB,CAAC;aACvB,MAAM,EAAE,CAAc,CAAC;QAE1B,OAAO,UAAU,CAAC;IACpB,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,0CAA0C,CAC9C,MAA+B,EAC/B,aAA+B,MAAM,EACrC,OAAiB;;QAEjB,MAAM,aAAa,GAAqC;YACtD,kBAAkB,EAAE,MAAM,CAAC,kBAAkB;YAC7C,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,IAAI,EAAE,MAAA,MAAM,CAAC,IAAI,0CAAE,KAAK;YACxB,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,cAAc,EAAE,MAAA,MAAM,CAAC,cAAc,mCAAI,EAAE;SAC5C,CAAC;QAEF,OAAO,IAAI,CAAC,mBAAmB,CAAC,aAAa,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;IACtE,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,4CAA4C,CAChD,MAAiC,EACjC,aAA+B,MAAM,EACrC,OAAiB;;QAEjB,MAAM,aAAa,GAAuC;YACxD,kBAAkB,EAAE,MAAM,CAAC,kBAAkB;YAC7C,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,IAAI,EAAE,MAAA,MAAM,CAAC,IAAI,0CAAE,KAAK;YACxB,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,UAAU,EAAE,MAAM,CAAC,YAAY;YAC/B,cAAc,EAAE,MAAA,MAAM,CAAC,gBAAgB,mCAAI,EAAE;SAC9C,CAAC;QAEF,OAAO,IAAI,CAAC,mBAAmB,CAAC,aAAa,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;IACtE,CAAC;IAED;;;;OAIG;IACK,KAAK,CAAC,mBAAmB,CAC/B,aAAoF,EACpF,UAA4B,EAC5B,OAAiB;QAEjB,MAAM,iBAAiB,GAAG;YACxB,MAAM,EAAE;gBACN,GAAG,aAAa;aACjB;YACD,UAAU;YACV,OAAO;SACR,CAAC;QAEF,OAAO,IAAI,CAAC,KAAK;aACd,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,WAAW,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC;aACjE,IAAI,CAAC,iBAAiB,CAAC;aACvB,MAAM,EAAE,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,qBAAqB,CAAC,WAAmB;QAC7C,OAAO,IAAI,CAAC,KAAK;aACd,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,WAAW,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,eAAe,WAAW,kBAAkB,EAAE,CAAC,CAAC,CAAC;aAC/F,IAAI,EAAE;aACN,MAAM,EAAE,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACH,8DAA8D;IAC9D,KAAK,CAAC,aAAa,CAAC,WAAmB;QACrC,OAAO,IAAI,CAAC,KAAK;aACd,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,UAAU,CAAC,CAAC;aACnE,IAAI,CAAC,EAAE,WAAW,EAAE,CAAC;aACrB,MAAM,EAAE,CAAC;IACd,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,iBAAiB,CAAC,WAAmB,EAAE,YAAoB,EAAE,KAAqB;QACtF,MAAM,IAAI,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC;QAC9C,yDAAyD;QACzD,MAAM,SAAS,GAAG,MAAM,kBAAY,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,WAAW,CAAC,CAAC;QAChF,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,EAAE,SAAS,EAAE,GAAG,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC;IAC3E,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,YAAY,CAAC,WAAmB;QACpC,OAAO,kBAAY,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,WAAW,CAAC,CAAC;IACjE,CAAC;IAED;;;OAGG;IACH,+BAA+B,CAC7B,cAAmD;QAEnD,8DAA8D;QAC9D,OAAO,CAAC,CAAC,CAAC,cAAc,IAAI,cAAc,KAAK,iBAAiB,CAAC,CAAC;IACpE,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,oCAAoC,CAAC,YAAgC;QAChF,MAAM,QAAQ,GAAsB,MAAM,IAAI,CAAC,KAAK;aACjD,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;aACrC,KAAK,CAAC,EAAE,YAAY,EAAE,CAAC;aACvB,MAAM,EAAE,CAAC;QACZ,MAAM,iBAAiB,GAAG,QAAQ,CAAC,SAAmB,CAAC;QACvD,OAAO,iBAAO,CAAC,EAAE,UAAU,EAAE,iBAAiB,EAAE,CAAC,CAAC;IACpD,CAAC;CACF;AArTD,+BAqTC","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"]}
323
+ //# 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  isPendingApprovalTxRequestFull(txRequest: TxRequest): boolean {\n    const { apiVersion, state } = txRequest;\n    return apiVersion === 'full' && 'pendingApproval' === state;\n  }\n}\n"]}
@@ -4,9 +4,12 @@ import { IRequestTracer } from '../../../api';
4
4
  import { KeychainsTriplet } from '../../baseCoin';
5
5
  import { ApiKeyShare, Keychain } from '../../keychain';
6
6
  import { ApiVersion, Memo, WalletType } from '../../wallet';
7
- import { EDDSA, GShare, SignShare, YShare } from '../../../account-lib/mpc/tss';
7
+ import { EDDSA, GShare, SignShare } from '../../../account-lib/mpc/tss';
8
8
  import { KeyShare } from './ecdsa';
9
9
  import { Hash } from 'crypto';
10
+ import { EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';
11
+ import { TssEcdsaStep1ReturnMessage, TssEcdsaStep2ReturnMessage, TxRequestChallengeResponse } from '../../tss/types';
12
+ import { AShare, DShare, SShare } from '../../tss/ecdsa/types';
10
13
  export declare type TxRequestVersion = 'full' | 'lite';
11
14
  export interface HopParams {
12
15
  paymentId?: string;
@@ -29,12 +32,67 @@ export interface TokenEnablement {
29
32
  name: string;
30
33
  address?: string;
31
34
  }
35
+ export declare enum ShareType {
36
+ R = "R",
37
+ Commitment = "commitment",
38
+ G = "G",
39
+ S = "S",
40
+ K = "K",
41
+ MuDelta = "MuDelta",
42
+ PaillierModulus = "PaillierModulus"
43
+ }
44
+ export declare enum MPCType {
45
+ EDDSA = "eddsa",
46
+ ECDSA = "ecdsa"
47
+ }
48
+ export interface CustomPaillierModulusGetterFunction {
49
+ (params: {
50
+ txRequest: TxRequest;
51
+ }): Promise<{
52
+ userPaillierModulus: string;
53
+ }>;
54
+ }
55
+ export interface CustomKShareGeneratingFunction {
56
+ (params: {
57
+ tssParams: TSSParams | TSSParamsForMessage;
58
+ challenges: {
59
+ enterpriseChallenge: EcdsaTypes.SerializedEcdsaChallenges;
60
+ bitgoChallenge: TxRequestChallengeResponse;
61
+ };
62
+ requestType: RequestType;
63
+ }): Promise<TssEcdsaStep1ReturnMessage>;
64
+ }
65
+ export interface CustomMuDeltaShareGeneratingFunction {
66
+ (params: {
67
+ txRequest: TxRequest;
68
+ aShareFromBitgo: Omit<AShare, 'ntilde' | 'h1' | 'h2'>;
69
+ bitgoChallenge: TxRequestChallengeResponse;
70
+ encryptedWShare: string;
71
+ }): Promise<TssEcdsaStep2ReturnMessage>;
72
+ }
73
+ export interface CustomSShareGeneratingFunction {
74
+ (params: {
75
+ tssParams: TSSParams | TSSParamsForMessage;
76
+ dShareFromBitgo: DShare;
77
+ requestType: RequestType;
78
+ encryptedOShare: string;
79
+ }): Promise<SShare>;
80
+ }
81
+ export interface CustomCommitmentGeneratingFunction {
82
+ (params: {
83
+ txRequest: TxRequest;
84
+ }): Promise<{
85
+ userToBitgoCommitment: CommitmentShareRecord;
86
+ encryptedSignerShare: EncryptedSignerShareRecord;
87
+ encryptedUserToBitgoRShare: EncryptedSignerShareRecord;
88
+ }>;
89
+ }
32
90
  export interface CustomRShareGeneratingFunction {
33
91
  (params: {
34
92
  txRequest: TxRequest;
93
+ encryptedUserToBitgoRShare: EncryptedSignerShareRecord;
35
94
  }): Promise<{
36
95
  rShare: SignShare;
37
- signingKeyYShare: YShare;
38
96
  }>;
39
97
  }
40
98
  export interface CustomGShareGeneratingFunction {
@@ -42,6 +100,7 @@ export interface CustomGShareGeneratingFunction {
42
100
  txRequest: TxRequest;
43
101
  userToBitgoRShare: SignShare;
44
102
  bitgoToUserRShare: SignatureShareRecord;
103
+ bitgoToUserCommitment: CommitmentShareRecord;
45
104
  }): Promise<GShare>;
46
105
  }
47
106
  export declare enum TokenType {
@@ -134,8 +193,8 @@ export interface PopulatedIntent extends PopulatedIntentBase {
134
193
  custodianTransactionId?: string;
135
194
  custodianMessageId?: string;
136
195
  }
137
- export declare type TxRequestState = 'pendingApproval' | 'canceled' | 'rejected' | 'initialized' | 'pendingDelivery' | 'delivered' | 'pendingUserSignature' | 'signed';
138
- export declare type TransactionState = 'initialized' | 'pendingSignature' | 'signed' | 'held' | 'delivered' | 'invalidSignature' | 'rejected';
196
+ export declare type TxRequestState = 'pendingCommitment' | 'pendingApproval' | 'canceled' | 'rejected' | 'initialized' | 'pendingDelivery' | 'delivered' | 'pendingUserSignature' | 'signed';
197
+ export declare type TransactionState = 'initialized' | 'pendingCommitment' | 'pendingSignature' | 'signed' | 'held' | 'delivered' | 'invalidSignature' | 'rejected';
139
198
  export declare type SignableTransaction = {
140
199
  serializedTxHex: string;
141
200
  signableHex: string;
@@ -170,6 +229,7 @@ export declare type TxRequest = {
170
229
  pendingApprovalId?: string;
171
230
  policiesChecked: boolean;
172
231
  signatureShares?: SignatureShareRecord[];
232
+ commitmentShares?: CommitmentShareRecord[];
173
233
  pendingTxHashes?: string[];
174
234
  txHashes?: string[];
175
235
  unsignedMessages?: UnsignedMessageTss[];
@@ -178,6 +238,7 @@ export declare type TxRequest = {
178
238
  state: TransactionState;
179
239
  unsignedTx: UnsignedTransactionTss;
180
240
  signatureShares: SignatureShareRecord[];
241
+ commitmentShares?: CommitmentShareRecord[];
181
242
  }[];
182
243
  messages?: {
183
244
  state: TransactionState;
@@ -201,14 +262,32 @@ export declare enum SignatureShareType {
201
262
  BACKUP = "backup",
202
263
  BITGO = "bitgo"
203
264
  }
204
- export interface SignatureShareRecord {
265
+ interface ShareBaseRecord {
205
266
  from: SignatureShareType;
206
267
  to: SignatureShareType;
207
268
  share: string;
269
+ }
270
+ export interface SignatureShareRecord extends ShareBaseRecord {
208
271
  vssProof?: string;
209
272
  privateShareProof?: string;
210
273
  publicShare?: string;
211
274
  }
275
+ export declare enum CommitmentType {
276
+ COMMITMENT = "commitment"
277
+ }
278
+ export interface CommitmentShareRecord extends ShareBaseRecord {
279
+ type: CommitmentType;
280
+ }
281
+ export interface ExchangeCommitmentResponse {
282
+ commitmentShare: CommitmentShareRecord;
283
+ }
284
+ export declare enum EncryptedSignerShareType {
285
+ ENCRYPTED_SIGNER_SHARE = "encryptedSignerShare",
286
+ ENCRYPTED_R_SHARE = "encryptedRShare"
287
+ }
288
+ export interface EncryptedSignerShareRecord extends ShareBaseRecord {
289
+ type: EncryptedSignerShareType;
290
+ }
212
291
  export declare type TSSParams = {
213
292
  txRequest: string | TxRequest;
214
293
  prv: string;
@@ -258,25 +337,37 @@ export interface ITssUtils<KeyShare = EDDSA.KeyShare> {
258
337
  reqId: IRequestTracer;
259
338
  }): Promise<TxRequest>;
260
339
  signTxRequestForMessage(params: TSSParams): Promise<TxRequest>;
261
- signUsingExternalSigner(txRequest: string | TxRequest, externalSignerRShareGenerator: CustomRShareGeneratingFunction, externalSignerGShareGenerator: CustomGShareGeneratingFunction): Promise<TxRequest>;
262
- createRShareFromTxRequest(params: {
340
+ signEddsaTssUsingExternalSigner(txRequest: string | TxRequest, externalSignerCommitmentGenerator: CustomCommitmentGeneratingFunction, externalSignerRShareGenerator: CustomRShareGeneratingFunction, externalSignerGShareGenerator: CustomGShareGeneratingFunction): Promise<TxRequest>;
341
+ signEcdsaTssUsingExternalSigner(params: TSSParams | TSSParamsForMessage, requestType: RequestType, externalSignerPaillierModulusGetter: CustomPaillierModulusGetterFunction, externalSignerKShareGenerator: CustomKShareGeneratingFunction, externalSignerMuDeltaShareGenerator: CustomMuDeltaShareGeneratingFunction, externalSignerSShareGenerator: CustomSShareGeneratingFunction): Promise<TxRequest>;
342
+ createCommitmentShareFromTxRequest(params: {
263
343
  txRequest: TxRequest;
264
344
  prv: string;
345
+ walletPassphrase: string;
346
+ }): Promise<{
347
+ userToBitgoCommitment: CommitmentShareRecord;
348
+ encryptedSignerShare: EncryptedSignerShareRecord;
349
+ encryptedUserToBitgoRShare: EncryptedSignerShareRecord;
350
+ }>;
351
+ createRShareFromTxRequest(params: {
352
+ txRequest: TxRequest;
353
+ walletPassphrase: string;
354
+ encryptedUserToBitgoRShare: EncryptedSignerShareRecord;
265
355
  }): Promise<{
266
356
  rShare: SignShare;
267
- signingKeyYShare: YShare;
268
357
  }>;
269
358
  createGShareFromTxRequest(params: {
270
359
  txRequest: TxRequest;
271
360
  prv: string;
272
361
  bitgoToUserRShare: SignatureShareRecord;
273
362
  userToBitgoRShare: SignShare;
363
+ bitgoToUserCommitment: CommitmentShareRecord;
274
364
  }): Promise<GShare>;
275
365
  prebuildTxWithIntent(params: PrebuildTransactionWithIntentOptions, apiVersion?: TxRequestVersion, preview?: boolean): Promise<TxRequest>;
276
366
  deleteSignatureShares(txRequestId: string): Promise<SignatureShareRecord[]>;
277
367
  sendTxRequest(txRequestId: string): Promise<any>;
278
368
  recreateTxRequest(txRequestId: string, decryptedPrv: string, reqId: IRequestTracer): Promise<TxRequest>;
279
369
  getTxRequest(txRequestId: string): Promise<TxRequest>;
370
+ supportedTxRequestVersions(): TxRequestVersion[];
280
371
  }
281
372
  export {};
282
373
  //# sourceMappingURL=baseTypes.d.ts.map