@bitgo-beta/abstract-utxo 1.6.1-alpha.413 → 1.6.1-alpha.414

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 (106) hide show
  1. package/dist/src/abstractUtxoCoin.d.ts +3 -5
  2. package/dist/src/abstractUtxoCoin.d.ts.map +1 -1
  3. package/dist/src/abstractUtxoCoin.js +43 -9
  4. package/dist/src/impl/bch/bch.d.ts +20 -0
  5. package/dist/src/impl/bch/bch.d.ts.map +1 -0
  6. package/dist/src/impl/bch/bch.js +70 -0
  7. package/dist/src/impl/bch/index.d.ts +3 -0
  8. package/dist/src/impl/bch/index.d.ts.map +1 -0
  9. package/dist/src/impl/bch/index.js +19 -0
  10. package/dist/src/impl/bch/tbch.d.ts +10 -0
  11. package/dist/src/impl/bch/tbch.d.ts.map +1 -0
  12. package/dist/src/impl/bch/tbch.js +48 -0
  13. package/dist/src/impl/bcha/bcha.d.ts +9 -0
  14. package/dist/src/impl/bcha/bcha.d.ts.map +1 -0
  15. package/dist/src/impl/bcha/bcha.js +58 -0
  16. package/dist/src/impl/bcha/index.d.ts +3 -0
  17. package/dist/src/impl/bcha/index.d.ts.map +1 -0
  18. package/dist/src/impl/bcha/index.js +19 -0
  19. package/dist/src/impl/bcha/tbcha.d.ts +10 -0
  20. package/dist/src/impl/bcha/tbcha.d.ts.map +1 -0
  21. package/dist/src/impl/bcha/tbcha.js +48 -0
  22. package/dist/src/impl/bsv/bsv.d.ts +8 -0
  23. package/dist/src/impl/bsv/bsv.d.ts.map +1 -0
  24. package/dist/src/impl/bsv/bsv.js +48 -0
  25. package/dist/src/impl/bsv/index.d.ts +3 -0
  26. package/dist/src/impl/bsv/index.d.ts.map +1 -0
  27. package/dist/src/impl/bsv/index.js +19 -0
  28. package/dist/src/impl/bsv/tbsv.d.ts +10 -0
  29. package/dist/src/impl/bsv/tbsv.d.ts.map +1 -0
  30. package/dist/src/impl/bsv/tbsv.js +48 -0
  31. package/dist/src/impl/btc/btc.d.ts +13 -0
  32. package/dist/src/impl/btc/btc.d.ts.map +1 -0
  33. package/dist/src/impl/btc/btc.js +55 -0
  34. package/dist/src/impl/btc/index.d.ts +7 -0
  35. package/dist/src/impl/btc/index.d.ts.map +1 -0
  36. package/dist/src/impl/btc/index.js +23 -0
  37. package/dist/src/impl/btc/inscriptionBuilder.d.ts +51 -0
  38. package/dist/src/impl/btc/inscriptionBuilder.d.ts.map +1 -0
  39. package/dist/src/impl/btc/inscriptionBuilder.js +183 -0
  40. package/dist/src/impl/btc/tbtc.d.ts +10 -0
  41. package/dist/src/impl/btc/tbtc.d.ts.map +1 -0
  42. package/dist/src/impl/btc/tbtc.js +48 -0
  43. package/dist/src/impl/btc/tbtc4.d.ts +10 -0
  44. package/dist/src/impl/btc/tbtc4.d.ts.map +1 -0
  45. package/dist/src/impl/btc/tbtc4.js +48 -0
  46. package/dist/src/impl/btc/tbtcbgsig.d.ts +10 -0
  47. package/dist/src/impl/btc/tbtcbgsig.d.ts.map +1 -0
  48. package/dist/src/impl/btc/tbtcbgsig.js +48 -0
  49. package/dist/src/impl/btc/tbtcsig.d.ts +10 -0
  50. package/dist/src/impl/btc/tbtcsig.d.ts.map +1 -0
  51. package/dist/src/impl/btc/tbtcsig.js +48 -0
  52. package/dist/src/impl/btg/btg.d.ts +7 -0
  53. package/dist/src/impl/btg/btg.d.ts.map +1 -0
  54. package/dist/src/impl/btg/btg.js +48 -0
  55. package/dist/src/impl/btg/index.d.ts +2 -0
  56. package/dist/src/impl/btg/index.d.ts.map +1 -0
  57. package/dist/src/impl/btg/index.js +18 -0
  58. package/dist/src/impl/dash/dash.d.ts +7 -0
  59. package/dist/src/impl/dash/dash.d.ts.map +1 -0
  60. package/dist/src/impl/dash/dash.js +48 -0
  61. package/dist/src/impl/dash/index.d.ts +3 -0
  62. package/dist/src/impl/dash/index.d.ts.map +1 -0
  63. package/dist/src/impl/dash/index.js +19 -0
  64. package/dist/src/impl/dash/tdash.d.ts +10 -0
  65. package/dist/src/impl/dash/tdash.d.ts.map +1 -0
  66. package/dist/src/impl/dash/tdash.js +48 -0
  67. package/dist/src/impl/doge/doge.d.ts +30 -0
  68. package/dist/src/impl/doge/doge.d.ts.map +1 -0
  69. package/dist/src/impl/doge/doge.js +79 -0
  70. package/dist/src/impl/doge/index.d.ts +3 -0
  71. package/dist/src/impl/doge/index.d.ts.map +1 -0
  72. package/dist/src/impl/doge/index.js +19 -0
  73. package/dist/src/impl/doge/tdoge.d.ts +10 -0
  74. package/dist/src/impl/doge/tdoge.d.ts.map +1 -0
  75. package/dist/src/impl/doge/tdoge.js +48 -0
  76. package/dist/src/impl/index.d.ts +10 -0
  77. package/dist/src/impl/index.d.ts.map +1 -0
  78. package/dist/src/impl/index.js +46 -0
  79. package/dist/src/impl/ltc/index.d.ts +3 -0
  80. package/dist/src/impl/ltc/index.d.ts.map +1 -0
  81. package/dist/src/impl/ltc/index.js +19 -0
  82. package/dist/src/impl/ltc/ltc.d.ts +7 -0
  83. package/dist/src/impl/ltc/ltc.d.ts.map +1 -0
  84. package/dist/src/impl/ltc/ltc.js +52 -0
  85. package/dist/src/impl/ltc/tltc.d.ts +7 -0
  86. package/dist/src/impl/ltc/tltc.d.ts.map +1 -0
  87. package/dist/src/impl/ltc/tltc.js +51 -0
  88. package/dist/src/impl/zec/index.d.ts +3 -0
  89. package/dist/src/impl/zec/index.d.ts.map +1 -0
  90. package/dist/src/impl/zec/index.js +19 -0
  91. package/dist/src/impl/zec/tzec.d.ts +7 -0
  92. package/dist/src/impl/zec/tzec.d.ts.map +1 -0
  93. package/dist/src/impl/zec/tzec.js +48 -0
  94. package/dist/src/impl/zec/zec.d.ts +10 -0
  95. package/dist/src/impl/zec/zec.d.ts.map +1 -0
  96. package/dist/src/impl/zec/zec.js +48 -0
  97. package/dist/src/index.d.ts +10 -0
  98. package/dist/src/index.d.ts.map +1 -1
  99. package/dist/src/index.js +13 -2
  100. package/dist/src/transaction/descriptor/verifyTransaction.d.ts +5 -3
  101. package/dist/src/transaction/descriptor/verifyTransaction.d.ts.map +1 -1
  102. package/dist/src/transaction/descriptor/verifyTransaction.js +5 -2
  103. package/dist/src/transaction/fixedScript/verifyTransaction.d.ts +17 -0
  104. package/dist/src/transaction/fixedScript/verifyTransaction.d.ts.map +1 -1
  105. package/dist/src/transaction/fixedScript/verifyTransaction.js +27 -5
  106. package/package.json +16 -10
