@bitgo-beta/abstract-utxo 1.6.1-alpha.41 → 1.6.1-alpha.411

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 (175) hide show
  1. package/dist/src/abstractUtxoCoin.d.ts +209 -98
  2. package/dist/src/abstractUtxoCoin.d.ts.map +1 -1
  3. package/dist/src/abstractUtxoCoin.js +314 -541
  4. package/dist/src/descriptor/NamedDescriptor.d.ts +20 -0
  5. package/dist/src/descriptor/NamedDescriptor.d.ts.map +1 -0
  6. package/dist/src/descriptor/NamedDescriptor.js +79 -0
  7. package/dist/src/descriptor/assertDescriptorWalletAddress.d.ts +5 -0
  8. package/dist/src/descriptor/assertDescriptorWalletAddress.d.ts.map +1 -0
  9. package/dist/src/descriptor/assertDescriptorWalletAddress.js +66 -0
  10. package/dist/src/descriptor/builder/builder.d.ts +13 -0
  11. package/dist/src/descriptor/builder/builder.d.ts.map +1 -0
  12. package/dist/src/descriptor/builder/builder.js +37 -0
  13. package/dist/src/descriptor/builder/index.d.ts +3 -0
  14. package/dist/src/descriptor/builder/index.d.ts.map +1 -0
  15. package/dist/src/descriptor/builder/index.js +8 -0
  16. package/dist/src/descriptor/builder/parse.d.ts +5 -0
  17. package/dist/src/descriptor/builder/parse.d.ts.map +1 -0
  18. package/dist/src/descriptor/builder/parse.js +149 -0
  19. package/dist/src/descriptor/createWallet/createDescriptorWallet.d.ts +20 -0
  20. package/dist/src/descriptor/createWallet/createDescriptorWallet.d.ts.map +1 -0
  21. package/dist/src/descriptor/createWallet/createDescriptorWallet.js +74 -0
  22. package/dist/src/descriptor/createWallet/createDescriptors.d.ts +12 -0
  23. package/dist/src/descriptor/createWallet/createDescriptors.d.ts.map +1 -0
  24. package/dist/src/descriptor/createWallet/createDescriptors.js +33 -0
  25. package/dist/src/descriptor/createWallet/index.d.ts +3 -0
  26. package/dist/src/descriptor/createWallet/index.d.ts.map +1 -0
  27. package/dist/src/descriptor/createWallet/index.js +19 -0
  28. package/dist/src/descriptor/descriptorWallet.d.ts +19 -0
  29. package/dist/src/descriptor/descriptorWallet.d.ts.map +1 -0
  30. package/dist/src/descriptor/descriptorWallet.js +54 -0
  31. package/dist/src/descriptor/index.d.ts +8 -0
  32. package/dist/src/descriptor/index.d.ts.map +1 -0
  33. package/dist/src/descriptor/index.js +53 -0
  34. package/dist/src/descriptor/validatePolicy.d.ts +22 -0
  35. package/dist/src/descriptor/validatePolicy.d.ts.map +1 -0
  36. package/dist/src/descriptor/validatePolicy.js +92 -0
  37. package/dist/src/index.d.ts +4 -0
  38. package/dist/src/index.d.ts.map +1 -1
  39. package/dist/src/index.js +32 -2
  40. package/dist/src/keychains.d.ts +48 -0
  41. package/dist/src/keychains.d.ts.map +1 -0
  42. package/dist/src/keychains.js +104 -0
  43. package/dist/src/names.d.ts +26 -0
  44. package/dist/src/names.d.ts.map +1 -0
  45. package/dist/src/names.js +214 -0
  46. package/dist/src/offlineVault/OfflineVaultHalfSigned.d.ts +8 -0
  47. package/dist/src/offlineVault/OfflineVaultHalfSigned.d.ts.map +1 -0
  48. package/dist/src/offlineVault/OfflineVaultHalfSigned.js +59 -0
  49. package/dist/src/offlineVault/OfflineVaultSignable.d.ts +46 -0
  50. package/dist/src/offlineVault/OfflineVaultSignable.d.ts.map +1 -0
  51. package/dist/src/offlineVault/OfflineVaultSignable.js +55 -0
  52. package/dist/src/offlineVault/TransactionExplanation.d.ts +15 -0
  53. package/dist/src/offlineVault/TransactionExplanation.d.ts.map +1 -0
  54. package/dist/src/offlineVault/TransactionExplanation.js +16 -0
  55. package/dist/src/offlineVault/descriptor/index.d.ts +2 -0
  56. package/dist/src/offlineVault/descriptor/index.d.ts.map +1 -0
  57. package/dist/src/offlineVault/descriptor/index.js +18 -0
  58. package/dist/src/offlineVault/descriptor/transaction.d.ts +38 -0
  59. package/dist/src/offlineVault/descriptor/transaction.d.ts.map +1 -0
  60. package/dist/src/offlineVault/descriptor/transaction.js +80 -0
  61. package/dist/src/offlineVault/index.d.ts +6 -0
  62. package/dist/src/offlineVault/index.d.ts.map +1 -0
  63. package/dist/src/offlineVault/index.js +44 -0
  64. package/dist/src/recovery/RecoveryProvider.d.ts +1 -1
  65. package/dist/src/recovery/RecoveryProvider.d.ts.map +1 -1
  66. package/dist/src/recovery/RecoveryProvider.js +2 -4
  67. package/dist/src/recovery/backupKeyRecovery.d.ts +42 -16
  68. package/dist/src/recovery/backupKeyRecovery.d.ts.map +1 -1
  69. package/dist/src/recovery/backupKeyRecovery.js +174 -102
  70. package/dist/src/recovery/baseApi.d.ts +3 -6
  71. package/dist/src/recovery/baseApi.d.ts.map +1 -1
  72. package/dist/src/recovery/baseApi.js +6 -6
  73. package/dist/src/recovery/coingeckoApi.d.ts +0 -3
  74. package/dist/src/recovery/coingeckoApi.d.ts.map +1 -1
  75. package/dist/src/recovery/coingeckoApi.js +1 -4
  76. package/dist/src/recovery/crossChainRecovery.d.ts +5 -4
  77. package/dist/src/recovery/crossChainRecovery.d.ts.map +1 -1
  78. package/dist/src/recovery/crossChainRecovery.js +95 -25
  79. package/dist/src/recovery/index.d.ts +0 -1
  80. package/dist/src/recovery/index.d.ts.map +1 -1
  81. package/dist/src/recovery/index.js +6 -3
  82. package/dist/src/recovery/mempoolApi.d.ts.map +1 -1
  83. package/dist/src/recovery/mempoolApi.js +10 -7
  84. package/dist/src/replayProtection.js +37 -5
  85. package/dist/src/sign.d.ts +31 -8
  86. package/dist/src/sign.d.ts.map +1 -1
  87. package/dist/src/sign.js +116 -15
  88. package/dist/src/transaction/bip322.d.ts +27 -0
  89. package/dist/src/transaction/bip322.d.ts.map +1 -0
  90. package/dist/src/transaction/bip322.js +125 -0
  91. package/dist/src/transaction/common/verifyPayGoAmount.d.ts +2 -0
  92. package/dist/src/transaction/common/verifyPayGoAmount.d.ts.map +1 -0
  93. package/dist/src/transaction/common/verifyPayGoAmount.js +3 -0
  94. package/dist/src/transaction/descriptor/explainPsbt.d.ts +5 -0
  95. package/dist/src/transaction/descriptor/explainPsbt.d.ts.map +1 -0
  96. package/dist/src/transaction/descriptor/explainPsbt.js +80 -0
  97. package/dist/src/transaction/descriptor/index.d.ts +7 -0
  98. package/dist/src/transaction/descriptor/index.d.ts.map +1 -0
  99. package/dist/src/transaction/descriptor/index.js +14 -0
  100. package/dist/src/transaction/descriptor/parse.d.ts +15 -0
  101. package/dist/src/transaction/descriptor/parse.d.ts.map +1 -0
  102. package/dist/src/transaction/descriptor/parse.js +116 -0
  103. package/dist/src/transaction/descriptor/parseToAmountType.d.ts +13 -0
  104. package/dist/src/transaction/descriptor/parseToAmountType.d.ts.map +1 -0
  105. package/dist/src/transaction/descriptor/parseToAmountType.js +60 -0
  106. package/dist/src/transaction/descriptor/recipient.d.ts +5 -0
  107. package/dist/src/transaction/descriptor/recipient.d.ts.map +1 -0
  108. package/dist/src/transaction/descriptor/recipient.js +3 -0
  109. package/dist/src/transaction/descriptor/signPsbt.d.ts +25 -0
  110. package/dist/src/transaction/descriptor/signPsbt.d.ts.map +1 -0
  111. package/dist/src/transaction/descriptor/signPsbt.js +43 -0
  112. package/dist/src/transaction/descriptor/verifyTransaction.d.ts +33 -0
  113. package/dist/src/transaction/descriptor/verifyTransaction.d.ts.map +1 -0
  114. package/dist/src/transaction/descriptor/verifyTransaction.js +105 -0
  115. package/dist/src/transaction/explainTransaction.d.ts +17 -0
  116. package/dist/src/transaction/explainTransaction.d.ts.map +1 -0
  117. package/dist/src/transaction/explainTransaction.js +67 -0
  118. package/dist/src/transaction/fetchInputs.d.ts +26 -0
  119. package/dist/src/transaction/fetchInputs.d.ts.map +1 -0
  120. package/dist/src/transaction/fetchInputs.js +109 -0
  121. package/dist/src/transaction/fixedScript/explainTransaction.d.ts +32 -0
  122. package/dist/src/transaction/fixedScript/explainTransaction.d.ts.map +1 -0
  123. package/dist/src/transaction/fixedScript/explainTransaction.js +317 -0
  124. package/dist/src/transaction/fixedScript/index.d.ts +6 -0
  125. package/dist/src/transaction/fixedScript/index.d.ts.map +1 -0
  126. package/dist/src/transaction/fixedScript/index.js +13 -0
  127. package/dist/src/transaction/fixedScript/parseOutput.d.ts +26 -0
  128. package/dist/src/transaction/fixedScript/parseOutput.d.ts.map +1 -0
  129. package/dist/src/transaction/fixedScript/parseOutput.js +213 -0
  130. package/dist/src/transaction/fixedScript/parseTransaction.d.ts +7 -0
  131. package/dist/src/transaction/fixedScript/parseTransaction.d.ts.map +1 -0
  132. package/dist/src/transaction/fixedScript/parseTransaction.js +203 -0
  133. package/dist/src/transaction/fixedScript/signTransaction.d.ts +18 -0
  134. package/dist/src/transaction/fixedScript/signTransaction.d.ts.map +1 -0
  135. package/dist/src/transaction/fixedScript/signTransaction.js +100 -0
  136. package/dist/src/transaction/fixedScript/verifyTransaction.d.ts +4 -0
  137. package/dist/src/transaction/fixedScript/verifyTransaction.d.ts.map +1 -0
  138. package/dist/src/transaction/fixedScript/verifyTransaction.js +176 -0
  139. package/dist/src/transaction/getPayGoVerificationPubkey.d.ts +9 -0
  140. package/dist/src/transaction/getPayGoVerificationPubkey.d.ts.map +1 -0
  141. package/dist/src/transaction/getPayGoVerificationPubkey.js +53 -0
  142. package/dist/src/transaction/index.d.ts +7 -0
  143. package/dist/src/transaction/index.d.ts.map +1 -0
  144. package/dist/src/transaction/index.js +49 -0
  145. package/dist/src/transaction/outputDifference.d.ts +40 -0
  146. package/dist/src/transaction/outputDifference.d.ts.map +1 -0
  147. package/dist/src/transaction/outputDifference.js +47 -0
  148. package/dist/src/transaction/parseTransaction.d.ts +3 -0
  149. package/dist/src/transaction/parseTransaction.d.ts.map +1 -0
  150. package/dist/src/transaction/parseTransaction.js +48 -0
  151. package/dist/src/transaction/recipient.d.ts +29 -0
  152. package/dist/src/transaction/recipient.d.ts.map +1 -0
  153. package/dist/src/transaction/recipient.js +88 -0
  154. package/dist/src/transaction/signTransaction.d.ts +6 -0
  155. package/dist/src/transaction/signTransaction.d.ts.map +1 -0
  156. package/dist/src/transaction/signTransaction.js +102 -0
  157. package/dist/src/transaction/verifyTransaction.d.ts +4 -0
  158. package/dist/src/transaction/verifyTransaction.d.ts.map +1 -0
  159. package/dist/src/transaction/verifyTransaction.js +50 -0
  160. package/dist/src/verifyKey.d.ts +28 -0
  161. package/dist/src/verifyKey.d.ts.map +1 -0
  162. package/dist/src/verifyKey.js +164 -0
  163. package/dist/src/wallet.d.ts +15 -0
  164. package/dist/src/wallet.d.ts.map +1 -0
  165. package/dist/src/wallet.js +8 -0
  166. package/package.json +20 -14
  167. package/.eslintignore +0 -5
  168. package/CHANGELOG.md +0 -235
  169. package/dist/src/parseOutput.d.ts +0 -22
  170. package/dist/src/parseOutput.d.ts.map +0 -1
  171. package/dist/src/parseOutput.js +0 -181
  172. package/dist/src/recovery/smartbitApi.d.ts +0 -11
  173. package/dist/src/recovery/smartbitApi.d.ts.map +0 -1
  174. package/dist/src/recovery/smartbitApi.js +0 -36
  175. package/dist/tsconfig.tsbuildinfo +0 -8041