@@ -0,0 +1,19 @@
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./zec"), exports);
18
+ __exportStar(require("./tzec"), exports);
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvaW1wbC96ZWMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHdDQUFzQjtBQUN0Qix5Q0FBdUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3plYyc7XG5leHBvcnQgKiBmcm9tICcuL3R6ZWMnO1xuIl19
@@ -0,0 +1,7 @@
1
+ import { BaseCoin, BitGoBase } from '@bitgo-beta/sdk-core';
2
+ import { Zec } from './zec';
3
+ export declare class Tzec extends Zec {
4
+ constructor(bitgo: BitGoBase);
5
+ static createInstance(bitgo: BitGoBase): BaseCoin;
6
+ }
7
+ //# sourceMappingURL=tzec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tzec.d.ts","sourceRoot":"","sources":["../../../../src/impl/zec/tzec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAG3D,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAE5B,qBAAa,IAAK,SAAQ,GAAG;gBACf,KAAK,EAAE,SAAS;IAI5B,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,SAAS,GAAG,QAAQ;CAGlD"}
@@ -0,0 +1,48 @@
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.Tzec = void 0;
37
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
38
+ const zec_1 = require("./zec");
39
+ class Tzec extends zec_1.Zec {
40
+ constructor(bitgo) {
41
+ super(bitgo, utxolib.networks.zcashTest);
42
+ }
43
+ static createInstance(bitgo) {
44
+ return new Tzec(bitgo);
45
+ }
46
+ }
47
+ exports.Tzec = Tzec;
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHplYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9pbXBsL3plYy90emVjLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUNBLDhEQUFnRDtBQUVoRCwrQkFBNEI7QUFFNUIsTUFBYSxJQUFLLFNBQVEsU0FBRztJQUMzQixZQUFZLEtBQWdCO1FBQzFCLEtBQUssQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMzQyxDQUFDO0lBRUQsTUFBTSxDQUFDLGNBQWMsQ0FBQyxLQUFnQjtRQUNwQyxPQUFPLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3pCLENBQUM7Q0FDRjtBQVJELG9CQVFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZUNvaW4sIEJpdEdvQmFzZSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuXG5pbXBvcnQgeyBaZWMgfSBmcm9tICcuL3plYyc7XG5cbmV4cG9ydCBjbGFzcyBUemVjIGV4dGVuZHMgWmVjIHtcbiAgY29uc3RydWN0b3IoYml0Z286IEJpdEdvQmFzZSkge1xuICAgIHN1cGVyKGJpdGdvLCB1dHhvbGliLm5ldHdvcmtzLnpjYXNoVGVzdCk7XG4gIH1cblxuICBzdGF0aWMgY3JlYXRlSW5zdGFuY2UoYml0Z286IEJpdEdvQmFzZSk6IEJhc2VDb2luIHtcbiAgICByZXR1cm4gbmV3IFR6ZWMoYml0Z28pO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,10 @@
1
+ /**
2
+ * @prettier
3
+ */
4
+ import { BitGoBase, BaseCoin } from '@bitgo-beta/sdk-core';
5
+ import { AbstractUtxoCoin, UtxoNetwork } from '../../abstractUtxoCoin';
6
+ export declare class Zec extends AbstractUtxoCoin {
7
+ constructor(bitgo: BitGoBase, network?: UtxoNetwork);
8
+ static createInstance(bitgo: BitGoBase): BaseCoin;
9
+ }
10
+ //# sourceMappingURL=zec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"zec.d.ts","sourceRoot":"","sources":["../../../../src/impl/zec/zec.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAG3D,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAEvE,qBAAa,GAAI,SAAQ,gBAAgB;gBAC3B,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,WAAW;IAInD,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,SAAS,GAAG,QAAQ;CAGlD"}
@@ -0,0 +1,48 @@
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.Zec = void 0;
37
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
38
+ const abstractUtxoCoin_1 = require("../../abstractUtxoCoin");
39
+ class Zec extends abstractUtxoCoin_1.AbstractUtxoCoin {
40
+ constructor(bitgo, network) {
41
+ super(bitgo, network || utxolib.networks.zcash);
42
+ }
43
+ static createInstance(bitgo) {
44
+ return new Zec(bitgo);
45
+ }
46
+ }
47
+ exports.Zec = Zec;
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiemVjLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2ltcGwvemVjL3plYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFJQSw4REFBZ0Q7QUFFaEQsNkRBQXVFO0FBRXZFLE1BQWEsR0FBSSxTQUFRLG1DQUFnQjtJQUN2QyxZQUFZLEtBQWdCLEVBQUUsT0FBcUI7UUFDakQsS0FBSyxDQUFDLEtBQUssRUFBRSxPQUFPLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRUQsTUFBTSxDQUFDLGNBQWMsQ0FBQyxLQUFnQjtRQUNwQyxPQUFPLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3hCLENBQUM7Q0FDRjtBQVJELGtCQVFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAcHJldHRpZXJcbiAqL1xuaW1wb3J0IHsgQml0R29CYXNlLCBCYXNlQ29pbiB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuXG5pbXBvcnQgeyBBYnN0cmFjdFV0eG9Db2luLCBVdHhvTmV0d29yayB9IGZyb20gJy4uLy4uL2Fic3RyYWN0VXR4b0NvaW4nO1xuXG5leHBvcnQgY2xhc3MgWmVjIGV4dGVuZHMgQWJzdHJhY3RVdHhvQ29pbiB7XG4gIGNvbnN0cnVjdG9yKGJpdGdvOiBCaXRHb0Jhc2UsIG5ldHdvcms/OiBVdHhvTmV0d29yaykge1xuICAgIHN1cGVyKGJpdGdvLCBuZXR3b3JrIHx8IHV0eG9saWIubmV0d29ya3MuemNhc2gpO1xuICB9XG5cbiAgc3RhdGljIGNyZWF0ZUluc3RhbmNlKGJpdGdvOiBCaXRHb0Jhc2UpOiBCYXNlQ29pbiB7XG4gICAgcmV0dXJuIG5ldyBaZWMoYml0Z28pO1xuICB9XG59XG4iXX0=
@@ -7,4 +7,14 @@ export { UtxoWallet } from './wallet';
7
7
  export * as descriptor from './descriptor';
8
8
  export * as offlineVault from './offlineVault';
9
9
  export * as transaction from './transaction';
10
+ export * as impl from './impl';
11
+ export * from './impl/btc';
12
+ export * from './impl/bch';
13
+ export * from './impl/bcha';
14
+ export * from './impl/bsv';
15
+ export * from './impl/btg';
16
+ export * from './impl/ltc';
17
+ export * from './impl/dash';
18
+ export * from './impl/doge';
19
+ export * from './impl/zec';
10
20
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,cAAc,QAAQ,CAAC;AAEvB,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,YAAY,MAAM,gBAAgB,CAAC;AAC/C,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,cAAc,QAAQ,CAAC;AAEvB,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,YAAY,MAAM,gBAAgB,CAAC;AAC/C,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAC7C,OAAO,KAAK,IAAI,MAAM,QAAQ,CAAC;AAG/B,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC"}
package/dist/src/index.js CHANGED
@@ -36,7 +36,7 @@ var __importStar = (this && this.__importStar) || (function () {
36
36
  };
37
37
  })();
38
38
  Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.transaction = exports.offlineVault = exports.descriptor = void 0;
39
+ exports.impl = exports.transaction = exports.offlineVault = exports.descriptor = void 0;
40
40
  __exportStar(require("./abstractUtxoCoin"), exports);
41
41
  __exportStar(require("./config"), exports);
42
42
  __exportStar(require("./recovery"), exports);
@@ -45,4 +45,15 @@ __exportStar(require("./sign"), exports);
45
45
  exports.descriptor = __importStar(require("./descriptor"));
46
46
  exports.offlineVault = __importStar(require("./offlineVault"));
47
47
  exports.transaction = __importStar(require("./transaction"));
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEscURBQW1DO0FBQ25DLDJDQUF5QjtBQUN6Qiw2Q0FBMkI7QUFDM0IscURBQW1DO0FBQ25DLHlDQUF1QjtBQUd2QiwyREFBMkM7QUFDM0MsK0RBQStDO0FBQy9DLDZEQUE2QyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYWJzdHJhY3RVdHhvQ29pbic7XG5leHBvcnQgKiBmcm9tICcuL2NvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL3JlY292ZXJ5JztcbmV4cG9ydCAqIGZyb20gJy4vcmVwbGF5UHJvdGVjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3NpZ24nO1xuXG5leHBvcnQgeyBVdHhvV2FsbGV0IH0gZnJvbSAnLi93YWxsZXQnO1xuZXhwb3J0ICogYXMgZGVzY3JpcHRvciBmcm9tICcuL2Rlc2NyaXB0b3InO1xuZXhwb3J0ICogYXMgb2ZmbGluZVZhdWx0IGZyb20gJy4vb2ZmbGluZVZhdWx0JztcbmV4cG9ydCAqIGFzIHRyYW5zYWN0aW9uIGZyb20gJy4vdHJhbnNhY3Rpb24nO1xuIl19
48
+ exports.impl = __importStar(require("./impl"));
49
+ // Export all coin implementations
50
+ __exportStar(require("./impl/btc"), exports);
51
+ __exportStar(require("./impl/bch"), exports);
52
+ __exportStar(require("./impl/bcha"), exports);
53
+ __exportStar(require("./impl/bsv"), exports);
54
+ __exportStar(require("./impl/btg"), exports);
55
+ __exportStar(require("./impl/ltc"), exports);
56
+ __exportStar(require("./impl/dash"), exports);
57
+ __exportStar(require("./impl/doge"), exports);
58
+ __exportStar(require("./impl/zec"), exports);
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEscURBQW1DO0FBQ25DLDJDQUF5QjtBQUN6Qiw2Q0FBMkI7QUFDM0IscURBQW1DO0FBQ25DLHlDQUF1QjtBQUd2QiwyREFBMkM7QUFDM0MsK0RBQStDO0FBQy9DLDZEQUE2QztBQUM3QywrQ0FBK0I7QUFFL0Isa0NBQWtDO0FBQ2xDLDZDQUEyQjtBQUMzQiw2Q0FBMkI7QUFDM0IsOENBQTRCO0FBQzVCLDZDQUEyQjtBQUMzQiw2Q0FBMkI7QUFDM0IsNkNBQTJCO0FBQzNCLDhDQUE0QjtBQUM1Qiw4Q0FBNEI7QUFDNUIsNkNBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hYnN0cmFjdFV0eG9Db2luJztcbmV4cG9ydCAqIGZyb20gJy4vY29uZmlnJztcbmV4cG9ydCAqIGZyb20gJy4vcmVjb3ZlcnknO1xuZXhwb3J0ICogZnJvbSAnLi9yZXBsYXlQcm90ZWN0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vc2lnbic7XG5cbmV4cG9ydCB7IFV0eG9XYWxsZXQgfSBmcm9tICcuL3dhbGxldCc7XG5leHBvcnQgKiBhcyBkZXNjcmlwdG9yIGZyb20gJy4vZGVzY3JpcHRvcic7XG5leHBvcnQgKiBhcyBvZmZsaW5lVmF1bHQgZnJvbSAnLi9vZmZsaW5lVmF1bHQnO1xuZXhwb3J0ICogYXMgdHJhbnNhY3Rpb24gZnJvbSAnLi90cmFuc2FjdGlvbic7XG5leHBvcnQgKiBhcyBpbXBsIGZyb20gJy4vaW1wbCc7XG5cbi8vIEV4cG9ydCBhbGwgY29pbiBpbXBsZW1lbnRhdGlvbnNcbmV4cG9ydCAqIGZyb20gJy4vaW1wbC9idGMnO1xuZXhwb3J0ICogZnJvbSAnLi9pbXBsL2JjaCc7XG5leHBvcnQgKiBmcm9tICcuL2ltcGwvYmNoYSc7XG5leHBvcnQgKiBmcm9tICcuL2ltcGwvYnN2JztcbmV4cG9ydCAqIGZyb20gJy4vaW1wbC9idGcnO1xuZXhwb3J0ICogZnJvbSAnLi9pbXBsL2x0Yyc7XG5leHBvcnQgKiBmcm9tICcuL2ltcGwvZGFzaCc7XG5leHBvcnQgKiBmcm9tICcuL2ltcGwvZG9nZSc7XG5leHBvcnQgKiBmcm9tICcuL2ltcGwvemVjJztcbiJdfQ==
@@ -1,7 +1,7 @@
1
1
  import * as utxolib from '@bitgo-beta/utxo-lib';
2
- import { ITransactionRecipient, VerifyTransactionOptions } from '@bitgo-beta/sdk-core';
2
+ import { ITransactionRecipient } from '@bitgo-beta/sdk-core';
3
3
  import { DescriptorMap } from '@bitgo-beta/utxo-core/descriptor';
4
- import { AbstractUtxoCoin, BaseOutput, BaseParsedTransactionOutputs } from '../../abstractUtxoCoin';
4
+ import { AbstractUtxoCoin, BaseOutput, BaseParsedTransactionOutputs, VerifyTransactionOptions } from '../../abstractUtxoCoin';
5
5
  export declare class ValidationError extends Error {
6
6
  constructor(message: string);
7
7
  }