@@ -1,7 +1,41 @@
1
1
  "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
2
35
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.isReplayProtectionUnspent = exports.getReplayProtectionAddresses = void 0;
4
- const utxolib = require("@bitgo-beta/utxo-lib");
36
+ exports.getReplayProtectionAddresses = getReplayProtectionAddresses;
37
+ exports.isReplayProtectionUnspent = isReplayProtectionUnspent;
38
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
5
39
  function getReplayProtectionAddresses(network) {
6
40
  switch (network) {
7
41
  case utxolib.networks.bitcoincash:
@@ -13,9 +47,7 @@ function getReplayProtectionAddresses(network) {
13
47
  }
14
48
  return [];
15
49
  }
16
- exports.getReplayProtectionAddresses = getReplayProtectionAddresses;
17
50
  function isReplayProtectionUnspent(u, network) {
18
51
  return getReplayProtectionAddresses(network).includes(u.address);
19
52
  }
20
- exports.isReplayProtectionUnspent = isReplayProtectionUnspent;
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwbGF5UHJvdGVjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yZXBsYXlQcm90ZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGdEQUFnRDtBQUVoRCxTQUFnQiw0QkFBNEIsQ0FBQyxPQUF3QjtJQUNuRSxRQUFRLE9BQU8sRUFBRTtRQUNmLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUM7UUFDbEMsS0FBSyxPQUFPLENBQUMsUUFBUSxDQUFDLFNBQVM7WUFDN0IsT0FBTyxDQUFDLG9DQUFvQyxDQUFDLENBQUM7UUFDaEQsS0FBSyxPQUFPLENBQUMsUUFBUSxDQUFDLGtCQUFrQixDQUFDO1FBQ3pDLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxnQkFBZ0I7WUFDcEMsT0FBTyxDQUFDLHFDQUFxQyxDQUFDLENBQUM7S0FDbEQ7SUFFRCxPQUFPLEVBQUUsQ0FBQztBQUNaLENBQUM7QUFYRCxvRUFXQztBQUVELFNBQWdCLHlCQUF5QixDQUN2QyxDQUFpQyxFQUNqQyxPQUF3QjtJQUV4QixPQUFPLDRCQUE0QixDQUFDLE9BQU8sQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDbkUsQ0FBQztBQUxELDhEQUtDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRSZXBsYXlQcm90ZWN0aW9uQWRkcmVzc2VzKG5ldHdvcms6IHV0eG9saWIuTmV0d29yayk6IHN0cmluZ1tdIHtcbiAgc3dpdGNoIChuZXR3b3JrKSB7XG4gICAgY2FzZSB1dHhvbGliLm5ldHdvcmtzLmJpdGNvaW5jYXNoOlxuICAgIGNhc2UgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luc3Y6XG4gICAgICByZXR1cm4gWyczM3AxcTdtVEd5ZU01VW5aRVJHaU1jVlVrWTEyU0NzYXRBJ107XG4gICAgY2FzZSB1dHhvbGliLm5ldHdvcmtzLmJpdGNvaW5jYXNoVGVzdG5ldDpcbiAgICBjYXNlIHV0eG9saWIubmV0d29ya3MuYml0Y29pbnN2VGVzdG5ldDpcbiAgICAgIHJldHVybiBbJzJNdU1uUG9TRGdXRXBOV0gyOFgybkx0WU1YUUpDeVQ2MWVZJ107XG4gIH1cblxuICByZXR1cm4gW107XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1JlcGxheVByb3RlY3Rpb25VbnNwZW50PFROdW1iZXIgZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQ+KFxuICB1OiB1dHhvbGliLmJpdGdvLlVuc3BlbnQ8VE51bWJlcj4sXG4gIG5ldHdvcms6IHV0eG9saWIuTmV0d29ya1xuKTogYm9vbGVhbiB7XG4gIHJldHVybiBnZXRSZXBsYXlQcm90ZWN0aW9uQWRkcmVzc2VzKG5ldHdvcmspLmluY2x1ZGVzKHUuYWRkcmVzcyk7XG59XG4iXX0=
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwbGF5UHJvdGVjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yZXBsYXlQcm90ZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsb0VBV0M7QUFFRCw4REFLQztBQXBCRCw4REFBZ0Q7QUFFaEQsU0FBZ0IsNEJBQTRCLENBQUMsT0FBd0I7SUFDbkUsUUFBUSxPQUFPLEVBQUUsQ0FBQztRQUNoQixLQUFLLE9BQU8sQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDO1FBQ2xDLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxTQUFTO1lBQzdCLE9BQU8sQ0FBQyxvQ0FBb0MsQ0FBQyxDQUFDO1FBQ2hELEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQztRQUN6QyxLQUFLLE9BQU8sQ0FBQyxRQUFRLENBQUMsZ0JBQWdCO1lBQ3BDLE9BQU8sQ0FBQyxxQ0FBcUMsQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFRCxPQUFPLEVBQUUsQ0FBQztBQUNaLENBQUM7QUFFRCxTQUFnQix5QkFBeUIsQ0FDdkMsQ0FBaUMsRUFDakMsT0FBd0I7SUFFeEIsT0FBTyw0QkFBNEIsQ0FBQyxPQUFPLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0FBQ25FLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyB1dHhvbGliIGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldFJlcGxheVByb3RlY3Rpb25BZGRyZXNzZXMobmV0d29yazogdXR4b2xpYi5OZXR3b3JrKTogc3RyaW5nW10ge1xuICBzd2l0Y2ggKG5ldHdvcmspIHtcbiAgICBjYXNlIHV0eG9saWIubmV0d29ya3MuYml0Y29pbmNhc2g6XG4gICAgY2FzZSB1dHhvbGliLm5ldHdvcmtzLmJpdGNvaW5zdjpcbiAgICAgIHJldHVybiBbJzMzcDFxN21UR3llTTVVblpFUkdpTWNWVWtZMTJTQ3NhdEEnXTtcbiAgICBjYXNlIHV0eG9saWIubmV0d29ya3MuYml0Y29pbmNhc2hUZXN0bmV0OlxuICAgIGNhc2UgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luc3ZUZXN0bmV0OlxuICAgICAgcmV0dXJuIFsnMk11TW5Qb1NEZ1dFcE5XSDI4WDJuTHRZTVhRSkN5VDYxZVknXTtcbiAgfVxuXG4gIHJldHVybiBbXTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzUmVwbGF5UHJvdGVjdGlvblVuc3BlbnQ8VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludD4oXG4gIHU6IHV0eG9saWIuYml0Z28uVW5zcGVudDxUTnVtYmVyPixcbiAgbmV0d29yazogdXR4b2xpYi5OZXR3b3JrXG4pOiBib29sZWFuIHtcbiAgcmV0dXJuIGdldFJlcGxheVByb3RlY3Rpb25BZGRyZXNzZXMobmV0d29yaykuaW5jbHVkZXModS5hZGRyZXNzKTtcbn1cbiJdfQ==
@@ -1,19 +1,42 @@
1
- /**
2
- * @prettier
3
- */
4
1
  import * as utxolib from '@bitgo-beta/utxo-lib';
5
- declare type Unspent<TNumber extends number | bigint = number> = utxolib.bitgo.Unspent<TNumber>;
6
- declare type RootWalletKeys = utxolib.bitgo.RootWalletKeys;
2
+ type Unspent<TNumber extends number | bigint = number> = utxolib.bitgo.Unspent<TNumber>;
3
+ type RootWalletKeys = utxolib.bitgo.RootWalletKeys;
7
4
  export declare class InputSigningError<TNumber extends number | bigint = number> extends Error {
8
5
  inputIndex: number;
9
- unspent: Unspent<TNumber>;
6
+ unspent: Unspent<TNumber> | {
7
+ id: string;
8
+ };
10
9
  reason: Error | string;
11
- static expectedWalletUnspent<TNumber extends number | bigint>(inputIndex: number, unspent: Unspent<TNumber>): InputSigningError<TNumber>;
12
- constructor(inputIndex: number, unspent: Unspent<TNumber>, reason: Error | string);
10
+ static expectedWalletUnspent<TNumber extends number | bigint>(inputIndex: number, unspent: Unspent<TNumber> | {
11
+ id: string;
12
+ }): InputSigningError<TNumber>;
13
+ constructor(inputIndex: number, unspent: Unspent<TNumber> | {
14
+ id: string;
15
+ }, reason: Error | string);
13
16
  }
14
17
  export declare class TransactionSigningError<TNumber extends number | bigint = number> extends Error {
15
18
  constructor(signErrors: InputSigningError<TNumber>[], verifyError: InputSigningError<TNumber>[]);
16
19
  }
20
+ /**
21
+ * Sign all inputs of a psbt and verify signatures after signing.
22
+ * Collects and logs signing errors and verification errors, throws error in the end if any of them
23
+ * failed.
24
+ *
25
+ * If it is the last signature, finalize and extract the transaction from the psbt.
26
+ *
27
+ * This function mirrors signAndVerifyWalletTransaction, but is used for signing PSBTs instead of
28
+ * using TransactionBuilder
29
+ *
30
+ * @param psbt
31
+ * @param signerKeychain
32
+ * @param isLastSignature
33
+ */
34
+ export declare function signAndVerifyPsbt(psbt: utxolib.bitgo.UtxoPsbt, signerKeychain: utxolib.BIP32Interface, { isLastSignature,
35
+ /** deprecated */
36
+ allowNonSegwitSigningWithoutPrevTx, }: {
37
+ isLastSignature: boolean;
38
+ allowNonSegwitSigningWithoutPrevTx?: boolean;
39
+ }): utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint>;
17
40
  /**
18
41
  * Sign all inputs of a wallet transaction and verify signatures after signing.
19
42
  * Collects and logs signing errors and verification errors, throws error in the end if any of them
@@ -1 +1 @@
1
- {"version":3,"file":"sign.d.ts","sourceRoot":"","sources":["../../src/sign.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAEhD,aAAK,OAAO,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,IAAI,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;AACxF,aAAK,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,cAAc,CAAC;AAQnD,qBAAa,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,CAAE,SAAQ,KAAK;IAQjE,UAAU,EAAE,MAAM;IAAS,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC;IAAS,MAAM,EAAE,KAAK,GAAG,MAAM;IAPtG,MAAM,CAAC,qBAAqB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAC1D,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC,GACxB,iBAAiB,CAAC,OAAO,CAAC;gBAIV,UAAU,EAAE,MAAM,EAAS,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC,EAAS,MAAM,EAAE,KAAK,GAAG,MAAM;CAGvG;AAED,qBAAa,uBAAuB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,CAAE,SAAQ,KAAK;gBAC9E,UAAU,EAAE,iBAAiB,CAAC,OAAO,CAAC,EAAE,EAAE,WAAW,EAAE,iBAAiB,CAAC,OAAO,CAAC,EAAE;CAMhG;AAED;;;;;;;;;GASG;AACH,wBAAgB,8BAA8B,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAC5E,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,sBAAsB,CAAC,OAAO,CAAC,EACnG,QAAQ,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE,EAC5B,YAAY,EAAE,OAAO,CAAC,KAAK,CAAC,mBAAmB,CAAC,cAAc,CAAC,EAC/D,EAAE,eAAe,EAAE,EAAE;IAAE,eAAe,EAAE,OAAO,CAAA;CAAE,GAChD,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,OAAO,CAAC,CAqExC"}
1
+ {"version":3,"file":"sign.d.ts","sourceRoot":"","sources":["../../src/sign.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAShD,KAAK,OAAO,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,IAAI,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;AAExF,KAAK,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,cAAc,CAAC;AAUnD,qBAAa,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,CAAE,SAAQ,KAAK;IAS3E,UAAU,EAAE,MAAM;IAClB,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC,GAAG;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE;IAC1C,MAAM,EAAE,KAAK,GAAG,MAAM;IAV/B,MAAM,CAAC,qBAAqB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAC1D,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC,GAAG;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,GACzC,iBAAiB,CAAC,OAAO,CAAC;gBAKpB,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC,GAAG;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,EAC1C,MAAM,EAAE,KAAK,GAAG,MAAM;CAIhC;AAED,qBAAa,uBAAuB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,CAAE,SAAQ,KAAK;gBAC9E,UAAU,EAAE,iBAAiB,CAAC,OAAO,CAAC,EAAE,EAAE,WAAW,EAAE,iBAAiB,CAAC,OAAO,CAAC,EAAE;CAMhG;AAED;;;;;;;;;;;;;GAaG;AACH,wBAAgB,iBAAiB,CAC/B,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,EAC5B,cAAc,EAAE,OAAO,CAAC,cAAc,EACtC,EACE,eAAe;AACf,iBAAiB;AACjB,kCAAkC,GACnC,EAAE;IAAE,eAAe,EAAE,OAAO,CAAC;IAAC,kCAAkC,CAAC,EAAE,OAAO,CAAA;CAAE,GAC5E,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,CAAC,CA6DhE;AAED;;;;;;;;;GASG;AACH,wBAAgB,8BAA8B,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAC5E,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,sBAAsB,CAAC,OAAO,CAAC,EACnG,QAAQ,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE,EAC5B,YAAY,EAAE,OAAO,CAAC,KAAK,CAAC,mBAAmB,CAAC,cAAc,CAAC,EAC/D,EAAE,eAAe,EAAE,EAAE;IAAE,eAAe,EAAE,OAAO,CAAA;CAAE,GAChD,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,OAAO,CAAC,CAqExC"}
package/dist/src/sign.js CHANGED
@@ -1,24 +1,59 @@
1
1
  "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
2
38
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.signAndVerifyWalletTransaction = exports.TransactionSigningError = exports.InputSigningError = void 0;
4
- /**
5
- * @prettier
6
- */
7
- const utxolib = require("@bitgo-beta/utxo-lib");
8
- const { isWalletUnspent, signInputWithUnspent, toOutput } = utxolib.bitgo;
9
- const debugLib = require("debug");
39
+ exports.TransactionSigningError = exports.InputSigningError = void 0;
40
+ exports.signAndVerifyPsbt = signAndVerifyPsbt;
41
+ exports.signAndVerifyWalletTransaction = signAndVerifyWalletTransaction;
42
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
43
+ const debug_1 = __importDefault(require("debug"));
10
44
  const replayProtection_1 = require("./replayProtection");
11
- const debug = debugLib('bitgo:v2:utxo');
45
+ const debug = (0, debug_1.default)('bitgo:v2:utxo');
46
+ const { isWalletUnspent, signInputWithUnspent, toOutput } = utxolib.bitgo;
12
47
  class InputSigningError extends Error {
48
+ static expectedWalletUnspent(inputIndex, unspent) {
49
+ return new InputSigningError(inputIndex, unspent, `not a wallet unspent, not a replay protection unspent`);
50
+ }
13
51
  constructor(inputIndex, unspent, reason) {
14
52
  super(`signing error at input ${inputIndex}: unspentId=${unspent.id}: ${reason}`);
15
53
  this.inputIndex = inputIndex;
16
54
  this.unspent = unspent;
17
55
  this.reason = reason;
18
56
  }
19
- static expectedWalletUnspent(inputIndex, unspent) {
20
- return new InputSigningError(inputIndex, unspent, `not a wallet unspent, not a replay protection unspent`);
21
- }
22
57
  }
23
58
  exports.InputSigningError = InputSigningError;
24
59
  class TransactionSigningError extends Error {
@@ -28,6 +63,73 @@ class TransactionSigningError extends Error {
28
63
  }
29
64
  }
30
65
  exports.TransactionSigningError = TransactionSigningError;
66
+ /**
67
+ * Sign all inputs of a psbt and verify signatures after signing.
68
+ * Collects and logs signing errors and verification errors, throws error in the end if any of them
69
+ * failed.
70
+ *
71
+ * If it is the last signature, finalize and extract the transaction from the psbt.
72
+ *
73
+ * This function mirrors signAndVerifyWalletTransaction, but is used for signing PSBTs instead of
74
+ * using TransactionBuilder
75
+ *
76
+ * @param psbt
77
+ * @param signerKeychain
78
+ * @param isLastSignature
79
+ */
80
+ function signAndVerifyPsbt(psbt, signerKeychain, { isLastSignature,
81
+ /** deprecated */
82
+ allowNonSegwitSigningWithoutPrevTx, }) {
83
+ const txInputs = psbt.txInputs;
84
+ const outputIds = [];
85
+ const scriptTypes = [];
86
+ const signErrors = psbt.data.inputs
87
+ .map((input, inputIndex) => {
88
+ const outputId = utxolib.bitgo.formatOutputId(utxolib.bitgo.getOutputIdForInput(txInputs[inputIndex]));
89
+ outputIds.push(outputId);
90
+ const { scriptType } = utxolib.bitgo.parsePsbtInput(input);
91
+ scriptTypes.push(scriptType);
92
+ if (scriptType === 'p2shP2pk') {
93
+ debug('Skipping signature for input %d of %d (RP input?)', inputIndex + 1, psbt.data.inputs.length);
94
+ return;
95
+ }
96
+ try {
97
+ psbt.signInputHD(inputIndex, signerKeychain);
98
+ debug('Successfully signed input %d of %d', inputIndex + 1, psbt.data.inputs.length);
99
+ }
100
+ catch (e) {
101
+ return new InputSigningError(inputIndex, { id: outputId }, e);
102
+ }
103
+ })
104
+ .filter((e) => e !== undefined);
105
+ const verifyErrors = psbt.data.inputs
106
+ .map((input, inputIndex) => {
107
+ const scriptType = scriptTypes[inputIndex];
108
+ if (scriptType === 'p2shP2pk') {
109
+ debug('Skipping input signature %d of %d (unspent from replay protection address which is platform signed only)', inputIndex + 1, psbt.data.inputs.length);
110
+ return;
111
+ }
112
+ const outputId = outputIds[inputIndex];
113
+ try {
114
+ if (!psbt.validateSignaturesOfInputHD(inputIndex, signerKeychain)) {
115
+ return new InputSigningError(inputIndex, { id: outputId }, new Error(`invalid signature`));
116
+ }
117
+ }
118
+ catch (e) {
119
+ debug('Invalid signature');
120
+ return new InputSigningError(inputIndex, { id: outputId }, e);
121
+ }
122
+ })
123
+ .filter((e) => e !== undefined);
124
+ if (signErrors.length || verifyErrors.length) {
125
+ throw new TransactionSigningError(signErrors, verifyErrors);
126
+ }
127
+ if (isLastSignature) {
128
+ psbt.finalizeAllInputs();
129
+ return psbt.extractTransaction();
130
+ }
131
+ return psbt;
132
+ }
31
133
  /**
32
134
  * Sign all inputs of a wallet transaction and verify signatures after signing.
33
135
  * Collects and logs signing errors and verification errors, throws error in the end if any of them
@@ -56,7 +158,7 @@ function signAndVerifyWalletTransaction(transaction, unspents, walletSigner, { i
56
158
  }
57
159
  const signErrors = unspents
58
160
  .map((unspent, inputIndex) => {
59
- if (replayProtection_1.isReplayProtectionUnspent(unspent, network)) {
161
+ if ((0, replayProtection_1.isReplayProtectionUnspent)(unspent, network)) {
60
162
  debug('Skipping signature for input %d of %d (RP input?)', inputIndex + 1, unspents.length);
61
163
  return;
62
164
  }
@@ -76,7 +178,7 @@ function signAndVerifyWalletTransaction(transaction, unspents, walletSigner, { i
76
178
  const verifyErrors = signedTransaction.ins
77
179
  .map((input, inputIndex) => {
78
180
  const unspent = unspents[inputIndex];
79
- if (replayProtection_1.isReplayProtectionUnspent(unspent, network)) {
181
+ if ((0, replayProtection_1.isReplayProtectionUnspent)(unspent, network)) {
80
182
  debug('Skipping input signature %d of %d (unspent from replay protection address which is platform signed only)', inputIndex + 1, unspents.length);
81
183
  return;
82
184
  }
@@ -100,5 +202,4 @@ function signAndVerifyWalletTransaction(transaction, unspents, walletSigner, { i
100
202
  }
101
203
  return signedTransaction;
102
204
  }
103
- exports.signAndVerifyWalletTransaction = signAndVerifyWalletTransaction;
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sign.js","sourceRoot":"","sources":["../../src/sign.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nconst { isWalletUnspent, signInputWithUnspent, toOutput } = utxolib.bitgo;\ntype Unspent<TNumber extends number | bigint = number> = utxolib.bitgo.Unspent<TNumber>;\ntype RootWalletKeys = utxolib.bitgo.RootWalletKeys;\n\nimport * as debugLib from 'debug';\n\nimport { isReplayProtectionUnspent } from './replayProtection';\n\nconst debug = debugLib('bitgo:v2:utxo');\n\nexport class InputSigningError<TNumber extends number | bigint = number> extends Error {\n  static expectedWalletUnspent<TNumber extends number | bigint>(\n    inputIndex: number,\n    unspent: Unspent<TNumber>\n  ): InputSigningError<TNumber> {\n    return new InputSigningError(inputIndex, unspent, `not a wallet unspent, not a replay protection unspent`);\n  }\n\n  constructor(public inputIndex: number, public unspent: Unspent<TNumber>, public reason: Error | string) {\n    super(`signing error at input ${inputIndex}: unspentId=${unspent.id}: ${reason}`);\n  }\n}\n\nexport class TransactionSigningError<TNumber extends number | bigint = number> extends Error {\n  constructor(signErrors: InputSigningError<TNumber>[], verifyError: InputSigningError<TNumber>[]) {\n    super(\n      `sign errors at inputs: [${signErrors.join(',')}], ` +\n        `verify errors at inputs: [${verifyError.join(',')}], see log for details`\n    );\n  }\n}\n\n/**\n * Sign all inputs of a wallet transaction and verify signatures after signing.\n * Collects and logs signing errors and verification errors, throws error in the end if any of them\n * failed.\n *\n * @param transaction - wallet transaction (builder) to be signed\n * @param unspents - transaction unspents\n * @param walletSigner - signing parameters\n * @param isLastSignature - Returns full-signed transaction when true. Builds half-signed when false.\n */\nexport function signAndVerifyWalletTransaction<TNumber extends number | bigint>(\n  transaction: utxolib.bitgo.UtxoTransaction<TNumber> | utxolib.bitgo.UtxoTransactionBuilder<TNumber>,\n  unspents: Unspent<TNumber>[],\n  walletSigner: utxolib.bitgo.WalletUnspentSigner<RootWalletKeys>,\n  { isLastSignature }: { isLastSignature: boolean }\n): utxolib.bitgo.UtxoTransaction<TNumber> {\n  const network = transaction.network as utxolib.Network;\n  const prevOutputs = unspents.map((u) => toOutput(u, network));\n\n  let txBuilder: utxolib.bitgo.UtxoTransactionBuilder<TNumber>;\n  if (transaction instanceof utxolib.bitgo.UtxoTransaction) {\n    txBuilder = utxolib.bitgo.createTransactionBuilderFromTransaction<TNumber>(transaction, prevOutputs);\n    if (transaction.ins.length !== unspents.length) {\n      throw new Error(`transaction inputs must match unspents`);\n    }\n  } else if (transaction instanceof utxolib.bitgo.UtxoTransactionBuilder) {\n    txBuilder = transaction;\n  } else {\n    throw new Error(`must pass UtxoTransaction or UtxoTransactionBuilder`);\n  }\n\n  const signErrors: InputSigningError<TNumber>[] = unspents\n    .map((unspent: Unspent<TNumber>, inputIndex: number) => {\n      if (isReplayProtectionUnspent<TNumber>(unspent, network)) {\n        debug('Skipping signature for input %d of %d (RP input?)', inputIndex + 1, unspents.length);\n        return;\n      }\n      if (!isWalletUnspent<TNumber>(unspent)) {\n        return InputSigningError.expectedWalletUnspent<TNumber>(inputIndex, unspent);\n      }\n      try {\n        signInputWithUnspent<TNumber>(txBuilder, inputIndex, unspent, walletSigner);\n        debug('Successfully signed input %d of %d', inputIndex + 1, unspents.length);\n      } catch (e) {\n        return new InputSigningError<TNumber>(inputIndex, unspent, e);\n      }\n    })\n    .filter((e): e is InputSigningError<TNumber> => e !== undefined);\n\n  const signedTransaction = isLastSignature ? txBuilder.build() : txBuilder.buildIncomplete();\n\n  const verifyErrors: InputSigningError<TNumber>[] = signedTransaction.ins\n    .map((input, inputIndex) => {\n      const unspent = unspents[inputIndex] as Unspent<TNumber>;\n      if (isReplayProtectionUnspent<TNumber>(unspent, network)) {\n        debug(\n          'Skipping input signature %d of %d (unspent from replay protection address which is platform signed only)',\n          inputIndex + 1,\n          unspents.length\n        );\n        return;\n      }\n      if (!isWalletUnspent<TNumber>(unspent)) {\n        return InputSigningError.expectedWalletUnspent<TNumber>(inputIndex, unspent);\n      }\n      try {\n        const publicKey = walletSigner.deriveForChainAndIndex(unspent.chain, unspent.index).signer.publicKey;\n        if (\n          !utxolib.bitgo.verifySignatureWithPublicKey<TNumber>(signedTransaction, inputIndex, prevOutputs, publicKey)\n        ) {\n          return new InputSigningError(inputIndex, unspent, new Error(`invalid signature`));\n        }\n      } catch (e) {\n        debug('Invalid signature');\n        return new InputSigningError<TNumber>(inputIndex, unspent, e);\n      }\n    })\n    .filter((e): e is InputSigningError<TNumber> => e !== undefined);\n\n  if (signErrors.length || verifyErrors.length) {\n    throw new TransactionSigningError(signErrors, verifyErrors);\n  }\n\n  return signedTransaction;\n}\n"]}
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sign.js","sourceRoot":"","sources":["../../src/sign.ts"],"names":[],"mappings":"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","sourcesContent":["import * as utxolib from '@bitgo-beta/utxo-lib';\nimport debugLib from 'debug';\n\nimport { isReplayProtectionUnspent } from './replayProtection';\n\nconst debug = debugLib('bitgo:v2:utxo');\n\nconst { isWalletUnspent, signInputWithUnspent, toOutput } = utxolib.bitgo;\n\ntype Unspent<TNumber extends number | bigint = number> = utxolib.bitgo.Unspent<TNumber>;\n\ntype RootWalletKeys = utxolib.bitgo.RootWalletKeys;\n\ntype PsbtParsedScriptTypes =\n  | 'p2sh'\n  | 'p2wsh'\n  | 'p2shP2wsh'\n  | 'p2shP2pk'\n  | 'taprootKeyPathSpend'\n  | 'taprootScriptPathSpend';\n\nexport class InputSigningError<TNumber extends number | bigint = number> extends Error {\n  static expectedWalletUnspent<TNumber extends number | bigint>(\n    inputIndex: number,\n    unspent: Unspent<TNumber> | { id: string }\n  ): InputSigningError<TNumber> {\n    return new InputSigningError(inputIndex, unspent, `not a wallet unspent, not a replay protection unspent`);\n  }\n\n  constructor(\n    public inputIndex: number,\n    public unspent: Unspent<TNumber> | { id: string },\n    public reason: Error | string\n  ) {\n    super(`signing error at input ${inputIndex}: unspentId=${unspent.id}: ${reason}`);\n  }\n}\n\nexport class TransactionSigningError<TNumber extends number | bigint = number> extends Error {\n  constructor(signErrors: InputSigningError<TNumber>[], verifyError: InputSigningError<TNumber>[]) {\n    super(\n      `sign errors at inputs: [${signErrors.join(',')}], ` +\n        `verify errors at inputs: [${verifyError.join(',')}], see log for details`\n    );\n  }\n}\n\n/**\n * Sign all inputs of a psbt and verify signatures after signing.\n * Collects and logs signing errors and verification errors, throws error in the end if any of them\n * failed.\n *\n * If it is the last signature, finalize and extract the transaction from the psbt.\n *\n * This function mirrors signAndVerifyWalletTransaction, but is used for signing PSBTs instead of\n * using TransactionBuilder\n *\n * @param psbt\n * @param signerKeychain\n * @param isLastSignature\n */\nexport function signAndVerifyPsbt(\n  psbt: utxolib.bitgo.UtxoPsbt,\n  signerKeychain: utxolib.BIP32Interface,\n  {\n    isLastSignature,\n    /** deprecated */\n    allowNonSegwitSigningWithoutPrevTx,\n  }: { isLastSignature: boolean; allowNonSegwitSigningWithoutPrevTx?: boolean }\n): utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint> {\n  const txInputs = psbt.txInputs;\n  const outputIds: string[] = [];\n  const scriptTypes: PsbtParsedScriptTypes[] = [];\n\n  const signErrors: InputSigningError<bigint>[] = psbt.data.inputs\n    .map((input, inputIndex: number) => {\n      const outputId = utxolib.bitgo.formatOutputId(utxolib.bitgo.getOutputIdForInput(txInputs[inputIndex]));\n      outputIds.push(outputId);\n\n      const { scriptType } = utxolib.bitgo.parsePsbtInput(input);\n      scriptTypes.push(scriptType);\n\n      if (scriptType === 'p2shP2pk') {\n        debug('Skipping signature for input %d of %d (RP input?)', inputIndex + 1, psbt.data.inputs.length);\n        return;\n      }\n\n      try {\n        psbt.signInputHD(inputIndex, signerKeychain);\n        debug('Successfully signed input %d of %d', inputIndex + 1, psbt.data.inputs.length);\n      } catch (e) {\n        return new InputSigningError<bigint>(inputIndex, { id: outputId }, e);\n      }\n    })\n    .filter((e): e is InputSigningError<bigint> => e !== undefined);\n\n  const verifyErrors: InputSigningError<bigint>[] = psbt.data.inputs\n    .map((input, inputIndex) => {\n      const scriptType = scriptTypes[inputIndex];\n      if (scriptType === 'p2shP2pk') {\n        debug(\n          'Skipping input signature %d of %d (unspent from replay protection address which is platform signed only)',\n          inputIndex + 1,\n          psbt.data.inputs.length\n        );\n        return;\n      }\n\n      const outputId = outputIds[inputIndex];\n      try {\n        if (!psbt.validateSignaturesOfInputHD(inputIndex, signerKeychain)) {\n          return new InputSigningError(inputIndex, { id: outputId }, new Error(`invalid signature`));\n        }\n      } catch (e) {\n        debug('Invalid signature');\n        return new InputSigningError<bigint>(inputIndex, { id: outputId }, e);\n      }\n    })\n    .filter((e): e is InputSigningError<bigint> => e !== undefined);\n\n  if (signErrors.length || verifyErrors.length) {\n    throw new TransactionSigningError(signErrors, verifyErrors);\n  }\n\n  if (isLastSignature) {\n    psbt.finalizeAllInputs();\n    return psbt.extractTransaction();\n  }\n\n  return psbt;\n}\n\n/**\n * Sign all inputs of a wallet transaction and verify signatures after signing.\n * Collects and logs signing errors and verification errors, throws error in the end if any of them\n * failed.\n *\n * @param transaction - wallet transaction (builder) to be signed\n * @param unspents - transaction unspents\n * @param walletSigner - signing parameters\n * @param isLastSignature - Returns full-signed transaction when true. Builds half-signed when false.\n */\nexport function signAndVerifyWalletTransaction<TNumber extends number | bigint>(\n  transaction: utxolib.bitgo.UtxoTransaction<TNumber> | utxolib.bitgo.UtxoTransactionBuilder<TNumber>,\n  unspents: Unspent<TNumber>[],\n  walletSigner: utxolib.bitgo.WalletUnspentSigner<RootWalletKeys>,\n  { isLastSignature }: { isLastSignature: boolean }\n): utxolib.bitgo.UtxoTransaction<TNumber> {\n  const network = transaction.network as utxolib.Network;\n  const prevOutputs = unspents.map((u) => toOutput(u, network));\n\n  let txBuilder: utxolib.bitgo.UtxoTransactionBuilder<TNumber>;\n  if (transaction instanceof utxolib.bitgo.UtxoTransaction) {\n    txBuilder = utxolib.bitgo.createTransactionBuilderFromTransaction<TNumber>(transaction, prevOutputs);\n    if (transaction.ins.length !== unspents.length) {\n      throw new Error(`transaction inputs must match unspents`);\n    }\n  } else if (transaction instanceof utxolib.bitgo.UtxoTransactionBuilder) {\n    txBuilder = transaction;\n  } else {\n    throw new Error(`must pass UtxoTransaction or UtxoTransactionBuilder`);\n  }\n\n  const signErrors: InputSigningError<TNumber>[] = unspents\n    .map((unspent: Unspent<TNumber>, inputIndex: number) => {\n      if (isReplayProtectionUnspent<TNumber>(unspent, network)) {\n        debug('Skipping signature for input %d of %d (RP input?)', inputIndex + 1, unspents.length);\n        return;\n      }\n      if (!isWalletUnspent<TNumber>(unspent)) {\n        return InputSigningError.expectedWalletUnspent<TNumber>(inputIndex, unspent);\n      }\n      try {\n        signInputWithUnspent<TNumber>(txBuilder, inputIndex, unspent, walletSigner);\n        debug('Successfully signed input %d of %d', inputIndex + 1, unspents.length);\n      } catch (e) {\n        return new InputSigningError<TNumber>(inputIndex, unspent, e);\n      }\n    })\n    .filter((e): e is InputSigningError<TNumber> => e !== undefined);\n\n  const signedTransaction = isLastSignature ? txBuilder.build() : txBuilder.buildIncomplete();\n\n  const verifyErrors: InputSigningError<TNumber>[] = signedTransaction.ins\n    .map((input, inputIndex) => {\n      const unspent = unspents[inputIndex] as Unspent<TNumber>;\n      if (isReplayProtectionUnspent<TNumber>(unspent, network)) {\n        debug(\n          'Skipping input signature %d of %d (unspent from replay protection address which is platform signed only)',\n          inputIndex + 1,\n          unspents.length\n        );\n        return;\n      }\n      if (!isWalletUnspent<TNumber>(unspent)) {\n        return InputSigningError.expectedWalletUnspent<TNumber>(inputIndex, unspent);\n      }\n      try {\n        const publicKey = walletSigner.deriveForChainAndIndex(unspent.chain, unspent.index).signer.publicKey;\n        if (\n          !utxolib.bitgo.verifySignatureWithPublicKey<TNumber>(signedTransaction, inputIndex, prevOutputs, publicKey)\n        ) {\n          return new InputSigningError(inputIndex, unspent, new Error(`invalid signature`));\n        }\n      } catch (e) {\n        debug('Invalid signature');\n        return new InputSigningError<TNumber>(inputIndex, unspent, e);\n      }\n    })\n    .filter((e): e is InputSigningError<TNumber> => e !== undefined);\n\n  if (signErrors.length || verifyErrors.length) {\n    throw new TransactionSigningError(signErrors, verifyErrors);\n  }\n\n  return signedTransaction;\n}\n"]}
@@ -0,0 +1,27 @@
1
+ import * as t from 'io-ts';
2
+ declare const BIP322MessageInfo: t.TypeC<{
3
+ address: t.StringC;
4
+ message: t.StringC;
5
+ pubkeys: t.ArrayC<t.StringC>;
6
+ scriptType: t.UnionC<[t.LiteralC<"p2sh">, t.LiteralC<"p2shP2wsh">, t.LiteralC<"p2wsh">, t.LiteralC<"p2tr">, t.LiteralC<"p2trMusig2">]>;
7
+ }>;
8
+ export type BIP322MessageInfo = t.TypeOf<typeof BIP322MessageInfo>;
9
+ declare const BIP322MessageBroadcastable: t.TypeC<{
10
+ txHex: t.StringC;
11
+ messageInfo: t.ArrayC<t.TypeC<{
12
+ address: t.StringC;
13
+ message: t.StringC;
14
+ pubkeys: t.ArrayC<t.StringC>;
15
+ scriptType: t.UnionC<[t.LiteralC<"p2sh">, t.LiteralC<"p2shP2wsh">, t.LiteralC<"p2wsh">, t.LiteralC<"p2tr">, t.LiteralC<"p2trMusig2">]>;
16
+ }>>;
17
+ }>;
18
+ export type BIP322MessageBroadcastable = t.TypeOf<typeof BIP322MessageBroadcastable>;
19
+ export declare function serializeBIP322BroadcastableMessage(message: BIP322MessageBroadcastable): string;
20
+ export declare function deserializeBIP322BroadcastableMessage(hex: string): BIP322MessageBroadcastable;
21
+ export declare function verifyTransactionFromBroadcastableMessage(message: BIP322MessageBroadcastable, coinName: string): boolean;
22
+ export declare function generateBIP322MessageListAndVerifyFromMessageBroadcastable(messageBroadcastables: BIP322MessageBroadcastable[], coinName: string): {
23
+ address: string;
24
+ message: string;
25
+ }[];
26
+ export {};
27
+ //# sourceMappingURL=bip322.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bip322.d.ts","sourceRoot":"","sources":["../../../src/transaction/bip322.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,CAAC,MAAM,OAAO,CAAC;AAE3B,QAAA,MAAM,iBAAiB;;;;;EAWrB,CAAC;AAEH,MAAM,MAAM,iBAAiB,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,iBAAiB,CAAC,CAAC;AAEnE,QAAA,MAAM,0BAA0B;;;;;;;;EAG9B,CAAC;AAEH,MAAM,MAAM,0BAA0B,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,0BAA0B,CAAC,CAAC;AAErF,wBAAgB,mCAAmC,CAAC,OAAO,EAAE,0BAA0B,GAAG,MAAM,CAE/F;AAED,wBAAgB,qCAAqC,CAAC,GAAG,EAAE,MAAM,GAAG,0BAA0B,CAK7F;AAED,wBAAgB,yCAAyC,CACvD,OAAO,EAAE,0BAA0B,EACnC,QAAQ,EAAE,MAAM,GACf,OAAO,CAwBT;AAED,wBAAgB,0DAA0D,CACxE,qBAAqB,EAAE,0BAA0B,EAAE,EACnD,QAAQ,EAAE,MAAM,GACf;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,EAAE,CA0BxC"}
@@ -0,0 +1,125 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.serializeBIP322BroadcastableMessage = serializeBIP322BroadcastableMessage;
37
+ exports.deserializeBIP322BroadcastableMessage = deserializeBIP322BroadcastableMessage;
38
+ exports.verifyTransactionFromBroadcastableMessage = verifyTransactionFromBroadcastableMessage;
39
+ exports.generateBIP322MessageListAndVerifyFromMessageBroadcastable = generateBIP322MessageListAndVerifyFromMessageBroadcastable;
40
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
41
+ const utxo_core_1 = require("@bitgo-beta/utxo-core");
42
+ const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
43
+ const t = __importStar(require("io-ts"));
44
+ const BIP322MessageInfo = t.type({
45
+ address: t.string,
46
+ message: t.string,
47
+ pubkeys: t.array(t.string),
48
+ scriptType: t.union([
49
+ t.literal('p2sh'),
50
+ t.literal('p2shP2wsh'),
51
+ t.literal('p2wsh'),
52
+ t.literal('p2tr'),
53
+ t.literal('p2trMusig2'),
54
+ ]),
55
+ });
56
+ const BIP322MessageBroadcastable = t.type({
57
+ txHex: t.string,
58
+ messageInfo: t.array(BIP322MessageInfo),
59
+ });
60
+ function serializeBIP322BroadcastableMessage(message) {
61
+ return Buffer.from(JSON.stringify(message), 'utf8').toString('hex');
62
+ }
63
+ function deserializeBIP322BroadcastableMessage(hex) {
64
+ const json = JSON.parse(Buffer.from(hex, 'hex').toString('utf8'));
65
+ return (0, sdk_core_1.decodeOrElse)(BIP322MessageBroadcastable.name, BIP322MessageBroadcastable, json, (error) => {
66
+ throw new Error(`Failed to decode ${BIP322MessageBroadcastable.name}: ${error}`);
67
+ });
68
+ }
69
+ function verifyTransactionFromBroadcastableMessage(message, coinName) {
70
+ let network = utxo_lib_1.networks.bitcoin;
71
+ if (coinName === 'tbtc4') {
72
+ network = utxo_lib_1.networks.bitcoinTestnet4;
73
+ }
74
+ else if (coinName !== 'btc') {
75
+ throw new Error('Only tbtc4 or btc coinNames are supported.');
76
+ }
77
+ if (utxo_lib_1.bitgo.isPsbt(message.txHex)) {
78
+ const psbt = utxo_lib_1.bitgo.createPsbtFromBuffer(Buffer.from(message.txHex, 'hex'), network);
79
+ try {
80
+ utxo_core_1.bip322.assertBip322PsbtProof(psbt, message.messageInfo);
81
+ return true;
82
+ }
83
+ catch (error) {
84
+ return false;
85
+ }
86
+ }
87
+ else {
88
+ const tx = utxo_lib_1.bitgo.createTransactionFromBuffer(Buffer.from(message.txHex, 'hex'), network, { amountType: 'bigint' });
89
+ try {
90
+ utxo_core_1.bip322.assertBip322TxProof(tx, message.messageInfo);
91
+ return true;
92
+ }
93
+ catch (error) {
94
+ return false;
95
+ }
96
+ }
97
+ }
98
+ function generateBIP322MessageListAndVerifyFromMessageBroadcastable(messageBroadcastables, coinName) {
99
+ // Map from the address to the message. If there are duplicates of the address, make sure that the
100
+ // message is the same. If there are duplicate addresses and the messages are not the same, throw an error.
101
+ const addressMap = new Map();
102
+ messageBroadcastables.forEach((message, index) => {
103
+ if (verifyTransactionFromBroadcastableMessage(message, coinName)) {
104
+ message.messageInfo.forEach((info) => {
105
+ const { address, message: msg } = info;
106
+ if (addressMap.has(address)) {
107
+ if (addressMap.get(address) !== msg) {
108
+ throw new Error(`Duplicate address ${address} has different messages`);
109
+ }
110
+ }
111
+ else {
112
+ addressMap.set(address, msg);
113
+ }
114
+ });
115
+ }
116
+ else {
117
+ throw new Error(`Message Broadcastable ${index} did not have a successful validation`);
118
+ }
119
+ });
120
+ return Array.from(addressMap.entries()).map(([address, message]) => ({
121
+ address,
122
+ message,
123
+ }));
124
+ }
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bip322.js","sourceRoot":"","sources":["../../../src/transaction/bip322.ts"],"names":[],"mappings":"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","sourcesContent":["import { decodeOrElse } from '@bitgo-beta/sdk-core';\nimport { bip322 } from '@bitgo-beta/utxo-core';\nimport { bitgo, networks, Network } from '@bitgo-beta/utxo-lib';\nimport * as t from 'io-ts';\n\nconst BIP322MessageInfo = t.type({\n  address: t.string,\n  message: t.string,\n  pubkeys: t.array(t.string),\n  scriptType: t.union([\n    t.literal('p2sh'),\n    t.literal('p2shP2wsh'),\n    t.literal('p2wsh'),\n    t.literal('p2tr'),\n    t.literal('p2trMusig2'),\n  ]),\n});\n\nexport type BIP322MessageInfo = t.TypeOf<typeof BIP322MessageInfo>;\n\nconst BIP322MessageBroadcastable = t.type({\n  txHex: t.string,\n  messageInfo: t.array(BIP322MessageInfo),\n});\n\nexport type BIP322MessageBroadcastable = t.TypeOf<typeof BIP322MessageBroadcastable>;\n\nexport function serializeBIP322BroadcastableMessage(message: BIP322MessageBroadcastable): string {\n  return Buffer.from(JSON.stringify(message), 'utf8').toString('hex');\n}\n\nexport function deserializeBIP322BroadcastableMessage(hex: string): BIP322MessageBroadcastable {\n  const json = JSON.parse(Buffer.from(hex, 'hex').toString('utf8'));\n  return decodeOrElse(BIP322MessageBroadcastable.name, BIP322MessageBroadcastable, json, (error) => {\n    throw new Error(`Failed to decode ${BIP322MessageBroadcastable.name}: ${error}`);\n  });\n}\n\nexport function verifyTransactionFromBroadcastableMessage(\n  message: BIP322MessageBroadcastable,\n  coinName: string\n): boolean {\n  let network: Network = networks.bitcoin;\n  if (coinName === 'tbtc4') {\n    network = networks.bitcoinTestnet4;\n  } else if (coinName !== 'btc') {\n    throw new Error('Only tbtc4 or btc coinNames are supported.');\n  }\n  if (bitgo.isPsbt(message.txHex)) {\n    const psbt = bitgo.createPsbtFromBuffer(Buffer.from(message.txHex, 'hex'), network);\n    try {\n      bip322.assertBip322PsbtProof(psbt, message.messageInfo);\n      return true;\n    } catch (error) {\n      return false;\n    }\n  } else {\n    const tx = bitgo.createTransactionFromBuffer(Buffer.from(message.txHex, 'hex'), network, { amountType: 'bigint' });\n    try {\n      bip322.assertBip322TxProof(tx, message.messageInfo);\n      return true;\n    } catch (error) {\n      return false;\n    }\n  }\n}\n\nexport function generateBIP322MessageListAndVerifyFromMessageBroadcastable(\n  messageBroadcastables: BIP322MessageBroadcastable[],\n  coinName: string\n): { address: string; message: string }[] {\n  // Map from the address to the message. If there are duplicates of the address, make sure that the\n  // message is the same. If there are duplicate addresses and the messages are not the same, throw an error.\n  const addressMap = new Map<string, string>();\n\n  messageBroadcastables.forEach((message, index) => {\n    if (verifyTransactionFromBroadcastableMessage(message, coinName)) {\n      message.messageInfo.forEach((info) => {\n        const { address, message: msg } = info;\n        if (addressMap.has(address)) {\n          if (addressMap.get(address) !== msg) {\n            throw new Error(`Duplicate address ${address} has different messages`);\n          }\n        } else {\n          addressMap.set(address, msg);\n        }\n      });\n    } else {\n      throw new Error(`Message Broadcastable ${index} did not have a successful validation`);\n    }\n  });\n\n  return Array.from(addressMap.entries()).map(([address, message]) => ({\n    address,\n    message,\n  }));\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=verifyPayGoAmount.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"verifyPayGoAmount.d.ts","sourceRoot":"","sources":["../../../../src/transaction/common/verifyPayGoAmount.ts"],"names":[],"mappings":""}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyaWZ5UGF5R29BbW91bnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHJhbnNhY3Rpb24vY29tbW9uL3ZlcmlmeVBheUdvQW1vdW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIiXX0=
@@ -0,0 +1,5 @@
1
+ import * as utxolib from '@bitgo-beta/utxo-lib';
2
+ import * as coreDescriptors from '@bitgo-beta/utxo-core/descriptor';
3
+ import { TransactionExplanation } from '../../abstractUtxoCoin';
4
+ export declare function explainPsbt(psbt: utxolib.bitgo.UtxoPsbt, descriptors: coreDescriptors.DescriptorMap): TransactionExplanation;
5
+ //# sourceMappingURL=explainPsbt.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"explainPsbt.d.ts","sourceRoot":"","sources":["../../../../src/transaction/descriptor/explainPsbt.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAEhD,OAAO,KAAK,eAAe,MAAM,kCAAkC,CAAC;AAGpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AA4BhE,wBAAgB,WAAW,CACzB,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,EAC5B,WAAW,EAAE,eAAe,CAAC,aAAa,GACzC,sBAAsB,CAkBxB"}