@@ -28,6 +28,8 @@ export declare function assertValidTransaction(psbt: utxolib.bitgo.UtxoPsbt, des
28
28
  * @param coin
29
29
  * @param params
30
30
  * @param descriptorMap
31
+ * @returns {boolean} True if verification passes
32
+ * @throws {TxIntentMismatchError} if transaction validation fails
31
33
  */
32
- export declare function verifyTransaction(coin: AbstractUtxoCoin, params: VerifyTransactionOptions, descriptorMap: DescriptorMap): Promise<boolean>;
34
+ export declare function verifyTransaction<TNumber extends number | bigint>(coin: AbstractUtxoCoin, params: VerifyTransactionOptions<TNumber>, descriptorMap: DescriptorMap): Promise<boolean>;
33
35
  //# sourceMappingURL=verifyTransaction.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"verifyTransaction.d.ts","sourceRoot":"","sources":["../../../../src/transaction/descriptor/verifyTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;AACvF,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AAEjE,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,4BAA4B,EAAE,MAAM,wBAAwB,CAAC;AAIpG,qBAAa,eAAgB,SAAQ,KAAK;gBAC5B,OAAO,EAAE,MAAM;CAG5B;AAED,qBAAa,mBAAoB,SAAQ,eAAe;IACnC,cAAc,EAAE,UAAU,CAAC,MAAM,GAAG,KAAK,CAAC,EAAE;gBAA5C,cAAc,EAAE,UAAU,CAAC,MAAM,GAAG,KAAK,CAAC,EAAE;CAGhE;AAED,qBAAa,4BAA6B,SAAQ,eAAe;IAC5C,uBAAuB,EAAE,UAAU,CAAC,MAAM,GAAG,KAAK,CAAC,EAAE;gBAArD,uBAAuB,EAAE,UAAU,CAAC,MAAM,GAAG,KAAK,CAAC,EAAE;CAGzE;AAED,qBAAa,wBAAyB,SAAQ,eAAe;IACxC,MAAM,EAAE,eAAe,EAAE;gBAAzB,MAAM,EAAE,eAAe,EAAE;CAG7C;AAED,wBAAgB,8BAA8B,CAC5C,aAAa,EAAE,4BAA4B,CAAC,MAAM,EAAE,UAAU,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC,GAC9E,IAAI,CAcN;AAED,wBAAgB,sBAAsB,CACpC,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,EAC5B,WAAW,EAAE,aAAa,EAC1B,UAAU,EAAE,qBAAqB,EAAE,EACnC,OAAO,EAAE,OAAO,CAAC,OAAO,GACvB,IAAI,CAEN;AAED;;;;;;;;;GASG;AACH,wBAAsB,iBAAiB,CACrC,IAAI,EAAE,gBAAgB,EACtB,MAAM,EAAE,wBAAwB,EAChC,aAAa,EAAE,aAAa,GAC3B,OAAO,CAAC,OAAO,CAAC,CAOlB"}
1
+ {"version":3,"file":"verifyTransaction.d.ts","sourceRoot":"","sources":["../../../../src/transaction/descriptor/verifyTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAyB,MAAM,sBAAsB,CAAC;AACpF,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AAEjE,OAAO,EACL,gBAAgB,EAChB,UAAU,EACV,4BAA4B,EAC5B,wBAAwB,EACzB,MAAM,wBAAwB,CAAC;AAIhC,qBAAa,eAAgB,SAAQ,KAAK;gBAC5B,OAAO,EAAE,MAAM;CAG5B;AAED,qBAAa,mBAAoB,SAAQ,eAAe;IACnC,cAAc,EAAE,UAAU,CAAC,MAAM,GAAG,KAAK,CAAC,EAAE;gBAA5C,cAAc,EAAE,UAAU,CAAC,MAAM,GAAG,KAAK,CAAC,EAAE;CAGhE;AAED,qBAAa,4BAA6B,SAAQ,eAAe;IAC5C,uBAAuB,EAAE,UAAU,CAAC,MAAM,GAAG,KAAK,CAAC,EAAE;gBAArD,uBAAuB,EAAE,UAAU,CAAC,MAAM,GAAG,KAAK,CAAC,EAAE;CAGzE;AAED,qBAAa,wBAAyB,SAAQ,eAAe;IACxC,MAAM,EAAE,eAAe,EAAE;gBAAzB,MAAM,EAAE,eAAe,EAAE;CAG7C;AAED,wBAAgB,8BAA8B,CAC5C,aAAa,EAAE,4BAA4B,CAAC,MAAM,EAAE,UAAU,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC,GAC9E,IAAI,CAcN;AAED,wBAAgB,sBAAsB,CACpC,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,EAC5B,WAAW,EAAE,aAAa,EAC1B,UAAU,EAAE,qBAAqB,EAAE,EACnC,OAAO,EAAE,OAAO,CAAC,OAAO,GACvB,IAAI,CAEN;AAED;;;;;;;;;;;GAWG;AACH,wBAAsB,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACrE,IAAI,EAAE,gBAAgB,EACtB,MAAM,EAAE,wBAAwB,CAAC,OAAO,CAAC,EACzC,aAAa,EAAE,aAAa,GAC3B,OAAO,CAAC,OAAO,CAAC,CAclB"}
@@ -38,6 +38,7 @@ exports.assertExpectedOutputDifference = assertExpectedOutputDifference;
38
38
  exports.assertValidTransaction = assertValidTransaction;
39
39
  exports.verifyTransaction = verifyTransaction;
40
40
  const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
41
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
41
42
  const parse_1 = require("./parse");
42
43
  class ValidationError extends Error {
43
44
  constructor(message) {
@@ -93,13 +94,15 @@ function assertValidTransaction(psbt, descriptors, recipients, network) {
93
94
  * @param coin
94
95
  * @param params
95
96
  * @param descriptorMap
97
+ * @returns {boolean} True if verification passes
98
+ * @throws {TxIntentMismatchError} if transaction validation fails
96
99
  */
97
100
  async function verifyTransaction(coin, params, descriptorMap) {
98
101
  const tx = coin.decodeTransactionFromPrebuild(params.txPrebuild);
99
102
  if (!(tx instanceof utxolib.bitgo.UtxoPsbt)) {
100
- throw new Error('unexpected transaction type');
103
+ throw new sdk_core_1.TxIntentMismatchError('unexpected transaction type', params.reqId, [params.txParams], params.txPrebuild.txHex);
101
104
  }
102
105
  assertValidTransaction(tx, descriptorMap, params.txParams.recipients ?? [], tx.network);
103
106
  return true;
104
107
  }
105
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyaWZ5VHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHJhbnNhY3Rpb24vZGVzY3JpcHRvci92ZXJpZnlUcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFnQ0Esd0VBZ0JDO0FBRUQsd0RBT0M7QUFZRCw4Q0FXQztBQWhGRCw4REFBZ0Q7QUFNaEQsbUNBQWlFO0FBRWpFLE1BQWEsZUFBZ0IsU0FBUSxLQUFLO0lBQ3hDLFlBQVksT0FBZTtRQUN6QixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztDQUNGO0FBSkQsMENBSUM7QUFFRCxNQUFhLG1CQUFvQixTQUFRLGVBQWU7SUFDdEQsWUFBbUIsY0FBNEM7UUFDN0QsS0FBSyxDQUFDLDBCQUEwQixjQUFjLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztRQUR6QyxtQkFBYyxHQUFkLGNBQWMsQ0FBOEI7SUFFL0QsQ0FBQztDQUNGO0FBSkQsa0RBSUM7QUFFRCxNQUFhLDRCQUE2QixTQUFRLGVBQWU7SUFDL0QsWUFBbUIsdUJBQXFEO1FBQ3RFLEtBQUssQ0FBQywrQ0FBK0MsdUJBQXVCLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztRQUR2RSw0QkFBdUIsR0FBdkIsdUJBQXVCLENBQThCO0lBRXhFLENBQUM7Q0FDRjtBQUpELG9FQUlDO0FBRUQsTUFBYSx3QkFBeUIsU0FBUSxlQUFlO0lBQzNELFlBQW1CLE1BQXlCO1FBQzFDLEtBQUssQ0FBQyxxQ0FBcUMsTUFBTSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7UUFENUMsV0FBTSxHQUFOLE1BQU0sQ0FBbUI7SUFFNUMsQ0FBQztDQUNGO0FBSkQsNERBSUM7QUFFRCxTQUFnQiw4QkFBOEIsQ0FDNUMsYUFBK0U7SUFFL0UsTUFBTSxNQUFNLEdBQXNCLEVBQUUsQ0FBQztJQUNyQyxJQUFJLGFBQWEsQ0FBQyxjQUFjLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQzVDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxtQkFBbUIsQ0FBQyxhQUFhLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQztJQUNyRSxDQUFDO0lBQ0QsSUFBSSxhQUFhLENBQUMsdUJBQXVCLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ3JELHNEQUFzRDtRQUN0RCxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksNEJBQTRCLENBQUMsYUFBYSxDQUFDLHVCQUF1QixDQUFDLENBQUMsQ0FBQztJQUN2RixDQUFDO0lBQ0QsSUFBSSxNQUFNLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ3RCLGlDQUFpQztRQUNqQyxvQ0FBb0M7UUFDcEMsTUFBTSxJQUFJLHdCQUF3QixDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzdDLENBQUM7QUFDSCxDQUFDO0FBRUQsU0FBZ0Isc0JBQXNCLENBQ3BDLElBQTRCLEVBQzVCLFdBQTBCLEVBQzFCLFVBQW1DLEVBQ25DLE9BQXdCO0lBRXhCLDhCQUE4QixDQUFDLElBQUEsOENBQXNDLEVBQUMsSUFBSSxFQUFFLFdBQVcsRUFBRSxVQUFVLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQztBQUNqSCxDQUFDO0FBRUQ7Ozs7Ozs7OztHQVNHO0FBQ0ksS0FBSyxVQUFVLGlCQUFpQixDQUNyQyxJQUFzQixFQUN0QixNQUFnQyxFQUNoQyxhQUE0QjtJQUU1QixNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUMsNkJBQTZCLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ2pFLElBQUksQ0FBQyxDQUFDLEVBQUUsWUFBWSxPQUFPLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7UUFDNUMsTUFBTSxJQUFJLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFDRCxzQkFBc0IsQ0FBQyxFQUFFLEVBQUUsYUFBYSxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsVUFBVSxJQUFJLEVBQUUsRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDeEYsT0FBTyxJQUFJLENBQUM7QUFDZCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBJVHJhbnNhY3Rpb25SZWNpcGllbnQsIFZlcmlmeVRyYW5zYWN0aW9uT3B0aW9ucyB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCB7IERlc2NyaXB0b3JNYXAgfSBmcm9tICdAYml0Z28tYmV0YS91dHhvLWNvcmUvZGVzY3JpcHRvcic7XG5cbmltcG9ydCB7IEFic3RyYWN0VXR4b0NvaW4sIEJhc2VPdXRwdXQsIEJhc2VQYXJzZWRUcmFuc2FjdGlvbk91dHB1dHMgfSBmcm9tICcuLi8uLi9hYnN0cmFjdFV0eG9Db2luJztcblxuaW1wb3J0IHsgdG9CYXNlUGFyc2VkVHJhbnNhY3Rpb25PdXRwdXRzRnJvbVBzYnQgfSBmcm9tICcuL3BhcnNlJztcblxuZXhwb3J0IGNsYXNzIFZhbGlkYXRpb25FcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEVycm9yTWlzc2luZ091dHB1dHMgZXh0ZW5kcyBWYWxpZGF0aW9uRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihwdWJsaWMgbWlzc2luZ091dHB1dHM6IEJhc2VPdXRwdXQ8YmlnaW50IHwgJ21heCc+W10pIHtcbiAgICBzdXBlcihgbWlzc2luZyBvdXRwdXRzIChjb3VudD0ke21pc3NpbmdPdXRwdXRzLmxlbmd0aH0pYCk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEVycm9ySW1wbGljaXRFeHRlcm5hbE91dHB1dHMgZXh0ZW5kcyBWYWxpZGF0aW9uRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihwdWJsaWMgaW1wbGljaXRFeHRlcm5hbE91dHB1dHM6IEJhc2VPdXRwdXQ8YmlnaW50IHwgJ21heCc+W10pIHtcbiAgICBzdXBlcihgdW5leHBlY3RlZCBpbXBsaWNpdCBleHRlcm5hbCBvdXRwdXRzIChjb3VudD0ke2ltcGxpY2l0RXh0ZXJuYWxPdXRwdXRzLmxlbmd0aH0pYCk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEFnZ3JlZ2F0ZVZhbGlkYXRpb25FcnJvciBleHRlbmRzIFZhbGlkYXRpb25FcnJvciB7XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBlcnJvcnM6IFZhbGlkYXRpb25FcnJvcltdKSB7XG4gICAgc3VwZXIoYGFnZ3JlZ2F0ZSB2YWxpZGF0aW9uIGVycm9yIChjb3VudD0ke2Vycm9ycy5sZW5ndGh9KWApO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBhc3NlcnRFeHBlY3RlZE91dHB1dERpZmZlcmVuY2UoXG4gIHBhcnNlZE91dHB1dHM6IEJhc2VQYXJzZWRUcmFuc2FjdGlvbk91dHB1dHM8YmlnaW50LCBCYXNlT3V0cHV0PGJpZ2ludCB8ICdtYXgnPj5cbik6IHZvaWQge1xuICBjb25zdCBlcnJvcnM6IFZhbGlkYXRpb25FcnJvcltdID0gW107XG4gIGlmIChwYXJzZWRPdXRwdXRzLm1pc3NpbmdPdXRwdXRzLmxlbmd0aCA+IDApIHtcbiAgICBlcnJvcnMucHVzaChuZXcgRXJyb3JNaXNzaW5nT3V0cHV0cyhwYXJzZWRPdXRwdXRzLm1pc3NpbmdPdXRwdXRzKSk7XG4gIH1cbiAgaWYgKHBhcnNlZE91dHB1dHMuaW1wbGljaXRFeHRlcm5hbE91dHB1dHMubGVuZ3RoID4gMCkge1xuICAgIC8vIEZJWE1FOiBmb3IgcGF5Z28gd2UgbmVlZCB0byByZWxheCB0aGlzIGEgbGl0dGxlIGJpdFxuICAgIGVycm9ycy5wdXNoKG5ldyBFcnJvckltcGxpY2l0RXh0ZXJuYWxPdXRwdXRzKHBhcnNlZE91dHB1dHMuaW1wbGljaXRFeHRlcm5hbE91dHB1dHMpKTtcbiAgfVxuICBpZiAoZXJyb3JzLmxlbmd0aCA+IDApIHtcbiAgICAvLyBGSVhNRShCVEMtMTY4OCk6IGVuYWJsZSBFUzIwMjFcbiAgICAvLyB0aHJvdyBuZXcgQWdncmVnYXRlRXJyb3IoZXJyb3JzKTtcbiAgICB0aHJvdyBuZXcgQWdncmVnYXRlVmFsaWRhdGlvbkVycm9yKGVycm9ycyk7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFzc2VydFZhbGlkVHJhbnNhY3Rpb24oXG4gIHBzYnQ6IHV0eG9saWIuYml0Z28uVXR4b1BzYnQsXG4gIGRlc2NyaXB0b3JzOiBEZXNjcmlwdG9yTWFwLFxuICByZWNpcGllbnRzOiBJVHJhbnNhY3Rpb25SZWNpcGllbnRbXSxcbiAgbmV0d29yazogdXR4b2xpYi5OZXR3b3JrXG4pOiB2b2lkIHtcbiAgYXNzZXJ0RXhwZWN0ZWRPdXRwdXREaWZmZXJlbmNlKHRvQmFzZVBhcnNlZFRyYW5zYWN0aW9uT3V0cHV0c0Zyb21Qc2J0KHBzYnQsIGRlc2NyaXB0b3JzLCByZWNpcGllbnRzLCBuZXR3b3JrKSk7XG59XG5cbi8qKlxuICogV3JhcHBlciBhcm91bmQgYXNzZXJ0VmFsaWRUcmFuc2FjdGlvbiB0aGF0IHJldHVybnMgYSBib29sZWFuIGluc3RlYWQgb2YgdGhyb3dpbmcuXG4gKlxuICogV2UgZm9sbG93IHRoZSBBYnN0cmFjdFV0eG9Db2luIGludGVyZmFjZSBoZXJlIHdoaWNoIGlzIGEgYml0IGNvbmZ1c2VkIC0gdGhlIHJldHVybiB2YWx1ZSBpcyBhIGJvb2xlYW4gYnV0IHdlXG4gKiBhbHNvIHRocm93IGVycm9ycyAoYmVjYXVzZSB3ZSBhY3R1YWxseSB3YW50IHRvIGtub3cgd2hhdCB3ZW50IHdyb25nKS5cbiAqXG4gKiBAcGFyYW0gY29pblxuICogQHBhcmFtIHBhcmFtc1xuICogQHBhcmFtIGRlc2NyaXB0b3JNYXBcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHZlcmlmeVRyYW5zYWN0aW9uKFxuICBjb2luOiBBYnN0cmFjdFV0eG9Db2luLFxuICBwYXJhbXM6IFZlcmlmeVRyYW5zYWN0aW9uT3B0aW9ucyxcbiAgZGVzY3JpcHRvck1hcDogRGVzY3JpcHRvck1hcFxuKTogUHJvbWlzZTxib29sZWFuPiB7XG4gIGNvbnN0IHR4ID0gY29pbi5kZWNvZGVUcmFuc2FjdGlvbkZyb21QcmVidWlsZChwYXJhbXMudHhQcmVidWlsZCk7XG4gIGlmICghKHR4IGluc3RhbmNlb2YgdXR4b2xpYi5iaXRnby5VdHhvUHNidCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ3VuZXhwZWN0ZWQgdHJhbnNhY3Rpb24gdHlwZScpO1xuICB9XG4gIGFzc2VydFZhbGlkVHJhbnNhY3Rpb24odHgsIGRlc2NyaXB0b3JNYXAsIHBhcmFtcy50eFBhcmFtcy5yZWNpcGllbnRzID8/IFtdLCB0eC5uZXR3b3JrKTtcbiAgcmV0dXJuIHRydWU7XG59XG4iXX0=
108
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyaWZ5VHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHJhbnNhY3Rpb24vZGVzY3JpcHRvci92ZXJpZnlUcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFxQ0Esd0VBZ0JDO0FBRUQsd0RBT0M7QUFjRCw4Q0FrQkM7QUE5RkQsOERBQWdEO0FBQ2hELG1EQUFvRjtBQVVwRixtQ0FBaUU7QUFFakUsTUFBYSxlQUFnQixTQUFRLEtBQUs7SUFDeEMsWUFBWSxPQUFlO1FBQ3pCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqQixDQUFDO0NBQ0Y7QUFKRCwwQ0FJQztBQUVELE1BQWEsbUJBQW9CLFNBQVEsZUFBZTtJQUN0RCxZQUFtQixjQUE0QztRQUM3RCxLQUFLLENBQUMsMEJBQTBCLGNBQWMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1FBRHpDLG1CQUFjLEdBQWQsY0FBYyxDQUE4QjtJQUUvRCxDQUFDO0NBQ0Y7QUFKRCxrREFJQztBQUVELE1BQWEsNEJBQTZCLFNBQVEsZUFBZTtJQUMvRCxZQUFtQix1QkFBcUQ7UUFDdEUsS0FBSyxDQUFDLCtDQUErQyx1QkFBdUIsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1FBRHZFLDRCQUF1QixHQUF2Qix1QkFBdUIsQ0FBOEI7SUFFeEUsQ0FBQztDQUNGO0FBSkQsb0VBSUM7QUFFRCxNQUFhLHdCQUF5QixTQUFRLGVBQWU7SUFDM0QsWUFBbUIsTUFBeUI7UUFDMUMsS0FBSyxDQUFDLHFDQUFxQyxNQUFNLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztRQUQ1QyxXQUFNLEdBQU4sTUFBTSxDQUFtQjtJQUU1QyxDQUFDO0NBQ0Y7QUFKRCw0REFJQztBQUVELFNBQWdCLDhCQUE4QixDQUM1QyxhQUErRTtJQUUvRSxNQUFNLE1BQU0sR0FBc0IsRUFBRSxDQUFDO0lBQ3JDLElBQUksYUFBYSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDNUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLG1CQUFtQixDQUFDLGFBQWEsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDO0lBQ3JFLENBQUM7SUFDRCxJQUFJLGFBQWEsQ0FBQyx1QkFBdUIsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDckQsc0RBQXNEO1FBQ3RELE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSw0QkFBNEIsQ0FBQyxhQUFhLENBQUMsdUJBQXVCLENBQUMsQ0FBQyxDQUFDO0lBQ3ZGLENBQUM7SUFDRCxJQUFJLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDdEIsaUNBQWlDO1FBQ2pDLG9DQUFvQztRQUNwQyxNQUFNLElBQUksd0JBQXdCLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDN0MsQ0FBQztBQUNILENBQUM7QUFFRCxTQUFnQixzQkFBc0IsQ0FDcEMsSUFBNEIsRUFDNUIsV0FBMEIsRUFDMUIsVUFBbUMsRUFDbkMsT0FBd0I7SUFFeEIsOEJBQThCLENBQUMsSUFBQSw4Q0FBc0MsRUFBQyxJQUFJLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO0FBQ2pILENBQUM7QUFFRDs7Ozs7Ozs7Ozs7R0FXRztBQUNJLEtBQUssVUFBVSxpQkFBaUIsQ0FDckMsSUFBc0IsRUFDdEIsTUFBeUMsRUFDekMsYUFBNEI7SUFFNUIsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLDZCQUE2QixDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNqRSxJQUFJLENBQUMsQ0FBQyxFQUFFLFlBQVksT0FBTyxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1FBQzVDLE1BQU0sSUFBSSxnQ0FBcUIsQ0FDN0IsNkJBQTZCLEVBQzdCLE1BQU0sQ0FBQyxLQUFLLEVBQ1osQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLEVBQ2pCLE1BQU0sQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUN4QixDQUFDO0lBQ0osQ0FBQztJQUVELHNCQUFzQixDQUFDLEVBQUUsRUFBRSxhQUFhLEVBQUUsTUFBTSxDQUFDLFFBQVEsQ0FBQyxVQUFVLElBQUksRUFBRSxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUV4RixPQUFPLElBQUksQ0FBQztBQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyB1dHhvbGliIGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcbmltcG9ydCB7IElUcmFuc2FjdGlvblJlY2lwaWVudCwgVHhJbnRlbnRNaXNtYXRjaEVycm9yIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgRGVzY3JpcHRvck1hcCB9IGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tY29yZS9kZXNjcmlwdG9yJztcblxuaW1wb3J0IHtcbiAgQWJzdHJhY3RVdHhvQ29pbixcbiAgQmFzZU91dHB1dCxcbiAgQmFzZVBhcnNlZFRyYW5zYWN0aW9uT3V0cHV0cyxcbiAgVmVyaWZ5VHJhbnNhY3Rpb25PcHRpb25zLFxufSBmcm9tICcuLi8uLi9hYnN0cmFjdFV0eG9Db2luJztcblxuaW1wb3J0IHsgdG9CYXNlUGFyc2VkVHJhbnNhY3Rpb25PdXRwdXRzRnJvbVBzYnQgfSBmcm9tICcuL3BhcnNlJztcblxuZXhwb3J0IGNsYXNzIFZhbGlkYXRpb25FcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEVycm9yTWlzc2luZ091dHB1dHMgZXh0ZW5kcyBWYWxpZGF0aW9uRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihwdWJsaWMgbWlzc2luZ091dHB1dHM6IEJhc2VPdXRwdXQ8YmlnaW50IHwgJ21heCc+W10pIHtcbiAgICBzdXBlcihgbWlzc2luZyBvdXRwdXRzIChjb3VudD0ke21pc3NpbmdPdXRwdXRzLmxlbmd0aH0pYCk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEVycm9ySW1wbGljaXRFeHRlcm5hbE91dHB1dHMgZXh0ZW5kcyBWYWxpZGF0aW9uRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihwdWJsaWMgaW1wbGljaXRFeHRlcm5hbE91dHB1dHM6IEJhc2VPdXRwdXQ8YmlnaW50IHwgJ21heCc+W10pIHtcbiAgICBzdXBlcihgdW5leHBlY3RlZCBpbXBsaWNpdCBleHRlcm5hbCBvdXRwdXRzIChjb3VudD0ke2ltcGxpY2l0RXh0ZXJuYWxPdXRwdXRzLmxlbmd0aH0pYCk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEFnZ3JlZ2F0ZVZhbGlkYXRpb25FcnJvciBleHRlbmRzIFZhbGlkYXRpb25FcnJvciB7XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBlcnJvcnM6IFZhbGlkYXRpb25FcnJvcltdKSB7XG4gICAgc3VwZXIoYGFnZ3JlZ2F0ZSB2YWxpZGF0aW9uIGVycm9yIChjb3VudD0ke2Vycm9ycy5sZW5ndGh9KWApO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBhc3NlcnRFeHBlY3RlZE91dHB1dERpZmZlcmVuY2UoXG4gIHBhcnNlZE91dHB1dHM6IEJhc2VQYXJzZWRUcmFuc2FjdGlvbk91dHB1dHM8YmlnaW50LCBCYXNlT3V0cHV0PGJpZ2ludCB8ICdtYXgnPj5cbik6IHZvaWQge1xuICBjb25zdCBlcnJvcnM6IFZhbGlkYXRpb25FcnJvcltdID0gW107XG4gIGlmIChwYXJzZWRPdXRwdXRzLm1pc3NpbmdPdXRwdXRzLmxlbmd0aCA+IDApIHtcbiAgICBlcnJvcnMucHVzaChuZXcgRXJyb3JNaXNzaW5nT3V0cHV0cyhwYXJzZWRPdXRwdXRzLm1pc3NpbmdPdXRwdXRzKSk7XG4gIH1cbiAgaWYgKHBhcnNlZE91dHB1dHMuaW1wbGljaXRFeHRlcm5hbE91dHB1dHMubGVuZ3RoID4gMCkge1xuICAgIC8vIEZJWE1FOiBmb3IgcGF5Z28gd2UgbmVlZCB0byByZWxheCB0aGlzIGEgbGl0dGxlIGJpdFxuICAgIGVycm9ycy5wdXNoKG5ldyBFcnJvckltcGxpY2l0RXh0ZXJuYWxPdXRwdXRzKHBhcnNlZE91dHB1dHMuaW1wbGljaXRFeHRlcm5hbE91dHB1dHMpKTtcbiAgfVxuICBpZiAoZXJyb3JzLmxlbmd0aCA+IDApIHtcbiAgICAvLyBGSVhNRShCVEMtMTY4OCk6IGVuYWJsZSBFUzIwMjFcbiAgICAvLyB0aHJvdyBuZXcgQWdncmVnYXRlRXJyb3IoZXJyb3JzKTtcbiAgICB0aHJvdyBuZXcgQWdncmVnYXRlVmFsaWRhdGlvbkVycm9yKGVycm9ycyk7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFzc2VydFZhbGlkVHJhbnNhY3Rpb24oXG4gIHBzYnQ6IHV0eG9saWIuYml0Z28uVXR4b1BzYnQsXG4gIGRlc2NyaXB0b3JzOiBEZXNjcmlwdG9yTWFwLFxuICByZWNpcGllbnRzOiBJVHJhbnNhY3Rpb25SZWNpcGllbnRbXSxcbiAgbmV0d29yazogdXR4b2xpYi5OZXR3b3JrXG4pOiB2b2lkIHtcbiAgYXNzZXJ0RXhwZWN0ZWRPdXRwdXREaWZmZXJlbmNlKHRvQmFzZVBhcnNlZFRyYW5zYWN0aW9uT3V0cHV0c0Zyb21Qc2J0KHBzYnQsIGRlc2NyaXB0b3JzLCByZWNpcGllbnRzLCBuZXR3b3JrKSk7XG59XG5cbi8qKlxuICogV3JhcHBlciBhcm91bmQgYXNzZXJ0VmFsaWRUcmFuc2FjdGlvbiB0aGF0IHJldHVybnMgYSBib29sZWFuIGluc3RlYWQgb2YgdGhyb3dpbmcuXG4gKlxuICogV2UgZm9sbG93IHRoZSBBYnN0cmFjdFV0eG9Db2luIGludGVyZmFjZSBoZXJlIHdoaWNoIGlzIGEgYml0IGNvbmZ1c2VkIC0gdGhlIHJldHVybiB2YWx1ZSBpcyBhIGJvb2xlYW4gYnV0IHdlXG4gKiBhbHNvIHRocm93IGVycm9ycyAoYmVjYXVzZSB3ZSBhY3R1YWxseSB3YW50IHRvIGtub3cgd2hhdCB3ZW50IHdyb25nKS5cbiAqXG4gKiBAcGFyYW0gY29pblxuICogQHBhcmFtIHBhcmFtc1xuICogQHBhcmFtIGRlc2NyaXB0b3JNYXBcbiAqIEByZXR1cm5zIHtib29sZWFufSBUcnVlIGlmIHZlcmlmaWNhdGlvbiBwYXNzZXNcbiAqIEB0aHJvd3Mge1R4SW50ZW50TWlzbWF0Y2hFcnJvcn0gaWYgdHJhbnNhY3Rpb24gdmFsaWRhdGlvbiBmYWlsc1xuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gdmVyaWZ5VHJhbnNhY3Rpb248VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludD4oXG4gIGNvaW46IEFic3RyYWN0VXR4b0NvaW4sXG4gIHBhcmFtczogVmVyaWZ5VHJhbnNhY3Rpb25PcHRpb25zPFROdW1iZXI+LFxuICBkZXNjcmlwdG9yTWFwOiBEZXNjcmlwdG9yTWFwXG4pOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgY29uc3QgdHggPSBjb2luLmRlY29kZVRyYW5zYWN0aW9uRnJvbVByZWJ1aWxkKHBhcmFtcy50eFByZWJ1aWxkKTtcbiAgaWYgKCEodHggaW5zdGFuY2VvZiB1dHhvbGliLmJpdGdvLlV0eG9Qc2J0KSkge1xuICAgIHRocm93IG5ldyBUeEludGVudE1pc21hdGNoRXJyb3IoXG4gICAgICAndW5leHBlY3RlZCB0cmFuc2FjdGlvbiB0eXBlJyxcbiAgICAgIHBhcmFtcy5yZXFJZCxcbiAgICAgIFtwYXJhbXMudHhQYXJhbXNdLFxuICAgICAgcGFyYW1zLnR4UHJlYnVpbGQudHhIZXhcbiAgICApO1xuICB9XG5cbiAgYXNzZXJ0VmFsaWRUcmFuc2FjdGlvbih0eCwgZGVzY3JpcHRvck1hcCwgcGFyYW1zLnR4UGFyYW1zLnJlY2lwaWVudHMgPz8gW10sIHR4Lm5ldHdvcmspO1xuXG4gIHJldHVybiB0cnVlO1xufVxuIl19
@@ -1,4 +1,21 @@
1
1
  import { BitGoBase } from '@bitgo-beta/sdk-core';
2
2
  import { AbstractUtxoCoin, VerifyTransactionOptions } from '../../abstractUtxoCoin';
3
+ /**
4
+ * Verify that a transaction prebuild complies with the original intention for fixed-script wallets
5
+ *
6
+ * This implementation handles transaction verification for traditional UTXO coins using fixed scripts
7
+ * (non-descriptor wallets). It validates keychains, signatures, outputs, and amounts.
8
+ *
9
+ * @param coin - The UTXO coin instance
10
+ * @param bitgo - BitGo API instance for network calls
11
+ * @param params - Verification parameters
12
+ * @param params.txParams - Transaction parameters passed to send
13
+ * @param params.txPrebuild - Prebuild object returned by server
14
+ * @param params.wallet - Wallet object to obtain keys to verify against
15
+ * @param params.verification - Verification options (disableNetworking, keychains, addresses)
16
+ * @param params.reqId - Optional request ID for logging
17
+ * @returns {boolean} True if verification passes
18
+ * @throws {TxIntentMismatchError} if transaction validation fails
19
+ */
3
20
  export declare function verifyTransaction<TNumber extends bigint | number>(coin: AbstractUtxoCoin, bitgo: BitGoBase, params: VerifyTransactionOptions<TNumber>): Promise<boolean>;
4
21
  //# sourceMappingURL=verifyTransaction.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"verifyTransaction.d.ts","sourceRoot":"","sources":["../../../../src/transaction/fixedScript/verifyTransaction.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAGjD,OAAO,EAAE,gBAAgB,EAA6B,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AAqB/G,wBAAsB,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACrE,IAAI,EAAE,gBAAgB,EACtB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,wBAAwB,CAAC,OAAO,CAAC,GACxC,OAAO,CAAC,OAAO,CAAC,CA4IlB"}
1
+ {"version":3,"file":"verifyTransaction.d.ts","sourceRoot":"","sources":["../../../../src/transaction/fixedScript/verifyTransaction.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAyB,MAAM,sBAAsB,CAAC;AAGxE,OAAO,EAAE,gBAAgB,EAA6B,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AAqB/G;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAsB,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACrE,IAAI,EAAE,gBAAgB,EACtB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,wBAAwB,CAAC,OAAO,CAAC,GACxC,OAAO,CAAC,OAAO,CAAC,CAiJlB"}
@@ -40,6 +40,7 @@ exports.verifyTransaction = verifyTransaction;
40
40
  const debug_1 = __importDefault(require("debug"));
41
41
  const lodash_1 = __importDefault(require("lodash"));
42
42
  const bignumber_js_1 = __importDefault(require("bignumber.js"));
43
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
43
44
  const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
44
45
  const verifyKey_1 = require("../../verifyKey");
45
46
  const fetchInputs_1 = require("../fetchInputs");
@@ -58,10 +59,31 @@ function getPayGoLimit(allowPaygoOutput) {
58
59
  // 150 basis points is the absolute permitted maximum if paygo outputs are allowed
59
60
  return 0.015;
60
61
  }
62
+ /**
63
+ * Verify that a transaction prebuild complies with the original intention for fixed-script wallets
64
+ *
65
+ * This implementation handles transaction verification for traditional UTXO coins using fixed scripts
66
+ * (non-descriptor wallets). It validates keychains, signatures, outputs, and amounts.
67
+ *
68
+ * @param coin - The UTXO coin instance
69
+ * @param bitgo - BitGo API instance for network calls
70
+ * @param params - Verification parameters
71
+ * @param params.txParams - Transaction parameters passed to send
72
+ * @param params.txPrebuild - Prebuild object returned by server
73
+ * @param params.wallet - Wallet object to obtain keys to verify against
74
+ * @param params.verification - Verification options (disableNetworking, keychains, addresses)
75
+ * @param params.reqId - Optional request ID for logging
76
+ * @returns {boolean} True if verification passes
77
+ * @throws {TxIntentMismatchError} if transaction validation fails
78
+ */
61
79
  async function verifyTransaction(coin, bitgo, params) {
62
80
  const { txParams, txPrebuild, wallet, verification = {}, reqId } = params;
81
+ // Helper to throw TxIntentMismatchError with consistent context
82
+ const throwTxMismatch = (message) => {
83
+ throw new sdk_core_1.TxIntentMismatchError(message, reqId, [txParams], txPrebuild.txHex);
84
+ };
63
85
  if (!lodash_1.default.isUndefined(verification.disableNetworking) && !lodash_1.default.isBoolean(verification.disableNetworking)) {
64
- throw new Error('verification.disableNetworking must be a boolean');
86
+ throw new TypeError('verification.disableNetworking must be a boolean');
65
87
  }
66
88
  const isPsbt = txPrebuild.txHex && utxolib.bitgo.isPsbt(txPrebuild.txHex);
67
89
  if (isPsbt && txPrebuild.txInfo?.unspents) {
@@ -90,7 +112,7 @@ async function verifyTransaction(coin, bitgo, params) {
90
112
  if (!lodash_1.default.isEmpty(keySignatures)) {
91
113
  const verify = (key, pub) => {
92
114
  if (!keychains.user || !keychains.user.pub) {
93
- throw new Error('missing user keychain');
115
+ throwTxMismatch('missing user keychain');
94
116
  }
95
117
  return (0, verifyKey_1.verifyKeySignature)({
96
118
  userKeychain: keychains.user,
@@ -123,7 +145,7 @@ async function verifyTransaction(coin, bitgo, params) {
123
145
  const missingOutputs = parsedTransaction.missingOutputs;
124
146
  if (missingOutputs.length !== 0) {
125
147
  // there are some outputs in the recipients list that have not made it into the actual transaction
126
- throw new Error('expected outputs missing in transaction prebuild');
148
+ throwTxMismatch('expected outputs missing in transaction prebuild');
127
149
  }
128
150
  const intendedExternalSpend = parsedTransaction.explicitExternalSpendAmount;
129
151
  // this is a limit we impose for the total value that is amended to the transaction beyond what was originally intended
@@ -151,7 +173,7 @@ async function verifyTransaction(coin, bitgo, params) {
151
173
  else {
152
174
  // the additional external outputs can only be BitGo's pay-as-you-go fee, but we cannot verify the wallet address
153
175
  // there are some addresses that are outside the scope of intended recipients that are not change addresses
154
- throw new Error('prebuild attempts to spend to unintended external recipients');
176
+ throwTxMismatch('prebuild attempts to spend to unintended external recipients');
155
177
  }
156
178
  }
157
179
  const allOutputs = parsedTransaction.outputs;
@@ -173,4 +195,4 @@ async function verifyTransaction(coin, bitgo, params) {
173
195
  }
174
196
  return true;
175
197
  }
176
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"verifyTransaction.js","sourceRoot":"","sources":["../../../../src/transaction/fixedScript/verifyTransaction.ts"],"names":[],"mappings":"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","sourcesContent":["import buildDebug from 'debug';\nimport _ from 'lodash';\nimport BigNumber from 'bignumber.js';\nimport { BitGoBase } from '@bitgo-beta/sdk-core';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\n\nimport { AbstractUtxoCoin, Output, ParsedTransaction, VerifyTransactionOptions } from '../../abstractUtxoCoin';\nimport { verifyCustomChangeKeySignatures, verifyKeySignature, verifyUserPublicKey } from '../../verifyKey';\nimport { getPsbtTxInputs, getTxInputs } from '../fetchInputs';\n\nconst debug = buildDebug('bitgo:abstract-utxo:verifyTransaction');\n\n/**\n * Get the maximum percentage limit for pay-as-you-go outputs\n *\n * @protected\n */\nfunction getPayGoLimit(allowPaygoOutput?: boolean): number {\n  // allowing paygo outputs needs to be the default behavior, so only disallow paygo outputs if the\n  // relevant verification option is both set and false\n  if (!_.isNil(allowPaygoOutput) && !allowPaygoOutput) {\n    return 0;\n  }\n  // 150 basis points is the absolute permitted maximum if paygo outputs are allowed\n  return 0.015;\n}\n\nexport async function verifyTransaction<TNumber extends bigint | number>(\n  coin: AbstractUtxoCoin,\n  bitgo: BitGoBase,\n  params: VerifyTransactionOptions<TNumber>\n): Promise<boolean> {\n  const { txParams, txPrebuild, wallet, verification = {}, reqId } = params;\n\n  if (!_.isUndefined(verification.disableNetworking) && !_.isBoolean(verification.disableNetworking)) {\n    throw new Error('verification.disableNetworking must be a boolean');\n  }\n  const isPsbt = txPrebuild.txHex && utxolib.bitgo.isPsbt(txPrebuild.txHex);\n  if (isPsbt && txPrebuild.txInfo?.unspents) {\n    throw new Error('should not have unspents in txInfo for psbt');\n  }\n  const disableNetworking = !!verification.disableNetworking;\n  const parsedTransaction: ParsedTransaction<TNumber> = await coin.parseTransaction<TNumber>({\n    txParams,\n    txPrebuild,\n    wallet,\n    verification,\n    reqId,\n  });\n\n  const keychains = parsedTransaction.keychains;\n\n  // verify that the claimed user public key corresponds to the wallet's user private key\n  let userPublicKeyVerified = false;\n  try {\n    // verify the user public key matches the private key - this will throw if there is no match\n    userPublicKeyVerified = verifyUserPublicKey(bitgo, { userKeychain: keychains.user, disableNetworking, txParams });\n  } catch (e) {\n    debug('failed to verify user public key!', e);\n  }\n\n  // let's verify these keychains\n  const keySignatures = parsedTransaction.keySignatures;\n  if (!_.isEmpty(keySignatures)) {\n    const verify = (key, pub) => {\n      if (!keychains.user || !keychains.user.pub) {\n        throw new Error('missing user keychain');\n      }\n      return verifyKeySignature({\n        userKeychain: keychains.user as { pub: string },\n        keychainToVerify: key,\n        keySignature: pub,\n      });\n    };\n    const isBackupKeySignatureValid = verify(keychains.backup, keySignatures.backupPub);\n    const isBitgoKeySignatureValid = verify(keychains.bitgo, keySignatures.bitgoPub);\n    if (!isBackupKeySignatureValid || !isBitgoKeySignatureValid) {\n      throw new Error('secondary public key signatures invalid');\n    }\n    debug('successfully verified backup and bitgo key signatures');\n  } else if (!disableNetworking) {\n    // these keys were obtained online and their signatures were not verified\n    // this could be dangerous\n    console.log('unsigned keys obtained online are being used for address verification');\n  }\n\n  if (parsedTransaction.needsCustomChangeKeySignatureVerification) {\n    if (!keychains.user || !userPublicKeyVerified) {\n      throw new Error('transaction requires verification of user public key, but it was unable to be verified');\n    }\n    const customChangeKeySignaturesVerified = verifyCustomChangeKeySignatures(parsedTransaction, keychains.user);\n    if (!customChangeKeySignaturesVerified) {\n      throw new Error(\n        'transaction requires verification of custom change key signatures, but they were unable to be verified'\n      );\n    }\n    debug('successfully verified user public key and custom change key signatures');\n  }\n\n  const missingOutputs = parsedTransaction.missingOutputs;\n  if (missingOutputs.length !== 0) {\n    // there are some outputs in the recipients list that have not made it into the actual transaction\n    throw new Error('expected outputs missing in transaction prebuild');\n  }\n\n  const intendedExternalSpend = parsedTransaction.explicitExternalSpendAmount;\n\n  // this is a limit we impose for the total value that is amended to the transaction beyond what was originally intended\n  const payAsYouGoLimit = new BigNumber(getPayGoLimit(verification.allowPaygoOutput)).multipliedBy(\n    intendedExternalSpend.toString()\n  );\n\n  /*\n  Some explanation for why we're doing what we're doing:\n  Some customers will have an output to BitGo's PAYGo wallet added to their transaction, and we need to account for\n  it here. To protect someone tampering with the output to make it send more than it should to BitGo, we define a\n  threshold for the output's value above which we'll throw an error, because the paygo output should never be that\n  high.\n   */\n\n  // make sure that all the extra addresses are change addresses\n  // get all the additional external outputs the server added and calculate their values\n  const nonChangeAmount = new BigNumber(parsedTransaction.implicitExternalSpendAmount.toString());\n\n  debug(\n    'Intended spend is %s, Non-change amount is %s, paygo limit is %s',\n    intendedExternalSpend.toString(),\n    nonChangeAmount.toString(),\n    payAsYouGoLimit.toString()\n  );\n\n  // There are two instances where we will get into this point here\n  if (nonChangeAmount.gt(payAsYouGoLimit)) {\n    if (isPsbt && parsedTransaction.customChange) {\n      // In the case that we have a custom change address on a wallet and we are building the transaction\n      // with a PSBT, we do not have the metadata to verify the address from the custom change wallet, nor\n      // can we fetch that information from the other wallet because we may not have the credentials. Therefore,\n      // we will not throw an error here, but we will log a warning.\n      debug(`cannot verify some of the addresses because it belongs to a separate wallet`);\n    } else {\n      // the additional external outputs can only be BitGo's pay-as-you-go fee, but we cannot verify the wallet address\n      // there are some addresses that are outside the scope of intended recipients that are not change addresses\n      throw new Error('prebuild attempts to spend to unintended external recipients');\n    }\n  }\n\n  const allOutputs = parsedTransaction.outputs;\n  if (!txPrebuild.txHex) {\n    throw new Error(`txPrebuild.txHex not set`);\n  }\n  const inputs = isPsbt\n    ? getPsbtTxInputs(txPrebuild.txHex, coin.network).map((v) => ({\n        ...v,\n        value: utxolib.bitgo.toTNumber(v.value, coin.amountType),\n      }))\n    : await getTxInputs({ txPrebuild, bitgo, coin, disableNetworking, reqId });\n  // coins (doge) that can exceed number limits (and thus will use bigint) will have the `valueString` field\n  const inputAmount = inputs.reduce(\n    (sum: bigint, i) => sum + BigInt(coin.amountType === 'bigint' ? i.valueString : i.value),\n    BigInt(0)\n  );\n  const outputAmount = allOutputs.reduce((sum: bigint, o: Output) => sum + BigInt(o.amount), BigInt(0));\n  const fee = inputAmount - outputAmount;\n\n  if (fee < 0) {\n    throw new Error(\n      `attempting to spend ${outputAmount} satoshis, which exceeds the input amount (${inputAmount} satoshis) by ${-fee}`\n    );\n  }\n\n  return true;\n}\n"]}
198
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"verifyTransaction.js","sourceRoot":"","sources":["../../../../src/transaction/fixedScript/verifyTransaction.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4CA,8CAqJC;AAjMD,kDAA+B;AAC/B,oDAAuB;AACvB,gEAAqC;AACrC,mDAAwE;AACxE,8DAAgD;AAGhD,+CAA2G;AAC3G,gDAA8D;AAE9D,MAAM,KAAK,GAAG,IAAA,eAAU,EAAC,uCAAuC,CAAC,CAAC;AAElE;;;;GAIG;AACH,SAAS,aAAa,CAAC,gBAA0B;IAC/C,iGAAiG;IACjG,qDAAqD;IACrD,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACpD,OAAO,CAAC,CAAC;IACX,CAAC;IACD,kFAAkF;IAClF,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACI,KAAK,UAAU,iBAAiB,CACrC,IAAsB,EACtB,KAAgB,EAChB,MAAyC;IAEzC,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,EAAE,YAAY,GAAG,EAAE,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC;IAE1E,gEAAgE;IAChE,MAAM,eAAe,GAAG,CAAC,OAAe,EAAS,EAAE;QACjD,MAAM,IAAI,gCAAqB,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC,QAAQ,CAAC,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;IAChF,CAAC,CAAC;IAEF,IAAI,CAAC,gBAAC,CAAC,WAAW,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,gBAAC,CAAC,SAAS,CAAC,YAAY,CAAC,iBAAiB,CAAC,EAAE,CAAC;QACnG,MAAM,IAAI,SAAS,CAAC,kDAAkD,CAAC,CAAC;IAC1E,CAAC;IACD,MAAM,MAAM,GAAG,UAAU,CAAC,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IAC1E,IAAI,MAAM,IAAI,UAAU,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC;QAC1C,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;IACjE,CAAC;IACD,MAAM,iBAAiB,GAAG,CAAC,CAAC,YAAY,CAAC,iBAAiB,CAAC;IAC3D,MAAM,iBAAiB,GAA+B,MAAM,IAAI,CAAC,gBAAgB,CAAU;QACzF,QAAQ;QACR,UAAU;QACV,MAAM;QACN,YAAY;QACZ,KAAK;KACN,CAAC,CAAC;IAEH,MAAM,SAAS,GAAG,iBAAiB,CAAC,SAAS,CAAC;IAE9C,uFAAuF;IACvF,IAAI,qBAAqB,GAAG,KAAK,CAAC;IAClC,IAAI,CAAC;QACH,4FAA4F;QAC5F,qBAAqB,GAAG,IAAA,+BAAmB,EAAC,KAAK,EAAE,EAAE,YAAY,EAAE,SAAS,CAAC,IAAI,EAAE,iBAAiB,EAAE,QAAQ,EAAE,CAAC,CAAC;IACpH,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,KAAK,CAAC,mCAAmC,EAAE,CAAC,CAAC,CAAC;IAChD,CAAC;IAED,+BAA+B;IAC/B,MAAM,aAAa,GAAG,iBAAiB,CAAC,aAAa,CAAC;IACtD,IAAI,CAAC,gBAAC,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE,CAAC;QAC9B,MAAM,MAAM,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YAC1B,IAAI,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;gBAC3C,eAAe,CAAC,uBAAuB,CAAC,CAAC;YAC3C,CAAC;YACD,OAAO,IAAA,8BAAkB,EAAC;gBACxB,YAAY,EAAE,SAAS,CAAC,IAAuB;gBAC/C,gBAAgB,EAAE,GAAG;gBACrB,YAAY,EAAE,GAAG;aAClB,CAAC,CAAC;QACL,CAAC,CAAC;QACF,MAAM,yBAAyB,GAAG,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,aAAa,CAAC,SAAS,CAAC,CAAC;QACpF,MAAM,wBAAwB,GAAG,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,aAAa,CAAC,QAAQ,CAAC,CAAC;QACjF,IAAI,CAAC,yBAAyB,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAC5D,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;QAC7D,CAAC;QACD,KAAK,CAAC,uDAAuD,CAAC,CAAC;IACjE,CAAC;SAAM,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC9B,yEAAyE;QACzE,0BAA0B;QAC1B,OAAO,CAAC,GAAG,CAAC,uEAAuE,CAAC,CAAC;IACvF,CAAC;IAED,IAAI,iBAAiB,CAAC,yCAAyC,EAAE,CAAC;QAChE,IAAI,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC9C,MAAM,IAAI,KAAK,CAAC,wFAAwF,CAAC,CAAC;QAC5G,CAAC;QACD,MAAM,iCAAiC,GAAG,IAAA,2CAA+B,EAAC,iBAAiB,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;QAC7G,IAAI,CAAC,iCAAiC,EAAE,CAAC;YACvC,MAAM,IAAI,KAAK,CACb,wGAAwG,CACzG,CAAC;QACJ,CAAC;QACD,KAAK,CAAC,wEAAwE,CAAC,CAAC;IAClF,CAAC;IAED,MAAM,cAAc,GAAG,iBAAiB,CAAC,cAAc,CAAC;IACxD,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAChC,kGAAkG;QAClG,eAAe,CAAC,kDAAkD,CAAC,CAAC;IACtE,CAAC;IAED,MAAM,qBAAqB,GAAG,iBAAiB,CAAC,2BAA2B,CAAC;IAE5E,uHAAuH;IACvH,MAAM,eAAe,GAAG,IAAI,sBAAS,CAAC,aAAa,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC,CAAC,YAAY,CAC9F,qBAAqB,CAAC,QAAQ,EAAE,CACjC,CAAC;IAEF;;;;;;OAMG;IAEH,8DAA8D;IAC9D,sFAAsF;IACtF,MAAM,eAAe,GAAG,IAAI,sBAAS,CAAC,iBAAiB,CAAC,2BAA2B,CAAC,QAAQ,EAAE,CAAC,CAAC;IAEhG,KAAK,CACH,kEAAkE,EAClE,qBAAqB,CAAC,QAAQ,EAAE,EAChC,eAAe,CAAC,QAAQ,EAAE,EAC1B,eAAe,CAAC,QAAQ,EAAE,CAC3B,CAAC;IAEF,iEAAiE;IACjE,IAAI,eAAe,CAAC,EAAE,CAAC,eAAe,CAAC,EAAE,CAAC;QACxC,IAAI,MAAM,IAAI,iBAAiB,CAAC,YAAY,EAAE,CAAC;YAC7C,mGAAmG;YACnG,oGAAoG;YACpG,0GAA0G;YAC1G,8DAA8D;YAC9D,KAAK,CAAC,6EAA6E,CAAC,CAAC;QACvF,CAAC;aAAM,CAAC;YACN,iHAAiH;YACjH,2GAA2G;YAC3G,eAAe,CAAC,8DAA8D,CAAC,CAAC;QAClF,CAAC;IACH,CAAC;IAED,MAAM,UAAU,GAAG,iBAAiB,CAAC,OAAO,CAAC;IAC7C,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;QACtB,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;IAC9C,CAAC;IACD,MAAM,MAAM,GAAG,MAAM;QACnB,CAAC,CAAC,IAAA,6BAAe,EAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAC1D,GAAG,CAAC;YACJ,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC;SACzD,CAAC,CAAC;QACL,CAAC,CAAC,MAAM,IAAA,yBAAW,EAAC,EAAE,UAAU,EAAE,KAAK,EAAE,IAAI,EAAE,iBAAiB,EAAE,KAAK,EAAE,CAAC,CAAC;IAC7E,0GAA0G;IAC1G,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,CAC/B,CAAC,GAAW,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,EACxF,MAAM,CAAC,CAAC,CAAC,CACV,CAAC;IACF,MAAM,YAAY,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,GAAW,EAAE,CAAS,EAAE,EAAE,CAAC,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IACtG,MAAM,GAAG,GAAG,WAAW,GAAG,YAAY,CAAC;IAEvC,IAAI,GAAG,GAAG,CAAC,EAAE,CAAC;QACZ,MAAM,IAAI,KAAK,CACb,uBAAuB,YAAY,8CAA8C,WAAW,iBAAiB,CAAC,GAAG,EAAE,CACpH,CAAC;IACJ,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC","sourcesContent":["import buildDebug from 'debug';\nimport _ from 'lodash';\nimport BigNumber from 'bignumber.js';\nimport { BitGoBase, TxIntentMismatchError } from '@bitgo-beta/sdk-core';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\n\nimport { AbstractUtxoCoin, Output, ParsedTransaction, VerifyTransactionOptions } from '../../abstractUtxoCoin';\nimport { verifyCustomChangeKeySignatures, verifyKeySignature, verifyUserPublicKey } from '../../verifyKey';\nimport { getPsbtTxInputs, getTxInputs } from '../fetchInputs';\n\nconst debug = buildDebug('bitgo:abstract-utxo:verifyTransaction');\n\n/**\n * Get the maximum percentage limit for pay-as-you-go outputs\n *\n * @protected\n */\nfunction getPayGoLimit(allowPaygoOutput?: boolean): number {\n  // allowing paygo outputs needs to be the default behavior, so only disallow paygo outputs if the\n  // relevant verification option is both set and false\n  if (!_.isNil(allowPaygoOutput) && !allowPaygoOutput) {\n    return 0;\n  }\n  // 150 basis points is the absolute permitted maximum if paygo outputs are allowed\n  return 0.015;\n}\n\n/**\n * Verify that a transaction prebuild complies with the original intention for fixed-script wallets\n *\n * This implementation handles transaction verification for traditional UTXO coins using fixed scripts\n * (non-descriptor wallets). It validates keychains, signatures, outputs, and amounts.\n *\n * @param coin - The UTXO coin instance\n * @param bitgo - BitGo API instance for network calls\n * @param params - Verification parameters\n * @param params.txParams - Transaction parameters passed to send\n * @param params.txPrebuild - Prebuild object returned by server\n * @param params.wallet - Wallet object to obtain keys to verify against\n * @param params.verification - Verification options (disableNetworking, keychains, addresses)\n * @param params.reqId - Optional request ID for logging\n * @returns {boolean} True if verification passes\n * @throws {TxIntentMismatchError} if transaction validation fails\n */\nexport async function verifyTransaction<TNumber extends bigint | number>(\n  coin: AbstractUtxoCoin,\n  bitgo: BitGoBase,\n  params: VerifyTransactionOptions<TNumber>\n): Promise<boolean> {\n  const { txParams, txPrebuild, wallet, verification = {}, reqId } = params;\n\n  // Helper to throw TxIntentMismatchError with consistent context\n  const throwTxMismatch = (message: string): never => {\n    throw new TxIntentMismatchError(message, reqId, [txParams], txPrebuild.txHex);\n  };\n\n  if (!_.isUndefined(verification.disableNetworking) && !_.isBoolean(verification.disableNetworking)) {\n    throw new TypeError('verification.disableNetworking must be a boolean');\n  }\n  const isPsbt = txPrebuild.txHex && utxolib.bitgo.isPsbt(txPrebuild.txHex);\n  if (isPsbt && txPrebuild.txInfo?.unspents) {\n    throw new Error('should not have unspents in txInfo for psbt');\n  }\n  const disableNetworking = !!verification.disableNetworking;\n  const parsedTransaction: ParsedTransaction<TNumber> = await coin.parseTransaction<TNumber>({\n    txParams,\n    txPrebuild,\n    wallet,\n    verification,\n    reqId,\n  });\n\n  const keychains = parsedTransaction.keychains;\n\n  // verify that the claimed user public key corresponds to the wallet's user private key\n  let userPublicKeyVerified = false;\n  try {\n    // verify the user public key matches the private key - this will throw if there is no match\n    userPublicKeyVerified = verifyUserPublicKey(bitgo, { userKeychain: keychains.user, disableNetworking, txParams });\n  } catch (e) {\n    debug('failed to verify user public key!', e);\n  }\n\n  // let's verify these keychains\n  const keySignatures = parsedTransaction.keySignatures;\n  if (!_.isEmpty(keySignatures)) {\n    const verify = (key, pub) => {\n      if (!keychains.user || !keychains.user.pub) {\n        throwTxMismatch('missing user keychain');\n      }\n      return verifyKeySignature({\n        userKeychain: keychains.user as { pub: string },\n        keychainToVerify: key,\n        keySignature: pub,\n      });\n    };\n    const isBackupKeySignatureValid = verify(keychains.backup, keySignatures.backupPub);\n    const isBitgoKeySignatureValid = verify(keychains.bitgo, keySignatures.bitgoPub);\n    if (!isBackupKeySignatureValid || !isBitgoKeySignatureValid) {\n      throw new Error('secondary public key signatures invalid');\n    }\n    debug('successfully verified backup and bitgo key signatures');\n  } else if (!disableNetworking) {\n    // these keys were obtained online and their signatures were not verified\n    // this could be dangerous\n    console.log('unsigned keys obtained online are being used for address verification');\n  }\n\n  if (parsedTransaction.needsCustomChangeKeySignatureVerification) {\n    if (!keychains.user || !userPublicKeyVerified) {\n      throw new Error('transaction requires verification of user public key, but it was unable to be verified');\n    }\n    const customChangeKeySignaturesVerified = verifyCustomChangeKeySignatures(parsedTransaction, keychains.user);\n    if (!customChangeKeySignaturesVerified) {\n      throw new Error(\n        'transaction requires verification of custom change key signatures, but they were unable to be verified'\n      );\n    }\n    debug('successfully verified user public key and custom change key signatures');\n  }\n\n  const missingOutputs = parsedTransaction.missingOutputs;\n  if (missingOutputs.length !== 0) {\n    // there are some outputs in the recipients list that have not made it into the actual transaction\n    throwTxMismatch('expected outputs missing in transaction prebuild');\n  }\n\n  const intendedExternalSpend = parsedTransaction.explicitExternalSpendAmount;\n\n  // this is a limit we impose for the total value that is amended to the transaction beyond what was originally intended\n  const payAsYouGoLimit = new BigNumber(getPayGoLimit(verification.allowPaygoOutput)).multipliedBy(\n    intendedExternalSpend.toString()\n  );\n\n  /*\n  Some explanation for why we're doing what we're doing:\n  Some customers will have an output to BitGo's PAYGo wallet added to their transaction, and we need to account for\n  it here. To protect someone tampering with the output to make it send more than it should to BitGo, we define a\n  threshold for the output's value above which we'll throw an error, because the paygo output should never be that\n  high.\n   */\n\n  // make sure that all the extra addresses are change addresses\n  // get all the additional external outputs the server added and calculate their values\n  const nonChangeAmount = new BigNumber(parsedTransaction.implicitExternalSpendAmount.toString());\n\n  debug(\n    'Intended spend is %s, Non-change amount is %s, paygo limit is %s',\n    intendedExternalSpend.toString(),\n    nonChangeAmount.toString(),\n    payAsYouGoLimit.toString()\n  );\n\n  // There are two instances where we will get into this point here\n  if (nonChangeAmount.gt(payAsYouGoLimit)) {\n    if (isPsbt && parsedTransaction.customChange) {\n      // In the case that we have a custom change address on a wallet and we are building the transaction\n      // with a PSBT, we do not have the metadata to verify the address from the custom change wallet, nor\n      // can we fetch that information from the other wallet because we may not have the credentials. Therefore,\n      // we will not throw an error here, but we will log a warning.\n      debug(`cannot verify some of the addresses because it belongs to a separate wallet`);\n    } else {\n      // the additional external outputs can only be BitGo's pay-as-you-go fee, but we cannot verify the wallet address\n      // there are some addresses that are outside the scope of intended recipients that are not change addresses\n      throwTxMismatch('prebuild attempts to spend to unintended external recipients');\n    }\n  }\n\n  const allOutputs = parsedTransaction.outputs;\n  if (!txPrebuild.txHex) {\n    throw new Error(`txPrebuild.txHex not set`);\n  }\n  const inputs = isPsbt\n    ? getPsbtTxInputs(txPrebuild.txHex, coin.network).map((v) => ({\n        ...v,\n        value: utxolib.bitgo.toTNumber(v.value, coin.amountType),\n      }))\n    : await getTxInputs({ txPrebuild, bitgo, coin, disableNetworking, reqId });\n  // coins (doge) that can exceed number limits (and thus will use bigint) will have the `valueString` field\n  const inputAmount = inputs.reduce(\n    (sum: bigint, i) => sum + BigInt(coin.amountType === 'bigint' ? i.valueString : i.value),\n    BigInt(0)\n  );\n  const outputAmount = allOutputs.reduce((sum: bigint, o: Output) => sum + BigInt(o.amount), BigInt(0));\n  const fee = inputAmount - outputAmount;\n\n  if (fee < 0) {\n    throw new Error(\n      `attempting to spend ${outputAmount} satoshis, which exceeds the input amount (${inputAmount} satoshis) by ${-fee}`\n    );\n  }\n\n  return true;\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bitgo-beta/abstract-utxo",
3
- "version": "1.6.1-alpha.413",
3
+ "version": "1.6.1-alpha.414",
4
4
  "description": "BitGo SDK coin library for UTXO base implementation",
5
5
  "main": "./dist/src/index.js",
6
6
  "types": "./dist/src/index.d.ts",
@@ -15,7 +15,8 @@
15
15
  "lint": "eslint --quiet .",
16
16
  "prepare": "npm run build",
17
17
  "test": "npm run unit-test",
18
- "unit-test": "mocha --recursive test/"
18
+ "unit-test": "mocha --recursive test/unit/",
19
+ "integration-test": "mocha --recursive test/integration/"
19
20
  },
20
21
  "author": "BitGo SDK Team <sdkteam@bitgo.com>",
21
22
  "license": "MIT",
@@ -42,13 +43,14 @@
42
43
  ]
43
44
  },
44
45
  "dependencies": {
45
- "@bitgo-beta/blockapis": "1.3.3-alpha.414",
46
- "@bitgo-beta/sdk-api": "1.6.1-alpha.413",
47
- "@bitgo-beta/sdk-core": "2.4.1-alpha.413",
48
- "@bitgo-beta/secp256k1": "1.0.1-alpha.371",
49
- "@bitgo-beta/unspents": "0.11.3-alpha.414",
50
- "@bitgo-beta/utxo-core": "1.0.1-alpha.144",
51
- "@bitgo-beta/utxo-lib": "4.0.1-alpha.414",
46
+ "@bitgo-beta/blockapis": "1.3.3-alpha.415",
47
+ "@bitgo-beta/sdk-api": "1.6.1-alpha.414",
48
+ "@bitgo-beta/sdk-core": "2.4.1-alpha.414",
49
+ "@bitgo-beta/secp256k1": "1.0.1-alpha.372",
50
+ "@bitgo-beta/unspents": "0.11.3-alpha.415",
51
+ "@bitgo-beta/utxo-core": "1.0.1-alpha.145",
52
+ "@bitgo-beta/utxo-lib": "4.0.1-alpha.415",
53
+ "@bitgo-beta/utxo-ord": "1.1.3-alpha.369",
52
54
  "@bitgo/wasm-miniscript": "2.0.0-beta.7",
53
55
  "@types/lodash": "^4.14.121",
54
56
  "@types/superagent": "4.1.15",
@@ -59,5 +61,9 @@
59
61
  "lodash": "^4.17.14",
60
62
  "superagent": "^9.0.1"
61
63
  },
62
- "gitHead": "930ca59f94921ae2bbda9e74b7f983609b2b59b1"
64
+ "devDependencies": {
65
+ "@bitgo-beta/sdk-test": "^9.1.8",
66
+ "mocha": "^10.2.0"
67
+ },
68
+ "gitHead": "b3bfeff4b8b9be8ffd6538204026bf8dd13e9e67"
63
69
  }