@bitgo-beta/sdk-coin-flrp 1.0.1-beta.67 → 1.0.1-beta.69

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 (113) hide show
  1. package/dist/tsconfig.tsbuildinfo +1 -1
  2. package/package.json +6 -6
  3. package/dist/src/flrp.d.ts +0 -91
  4. package/dist/src/flrp.d.ts.map +0 -1
  5. package/dist/src/flrp.js +0 -343
  6. package/dist/src/iface.d.ts +0 -25
  7. package/dist/src/iface.d.ts.map +0 -1
  8. package/dist/src/iface.js +0 -3
  9. package/dist/src/index.d.ts +0 -6
  10. package/dist/src/index.d.ts.map +0 -1
  11. package/dist/src/index.js +0 -45
  12. package/dist/src/lib/atomicInCTransactionBuilder.d.ts +0 -26
  13. package/dist/src/lib/atomicInCTransactionBuilder.d.ts.map +0 -1
  14. package/dist/src/lib/atomicInCTransactionBuilder.js +0 -64
  15. package/dist/src/lib/atomicTransactionBuilder.d.ts +0 -96
  16. package/dist/src/lib/atomicTransactionBuilder.d.ts.map +0 -1
  17. package/dist/src/lib/atomicTransactionBuilder.js +0 -318
  18. package/dist/src/lib/constants.d.ts +0 -170
  19. package/dist/src/lib/constants.d.ts.map +0 -1
  20. package/dist/src/lib/constants.js +0 -227
  21. package/dist/src/lib/delegatorTxBuilder.d.ts +0 -58
  22. package/dist/src/lib/delegatorTxBuilder.d.ts.map +0 -1
  23. package/dist/src/lib/delegatorTxBuilder.js +0 -224
  24. package/dist/src/lib/errors.d.ts +0 -8
  25. package/dist/src/lib/errors.d.ts.map +0 -1
  26. package/dist/src/lib/errors.js +0 -19
  27. package/dist/src/lib/exportInCTxBuilder.d.ts +0 -77
  28. package/dist/src/lib/exportInCTxBuilder.d.ts.map +0 -1
  29. package/dist/src/lib/exportInCTxBuilder.js +0 -199
  30. package/dist/src/lib/exportInPTxBuilder.d.ts +0 -30
  31. package/dist/src/lib/exportInPTxBuilder.d.ts.map +0 -1
  32. package/dist/src/lib/exportInPTxBuilder.js +0 -120
  33. package/dist/src/lib/iface.d.ts +0 -119
  34. package/dist/src/lib/iface.d.ts.map +0 -1
  35. package/dist/src/lib/iface.js +0 -22
  36. package/dist/src/lib/importInCTxBuilder.d.ts +0 -67
  37. package/dist/src/lib/importInCTxBuilder.d.ts.map +0 -1
  38. package/dist/src/lib/importInCTxBuilder.js +0 -403
  39. package/dist/src/lib/importInPTxBuilder.d.ts +0 -73
  40. package/dist/src/lib/importInPTxBuilder.d.ts.map +0 -1
  41. package/dist/src/lib/importInPTxBuilder.js +0 -464
  42. package/dist/src/lib/index.d.ts +0 -12
  43. package/dist/src/lib/index.d.ts.map +0 -1
  44. package/dist/src/lib/index.js +0 -39
  45. package/dist/src/lib/keyPair.d.ts +0 -58
  46. package/dist/src/lib/keyPair.d.ts.map +0 -1
  47. package/dist/src/lib/keyPair.js +0 -142
  48. package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts +0 -81
  49. package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts.map +0 -1
  50. package/dist/src/lib/permissionlessValidatorTxBuilder.js +0 -248
  51. package/dist/src/lib/transaction.d.ts +0 -111
  52. package/dist/src/lib/transaction.d.ts.map +0 -1
  53. package/dist/src/lib/transaction.js +0 -322
  54. package/dist/src/lib/transactionBuilder.d.ts +0 -85
  55. package/dist/src/lib/transactionBuilder.d.ts.map +0 -1
  56. package/dist/src/lib/transactionBuilder.js +0 -167
  57. package/dist/src/lib/transactionBuilderFactory.d.ts +0 -37
  58. package/dist/src/lib/transactionBuilderFactory.d.ts.map +0 -1
  59. package/dist/src/lib/transactionBuilderFactory.js +0 -91
  60. package/dist/src/lib/types.d.ts +0 -78
  61. package/dist/src/lib/types.d.ts.map +0 -1
  62. package/dist/src/lib/types.js +0 -5
  63. package/dist/src/lib/utils.d.ts +0 -217
  64. package/dist/src/lib/utils.d.ts.map +0 -1
  65. package/dist/src/lib/utils.js +0 -498
  66. package/dist/src/lib/validatorTxBuilder.d.ts +0 -40
  67. package/dist/src/lib/validatorTxBuilder.d.ts.map +0 -1
  68. package/dist/src/lib/validatorTxBuilder.js +0 -180
  69. package/dist/src/register.d.ts +0 -3
  70. package/dist/src/register.d.ts.map +0 -1
  71. package/dist/src/register.js +0 -11
  72. package/dist/src/tflrp.d.ts +0 -8
  73. package/dist/src/tflrp.d.ts.map +0 -1
  74. package/dist/src/tflrp.js +0 -14
  75. package/dist/test/unit/delegatorTxBuilder.test.d.ts +0 -2
  76. package/dist/test/unit/delegatorTxBuilder.test.d.ts.map +0 -1
  77. package/dist/test/unit/delegatorTxBuilder.test.js +0 -233
  78. package/dist/test/unit/flrp.d.ts +0 -2
  79. package/dist/test/unit/flrp.d.ts.map +0 -1
  80. package/dist/test/unit/flrp.js +0 -118
  81. package/dist/test/unit/lib/atomicTransactionBuilder.d.ts +0 -2
  82. package/dist/test/unit/lib/atomicTransactionBuilder.d.ts.map +0 -1
  83. package/dist/test/unit/lib/atomicTransactionBuilder.js +0 -222
  84. package/dist/test/unit/lib/exportInCTxBuilder.d.ts +0 -2
  85. package/dist/test/unit/lib/exportInCTxBuilder.d.ts.map +0 -1
  86. package/dist/test/unit/lib/exportInCTxBuilder.js +0 -584
  87. package/dist/test/unit/lib/exportInPTxBuilder.d.ts +0 -2
  88. package/dist/test/unit/lib/exportInPTxBuilder.d.ts.map +0 -1
  89. package/dist/test/unit/lib/exportInPTxBuilder.js +0 -377
  90. package/dist/test/unit/lib/importInCTxBuilder.d.ts +0 -2
  91. package/dist/test/unit/lib/importInCTxBuilder.d.ts.map +0 -1
  92. package/dist/test/unit/lib/importInCTxBuilder.js +0 -257
  93. package/dist/test/unit/lib/importInPTxBuilder.d.ts +0 -2
  94. package/dist/test/unit/lib/importInPTxBuilder.d.ts.map +0 -1
  95. package/dist/test/unit/lib/importInPTxBuilder.js +0 -500
  96. package/dist/test/unit/lib/transaction.d.ts +0 -2
  97. package/dist/test/unit/lib/transaction.d.ts.map +0 -1
  98. package/dist/test/unit/lib/transaction.js +0 -460
  99. package/dist/test/unit/lib/utils.d.ts +0 -2
  100. package/dist/test/unit/lib/utils.d.ts.map +0 -1
  101. package/dist/test/unit/lib/utils.js +0 -286
  102. package/dist/test/unit/permissionlessValidatorTxBuilder.test.d.ts +0 -2
  103. package/dist/test/unit/permissionlessValidatorTxBuilder.test.d.ts.map +0 -1
  104. package/dist/test/unit/permissionlessValidatorTxBuilder.test.js +0 -271
  105. package/dist/test/unit/smoke.d.ts +0 -2
  106. package/dist/test/unit/smoke.d.ts.map +0 -1
  107. package/dist/test/unit/smoke.js +0 -23
  108. package/dist/test/unit/transactionBuilder.test.d.ts +0 -2
  109. package/dist/test/unit/transactionBuilder.test.d.ts.map +0 -1
  110. package/dist/test/unit/transactionBuilder.test.js +0 -114
  111. package/dist/test/unit/validatorTxBuilder.test.d.ts +0 -2
  112. package/dist/test/unit/validatorTxBuilder.test.d.ts.map +0 -1
  113. package/dist/test/unit/validatorTxBuilder.test.js +0 -293
@@ -1,64 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.AtomicInCTransactionBuilder = void 0;
7
- const atomicTransactionBuilder_1 = require("./atomicTransactionBuilder");
8
- const utils_1 = __importDefault(require("./utils"));
9
- const sdk_core_1 = require("@bitgo-beta/sdk-core");
10
- /**
11
- * Flare P->C atomic import/export style builder (C-chain context). This adapts the AVAXP logic
12
- * removing direct Avalanche SDK dependencies. Network / chain ids are expected to be provided
13
- * in the transaction._network object by a higher-level factory once Flare network constants
14
- * are finalized. For now we CB58-decode placeholders if present and default to zero buffers.
15
- */
16
- class AtomicInCTransactionBuilder extends atomicTransactionBuilder_1.AtomicTransactionBuilder {
17
- constructor(_coinConfig) {
18
- super(_coinConfig);
19
- // Placeholder fixed fee (can be overridden by subclasses or network config)
20
- this.fixedFee = 0n;
21
- this.initializeChainIds();
22
- }
23
- /**
24
- * Set base fee (already scaled to Flare C-chain native decimals). Accept bigint | number | string.
25
- */
26
- feeRate(baseFee) {
27
- const n = typeof baseFee === 'bigint' ? baseFee : BigInt(baseFee);
28
- this.validateFee(n);
29
- this.setFeeRate(n);
30
- return this;
31
- }
32
- /**
33
- * Recreate builder state from raw tx (hex). Flare C-chain support TBD; for now validate & stash.
34
- */
35
- fromImplementation(rawTransaction) {
36
- // If utils has validateRawTransaction use it; otherwise basic check
37
- if (utils_1.default.validateRawTransaction) {
38
- utils_1.default.validateRawTransaction(rawTransaction);
39
- }
40
- this.transaction.setTransaction(rawTransaction);
41
- return this.transaction;
42
- }
43
- validateFee(fee) {
44
- if (fee <= 0n) {
45
- throw new sdk_core_1.BuildTransactionError('Fee must be greater than 0');
46
- }
47
- }
48
- initializeChainIds() {
49
- const meta = this.transaction._network;
50
- if (meta?.blockchainID) {
51
- this._externalChainId = utils_1.default.cb58Decode(meta.blockchainID);
52
- }
53
- if (meta?.cChainBlockchainID) {
54
- this.transaction._blockchainID = utils_1.default.cb58Decode(meta.cChainBlockchainID);
55
- }
56
- }
57
- setFeeRate(n) {
58
- const currentContainer = this.transaction;
59
- const current = currentContainer._fee || { fee: '0' };
60
- currentContainer._fee = { ...current, feeRate: n.toString() };
61
- }
62
- }
63
- exports.AtomicInCTransactionBuilder = AtomicInCTransactionBuilder;
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXRvbWljSW5DVHJhbnNhY3Rpb25CdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi9hdG9taWNJbkNUcmFuc2FjdGlvbkJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEseUVBQXNFO0FBRXRFLG9EQUE0QjtBQUM1QixtREFBNkQ7QUFhN0Q7Ozs7O0dBS0c7QUFDSCxNQUFzQiwyQkFBNEIsU0FBUSxtREFBd0I7SUFHaEYsWUFBWSxXQUFpQztRQUMzQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7UUFIckIsNEVBQTRFO1FBQ2xFLGFBQVEsR0FBRyxFQUFFLENBQUM7UUFHdEIsSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUM7SUFDNUIsQ0FBQztJQUVEOztPQUVHO0lBQ0gsT0FBTyxDQUFDLE9BQWlDO1FBQ3ZDLE1BQU0sQ0FBQyxHQUFHLE9BQU8sT0FBTyxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDbEUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNwQixJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ25CLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOztPQUVHO0lBQ08sa0JBQWtCLENBQUMsY0FBc0I7UUFDakQsb0VBQW9FO1FBQ3BFLElBQUssZUFBcUUsQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO1lBQ2pHLGVBQW9FLENBQUMsc0JBQXNCLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDL0csQ0FBQztRQUNELElBQUksQ0FBQyxXQUFXLENBQUMsY0FBYyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ2hELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDO0lBRU8sV0FBVyxDQUFDLEdBQVc7UUFDN0IsSUFBSSxHQUFHLElBQUksRUFBRSxFQUFFLENBQUM7WUFDZCxNQUFNLElBQUksZ0NBQXFCLENBQUMsNEJBQTRCLENBQUMsQ0FBQztRQUNoRSxDQUFDO0lBQ0gsQ0FBQztJQUVPLGtCQUFrQjtRQUN4QixNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQWlDLENBQUM7UUFDaEUsSUFBSSxJQUFJLEVBQUUsWUFBWSxFQUFFLENBQUM7WUFDdkIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLGVBQUssQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQzlELENBQUM7UUFDRCxJQUFJLElBQUksRUFBRSxrQkFBa0IsRUFBRSxDQUFDO1lBQzdCLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxHQUFHLGVBQUssQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUM7UUFDN0UsQ0FBQztJQUNILENBQUM7SUFFTyxVQUFVLENBQUMsQ0FBUztRQUMxQixNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyxXQUE0QyxDQUFDO1FBQzNFLE1BQU0sT0FBTyxHQUFHLGdCQUFnQixDQUFDLElBQUksSUFBSSxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsQ0FBQztRQUN0RCxnQkFBZ0IsQ0FBQyxJQUFJLEdBQUcsRUFBRSxHQUFHLE9BQU8sRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUM7SUFDaEUsQ0FBQztDQUNGO0FBbkRELGtFQW1EQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEF0b21pY1RyYW5zYWN0aW9uQnVpbGRlciB9IGZyb20gJy4vYXRvbWljVHJhbnNhY3Rpb25CdWlsZGVyJztcbmltcG9ydCB7IEJhc2VDb2luIGFzIENvaW5Db25maWcgfSBmcm9tICdAYml0Z28tYmV0YS9zdGF0aWNzJztcbmltcG9ydCB1dGlscyBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IEJ1aWxkVHJhbnNhY3Rpb25FcnJvciB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcblxuaW50ZXJmYWNlIEZsYXJlQ2hhaW5OZXR3b3JrTWV0YSB7XG4gIGJsb2NrY2hhaW5JRD86IHN0cmluZzsgLy8gUC1jaGFpbiBpZCAoZXh0ZXJuYWwpXG4gIGNDaGFpbkJsb2NrY2hhaW5JRD86IHN0cmluZzsgLy8gQy1jaGFpbiBpZCAobG9jYWwpXG4gIFtrOiBzdHJpbmddOiB1bmtub3duO1xufVxuXG5pbnRlcmZhY2UgRmVlU2hhcGUge1xuICBmZWU/OiBzdHJpbmc7IC8vIGxlZ2FjeVxuICBmZWVSYXRlPzogc3RyaW5nOyAvLyBwZXIgdW5pdCByYXRlXG59XG5cbi8qKlxuICogRmxhcmUgUC0+QyBhdG9taWMgaW1wb3J0L2V4cG9ydCBzdHlsZSBidWlsZGVyIChDLWNoYWluIGNvbnRleHQpLiBUaGlzIGFkYXB0cyB0aGUgQVZBWFAgbG9naWNcbiAqIHJlbW92aW5nIGRpcmVjdCBBdmFsYW5jaGUgU0RLIGRlcGVuZGVuY2llcy4gTmV0d29yayAvIGNoYWluIGlkcyBhcmUgZXhwZWN0ZWQgdG8gYmUgcHJvdmlkZWRcbiAqIGluIHRoZSB0cmFuc2FjdGlvbi5fbmV0d29yayBvYmplY3QgYnkgYSBoaWdoZXItbGV2ZWwgZmFjdG9yeSBvbmNlIEZsYXJlIG5ldHdvcmsgY29uc3RhbnRzXG4gKiBhcmUgZmluYWxpemVkLiBGb3Igbm93IHdlIENCNTgtZGVjb2RlIHBsYWNlaG9sZGVycyBpZiBwcmVzZW50IGFuZCBkZWZhdWx0IHRvIHplcm8gYnVmZmVycy5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEF0b21pY0luQ1RyYW5zYWN0aW9uQnVpbGRlciBleHRlbmRzIEF0b21pY1RyYW5zYWN0aW9uQnVpbGRlciB7XG4gIC8vIFBsYWNlaG9sZGVyIGZpeGVkIGZlZSAoY2FuIGJlIG92ZXJyaWRkZW4gYnkgc3ViY2xhc3NlcyBvciBuZXR3b3JrIGNvbmZpZylcbiAgcHJvdGVjdGVkIGZpeGVkRmVlID0gMG47XG4gIGNvbnN0cnVjdG9yKF9jb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPikge1xuICAgIHN1cGVyKF9jb2luQ29uZmlnKTtcbiAgICB0aGlzLmluaXRpYWxpemVDaGFpbklkcygpO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCBiYXNlIGZlZSAoYWxyZWFkeSBzY2FsZWQgdG8gRmxhcmUgQy1jaGFpbiBuYXRpdmUgZGVjaW1hbHMpLiBBY2NlcHQgYmlnaW50IHwgbnVtYmVyIHwgc3RyaW5nLlxuICAgKi9cbiAgZmVlUmF0ZShiYXNlRmVlOiBiaWdpbnQgfCBudW1iZXIgfCBzdHJpbmcpOiB0aGlzIHtcbiAgICBjb25zdCBuID0gdHlwZW9mIGJhc2VGZWUgPT09ICdiaWdpbnQnID8gYmFzZUZlZSA6IEJpZ0ludChiYXNlRmVlKTtcbiAgICB0aGlzLnZhbGlkYXRlRmVlKG4pO1xuICAgIHRoaXMuc2V0RmVlUmF0ZShuKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWNyZWF0ZSBidWlsZGVyIHN0YXRlIGZyb20gcmF3IHR4IChoZXgpLiBGbGFyZSBDLWNoYWluIHN1cHBvcnQgVEJEOyBmb3Igbm93IHZhbGlkYXRlICYgc3Rhc2guXG4gICAqL1xuICBwcm90ZWN0ZWQgZnJvbUltcGxlbWVudGF0aW9uKHJhd1RyYW5zYWN0aW9uOiBzdHJpbmcpOiB7IF90eD86IHVua25vd24gfSB7XG4gICAgLy8gSWYgdXRpbHMgaGFzIHZhbGlkYXRlUmF3VHJhbnNhY3Rpb24gdXNlIGl0OyBvdGhlcndpc2UgYmFzaWMgY2hlY2tcbiAgICBpZiAoKHV0aWxzIGFzIHVua25vd24gYXMgeyB2YWxpZGF0ZVJhd1RyYW5zYWN0aW9uPzogKHI6IHN0cmluZykgPT4gdm9pZCB9KS52YWxpZGF0ZVJhd1RyYW5zYWN0aW9uKSB7XG4gICAgICAodXRpbHMgYXMgdW5rbm93biBhcyB7IHZhbGlkYXRlUmF3VHJhbnNhY3Rpb246IChyOiBzdHJpbmcpID0+IHZvaWQgfSkudmFsaWRhdGVSYXdUcmFuc2FjdGlvbihyYXdUcmFuc2FjdGlvbik7XG4gICAgfVxuICAgIHRoaXMudHJhbnNhY3Rpb24uc2V0VHJhbnNhY3Rpb24ocmF3VHJhbnNhY3Rpb24pO1xuICAgIHJldHVybiB0aGlzLnRyYW5zYWN0aW9uO1xuICB9XG5cbiAgcHJpdmF0ZSB2YWxpZGF0ZUZlZShmZWU6IGJpZ2ludCk6IHZvaWQge1xuICAgIGlmIChmZWUgPD0gMG4pIHtcbiAgICAgIHRocm93IG5ldyBCdWlsZFRyYW5zYWN0aW9uRXJyb3IoJ0ZlZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAwJyk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBpbml0aWFsaXplQ2hhaW5JZHMoKTogdm9pZCB7XG4gICAgY29uc3QgbWV0YSA9IHRoaXMudHJhbnNhY3Rpb24uX25ldHdvcmsgYXMgRmxhcmVDaGFpbk5ldHdvcmtNZXRhO1xuICAgIGlmIChtZXRhPy5ibG9ja2NoYWluSUQpIHtcbiAgICAgIHRoaXMuX2V4dGVybmFsQ2hhaW5JZCA9IHV0aWxzLmNiNThEZWNvZGUobWV0YS5ibG9ja2NoYWluSUQpO1xuICAgIH1cbiAgICBpZiAobWV0YT8uY0NoYWluQmxvY2tjaGFpbklEKSB7XG4gICAgICB0aGlzLnRyYW5zYWN0aW9uLl9ibG9ja2NoYWluSUQgPSB1dGlscy5jYjU4RGVjb2RlKG1ldGEuY0NoYWluQmxvY2tjaGFpbklEKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIHNldEZlZVJhdGUobjogYmlnaW50KTogdm9pZCB7XG4gICAgY29uc3QgY3VycmVudENvbnRhaW5lciA9IHRoaXMudHJhbnNhY3Rpb24gYXMgdW5rbm93biBhcyB7IF9mZWU6IEZlZVNoYXBlIH07XG4gICAgY29uc3QgY3VycmVudCA9IGN1cnJlbnRDb250YWluZXIuX2ZlZSB8fCB7IGZlZTogJzAnIH07XG4gICAgY3VycmVudENvbnRhaW5lci5fZmVlID0geyAuLi5jdXJyZW50LCBmZWVSYXRlOiBuLnRvU3RyaW5nKCkgfTtcbiAgfVxufVxuIl19
@@ -1,96 +0,0 @@
1
- import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
2
- import { TransactionType, BaseTransaction } from '@bitgo-beta/sdk-core';
3
- import { Credential, TransferableInput, TransferableOutput } from '@flarenetwork/flarejs';
4
- import { TransactionExplanation, DecodedUtxoObj } from './iface';
5
- /**
6
- * Flare P-chain atomic transaction builder with FlareJS credential support.
7
- * This provides the foundation for building Flare P-chain transactions with proper
8
- * credential handling using FlareJS Credential and Signature classes.
9
- */
10
- export declare abstract class AtomicTransactionBuilder {
11
- protected readonly _coinConfig: Readonly<CoinConfig>;
12
- protected _externalChainId: Buffer | undefined;
13
- protected _utxos: DecodedUtxoObj[];
14
- protected transaction: {
15
- _network: Record<string, unknown>;
16
- _networkID: number;
17
- _blockchainID: Buffer;
18
- _assetId: Buffer;
19
- _fromAddresses: string[];
20
- _to: string[];
21
- _locktime: bigint;
22
- _threshold: number;
23
- _fee: {
24
- fee: string;
25
- feeRate?: string;
26
- size?: number;
27
- };
28
- hasCredentials: boolean;
29
- _tx?: unknown;
30
- _signature?: unknown;
31
- setTransaction: (tx: unknown) => void;
32
- };
33
- constructor(coinConfig: Readonly<CoinConfig>);
34
- protected abstract get transactionType(): TransactionType;
35
- /**
36
- * Get the asset ID for Flare network transactions
37
- * @returns Buffer containing the asset ID
38
- */
39
- protected getAssetId(): Buffer;
40
- validateAmount(amount: bigint): void;
41
- /**
42
- * Validates that credentials array is properly formed
43
- * @param credentials - Array of credentials to validate
44
- */
45
- protected validateCredentials(credentials: Credential[]): void;
46
- /**
47
- * Creates inputs, outputs, and credentials for Flare P-chain atomic transactions.
48
- * Based on AVAX P-chain implementation adapted for FlareJS.
49
- *
50
- * Note: This is a simplified implementation that creates the core structure.
51
- * The FlareJS type system integration will be refined in future iterations.
52
- *
53
- * @param total - Total amount needed including fees
54
- * @returns Object containing TransferableInput[], TransferableOutput[], and Credential[]
55
- */
56
- protected createInputOutput(total: bigint): {
57
- inputs: TransferableInput[];
58
- outputs: TransferableOutput[];
59
- credentials: Credential[];
60
- };
61
- /**
62
- * Set UTXOs for the transaction. This is required for creating inputs and outputs.
63
- *
64
- * @param utxos - Array of decoded UTXO objects
65
- * @returns this builder instance for chaining
66
- */
67
- utxos(utxos: DecodedUtxoObj[]): this;
68
- /**
69
- * Flare equivalent of Avalanche's SelectCredentialClass
70
- * Creates a credential with the provided signatures
71
- *
72
- * @param credentialId - The credential ID (not used in FlareJS but kept for compatibility)
73
- * @param signatures - Array of signature hex strings or empty strings for placeholders
74
- * @returns Credential instance
75
- */
76
- protected createFlareCredential(_credentialId: number, signatures: string[]): Credential;
77
- /**
78
- * Base initBuilder used by concrete builders. For now just returns this so fluent API works.
79
- */
80
- initBuilder(_tx: unknown): this;
81
- /**
82
- * Sign transaction with private key using FlareJS compatibility
83
- */
84
- sign(params: {
85
- key: string;
86
- }): this;
87
- /**
88
- * Build the transaction using FlareJS compatibility
89
- */
90
- build(): Promise<BaseTransaction>;
91
- /**
92
- * Parse and explain a transaction from hex using FlareJS compatibility
93
- */
94
- explainTransaction(): TransactionExplanation;
95
- }
96
- //# sourceMappingURL=atomicTransactionBuilder.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"atomicTransactionBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/atomicTransactionBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAyB,eAAe,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC/F,OAAO,EAAE,UAAU,EAAa,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AACrG,OAAO,EAAE,sBAAsB,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAoCjE;;;;GAIG;AACH,8BAAsB,wBAAwB;IAC5C,SAAS,CAAC,QAAQ,CAAC,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC;IAErD,SAAS,CAAC,gBAAgB,EAAE,MAAM,GAAG,SAAS,CAAC;IAE/C,SAAS,CAAC,MAAM,EAAE,cAAc,EAAE,CAAM;IAExC,SAAS,CAAC,WAAW,EAAE;QACrB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAClC,UAAU,EAAE,MAAM,CAAC;QACnB,aAAa,EAAE,MAAM,CAAC;QACtB,QAAQ,EAAE,MAAM,CAAC;QACjB,cAAc,EAAE,MAAM,EAAE,CAAC;QACzB,GAAG,EAAE,MAAM,EAAE,CAAC;QACd,SAAS,EAAE,MAAM,CAAC;QAClB,UAAU,EAAE,MAAM,CAAC;QACnB,IAAI,EAAE;YAAE,GAAG,EAAE,MAAM,CAAC;YAAC,OAAO,CAAC,EAAE,MAAM,CAAC;YAAC,IAAI,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC;QACvD,cAAc,EAAE,OAAO,CAAC;QACxB,GAAG,CAAC,EAAE,OAAO,CAAC;QACd,UAAU,CAAC,EAAE,OAAO,CAAC;QACrB,cAAc,EAAE,CAAC,EAAE,EAAE,OAAO,KAAK,IAAI,CAAC;KACvC,CAcC;gBAEU,UAAU,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI5C,SAAS,CAAC,QAAQ,KAAK,eAAe,IAAI,eAAe,CAAC;IAE1D;;;OAGG;IACH,SAAS,CAAC,UAAU,IAAI,MAAM;IAY9B,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAMpC;;;OAGG;IACH,SAAS,CAAC,mBAAmB,CAAC,WAAW,EAAE,UAAU,EAAE,GAAG,IAAI;IAY9D;;;;;;;;;OASG;IACH,SAAS,CAAC,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG;QAC1C,MAAM,EAAE,iBAAiB,EAAE,CAAC;QAC5B,OAAO,EAAE,kBAAkB,EAAE,CAAC;QAC9B,WAAW,EAAE,UAAU,EAAE,CAAC;KAC3B;IA8FD;;;;;OAKG;IACH,KAAK,CAAC,KAAK,EAAE,cAAc,EAAE,GAAG,IAAI;IAKpC;;;;;;;OAOG;IACH,SAAS,CAAC,qBAAqB,CAAC,aAAa,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,UAAU;IAmDxF;;OAEG;IACH,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAI/B;;OAEG;IACH,IAAI,CAAC,MAAM,EAAE;QAAE,GAAG,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI;IA0BnC;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,eAAe,CAAC;IAyDvC;;OAEG;IACH,kBAAkB,IAAI,sBAAsB;CAoB7C"}
@@ -1,318 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.AtomicTransactionBuilder = void 0;
4
- const sdk_core_1 = require("@bitgo-beta/sdk-core");
5
- const flarejs_1 = require("@flarenetwork/flarejs");
6
- const constants_1 = require("./constants");
7
- const utils_1 = require("./utils");
8
- /**
9
- * Flare P-chain atomic transaction builder with FlareJS credential support.
10
- * This provides the foundation for building Flare P-chain transactions with proper
11
- * credential handling using FlareJS Credential and Signature classes.
12
- */
13
- class AtomicTransactionBuilder {
14
- constructor(coinConfig) {
15
- this._utxos = [];
16
- this.transaction = {
17
- _network: {},
18
- _networkID: constants_1.DEFAULT_NETWORK_ID,
19
- _blockchainID: Buffer.alloc(constants_1.EMPTY_BUFFER_SIZE),
20
- _assetId: Buffer.alloc(constants_1.EMPTY_BUFFER_SIZE),
21
- _fromAddresses: [],
22
- _to: [],
23
- _locktime: constants_1.DEFAULT_LOCKTIME,
24
- _threshold: constants_1.DEFAULT_THRESHOLD,
25
- _fee: { fee: constants_1.AMOUNT_STRING_ZERO },
26
- hasCredentials: false,
27
- setTransaction: function (_tx) {
28
- this._tx = _tx;
29
- },
30
- };
31
- this._coinConfig = coinConfig;
32
- }
33
- /**
34
- * Get the asset ID for Flare network transactions
35
- * @returns Buffer containing the asset ID
36
- */
37
- getAssetId() {
38
- // Use the asset ID from transaction if already set
39
- if (this.transaction._assetId && this.transaction._assetId.length > 0) {
40
- return this.transaction._assetId;
41
- }
42
- // For native FLR transactions, return zero-filled buffer as placeholder
43
- // In a real implementation, this would be obtained from the network configuration
44
- // or FlareJS API to get the actual native asset ID
45
- return Buffer.alloc(constants_1.ASSET_ID_LENGTH);
46
- }
47
- validateAmount(amount) {
48
- if (amount <= constants_1.ZERO_BIGINT) {
49
- throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_AMOUNT_POSITIVE);
50
- }
51
- }
52
- /**
53
- * Validates that credentials array is properly formed
54
- * @param credentials - Array of credentials to validate
55
- */
56
- validateCredentials(credentials) {
57
- if (!Array.isArray(credentials)) {
58
- throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_CREDENTIALS_ARRAY);
59
- }
60
- credentials.forEach((credential, index) => {
61
- if (!(credential instanceof flarejs_1.Credential)) {
62
- throw new sdk_core_1.BuildTransactionError(`Invalid credential at index ${index}`);
63
- }
64
- });
65
- }
66
- /**
67
- * Creates inputs, outputs, and credentials for Flare P-chain atomic transactions.
68
- * Based on AVAX P-chain implementation adapted for FlareJS.
69
- *
70
- * Note: This is a simplified implementation that creates the core structure.
71
- * The FlareJS type system integration will be refined in future iterations.
72
- *
73
- * @param total - Total amount needed including fees
74
- * @returns Object containing TransferableInput[], TransferableOutput[], and Credential[]
75
- */
76
- createInputOutput(total) {
77
- if (!this._utxos || this._utxos.length === constants_1.ZERO_NUMBER) {
78
- throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_UTXOS_REQUIRED);
79
- }
80
- const inputs = [];
81
- const outputs = [];
82
- const credentials = [];
83
- let inputSum = 0n;
84
- const addressIndices = {};
85
- let nextAddressIndex = 0;
86
- // Sort UTXOs by amount in descending order for optimal coin selection
87
- const sortedUtxos = [...this._utxos].sort((a, b) => {
88
- const amountA = BigInt(a.amount);
89
- const amountB = BigInt(b.amount);
90
- if (amountA > amountB)
91
- return -1;
92
- if (amountA < amountB)
93
- return 1;
94
- return 0;
95
- });
96
- // Process UTXOs to create inputs and credentials
97
- for (const utxo of sortedUtxos) {
98
- const utxoAmount = BigInt(utxo.amount);
99
- if (inputSum >= total) {
100
- break; // We have enough inputs
101
- }
102
- // Track input sum
103
- inputSum += utxoAmount;
104
- // Track address indices for signature ordering (mimics AVAX pattern)
105
- const addressIndexArray = [];
106
- for (const address of utxo.addresses) {
107
- if (!(address in addressIndices)) {
108
- addressIndices[address] = nextAddressIndex++;
109
- }
110
- addressIndexArray.push(addressIndices[address]);
111
- }
112
- // Store address indices on the UTXO for credential creation
113
- utxo.addressesIndex = addressIndexArray;
114
- // Create TransferableInput for atomic transactions
115
- const transferableInput = {
116
- txID: Buffer.from(utxo.txid || constants_1.AMOUNT_STRING_ZERO.repeat(constants_1.TRANSACTION_ID_HEX_LENGTH), constants_1.HEX_ENCODING),
117
- outputIndex: parseInt(utxo.outputidx || constants_1.AMOUNT_STRING_ZERO, constants_1.DECIMAL_RADIX),
118
- assetID: this.getAssetId(),
119
- input: {
120
- amount: utxoAmount,
121
- addressIndices: addressIndexArray,
122
- threshold: utxo.threshold,
123
- },
124
- };
125
- // Store the input (type assertion for compatibility)
126
- inputs.push(transferableInput);
127
- // Create credential with placeholder signatures
128
- // In a real implementation, these would be actual signatures
129
- const signatures = Array.from({ length: utxo.threshold }, () => '');
130
- const credential = this.createFlareCredential(0, signatures);
131
- credentials.push(credential);
132
- }
133
- // Verify we have enough inputs
134
- if (inputSum < total) {
135
- throw new sdk_core_1.BuildTransactionError(`Insufficient funds: need ${total}, have ${inputSum}`);
136
- }
137
- // Create change output if we have excess input amount
138
- if (inputSum > total) {
139
- const changeAmount = inputSum - total;
140
- // Create change output for atomic transactions
141
- const changeOutput = {
142
- assetID: this.getAssetId(),
143
- output: {
144
- amount: changeAmount,
145
- addresses: this.transaction._fromAddresses,
146
- threshold: 1,
147
- locktime: 0n,
148
- },
149
- };
150
- // Add the change output (type assertion for compatibility)
151
- outputs.push(changeOutput);
152
- }
153
- return { inputs, outputs, credentials };
154
- }
155
- /**
156
- * Set UTXOs for the transaction. This is required for creating inputs and outputs.
157
- *
158
- * @param utxos - Array of decoded UTXO objects
159
- * @returns this builder instance for chaining
160
- */
161
- utxos(utxos) {
162
- this._utxos = utxos;
163
- return this;
164
- }
165
- /**
166
- * Flare equivalent of Avalanche's SelectCredentialClass
167
- * Creates a credential with the provided signatures
168
- *
169
- * @param credentialId - The credential ID (not used in FlareJS but kept for compatibility)
170
- * @param signatures - Array of signature hex strings or empty strings for placeholders
171
- * @returns Credential instance
172
- */
173
- createFlareCredential(_credentialId, signatures) {
174
- if (!Array.isArray(signatures)) {
175
- throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_SIGNATURES_ARRAY);
176
- }
177
- if (signatures.length === constants_1.ZERO_NUMBER) {
178
- throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_SIGNATURES_EMPTY);
179
- }
180
- const sigs = signatures.map((sig, index) => {
181
- // Handle empty/placeholder signatures
182
- if (!sig || sig.length === 0) {
183
- return new flarejs_1.Signature(new Uint8Array(constants_1.SECP256K1_SIGNATURE_LENGTH));
184
- }
185
- // Validate hex string format
186
- const cleanSig = sig.startsWith(constants_1.HEX_PREFIX) ? sig.slice(constants_1.HEX_PREFIX_LENGTH) : sig;
187
- if (!(0, utils_1.createFlexibleHexRegex)().test(cleanSig)) {
188
- throw new sdk_core_1.BuildTransactionError(`Invalid hex signature at index ${index}: contains non-hex characters`);
189
- }
190
- // Convert to buffer and validate length
191
- const sigBuffer = Buffer.from(cleanSig, constants_1.HEX_ENCODING);
192
- if (sigBuffer.length > constants_1.SECP256K1_SIGNATURE_LENGTH) {
193
- throw new sdk_core_1.BuildTransactionError(`Signature too long at index ${index}: ${sigBuffer.length} bytes (max ${constants_1.SECP256K1_SIGNATURE_LENGTH})`);
194
- }
195
- // Create fixed-length buffer and copy signature data
196
- const fixedLengthBuffer = Buffer.alloc(constants_1.SECP256K1_SIGNATURE_LENGTH);
197
- sigBuffer.copy(fixedLengthBuffer);
198
- try {
199
- return new flarejs_1.Signature(new Uint8Array(fixedLengthBuffer));
200
- }
201
- catch (error) {
202
- throw new sdk_core_1.BuildTransactionError(`Failed to create signature at index ${index}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN}`);
203
- }
204
- });
205
- try {
206
- return new flarejs_1.Credential(sigs);
207
- }
208
- catch (error) {
209
- throw new sdk_core_1.BuildTransactionError(`${constants_1.ERROR_CREATE_CREDENTIAL_FAILED}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN}`);
210
- }
211
- }
212
- /**
213
- * Base initBuilder used by concrete builders. For now just returns this so fluent API works.
214
- */
215
- initBuilder(_tx) {
216
- return this;
217
- }
218
- /**
219
- * Sign transaction with private key using FlareJS compatibility
220
- */
221
- sign(params) {
222
- // FlareJS signing implementation with atomic transaction support
223
- try {
224
- // Validate private key format (placeholder implementation)
225
- if (!params.key || params.key.length < constants_1.PRIVATE_KEY_HEX_LENGTH) {
226
- throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_INVALID_PRIVATE_KEY);
227
- }
228
- // Create signature structure
229
- const signature = {
230
- privateKey: params.key,
231
- signingMethod: constants_1.SIGNING_METHOD,
232
- };
233
- // Store signature for FlareJS compatibility
234
- this.transaction._signature = signature;
235
- this.transaction.hasCredentials = true;
236
- return this;
237
- }
238
- catch (error) {
239
- throw new sdk_core_1.BuildTransactionError(`${constants_1.ERROR_FLAREJS_SIGNING_FAILED}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN}`);
240
- }
241
- }
242
- /**
243
- * Build the transaction using FlareJS compatibility
244
- */
245
- async build() {
246
- // FlareJS UnsignedTx creation with atomic transaction support
247
- try {
248
- // Validate transaction requirements
249
- if (!this._utxos || this._utxos.length === 0) {
250
- throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_UTXOS_REQUIRED_BUILD);
251
- }
252
- // Create FlareJS transaction structure with atomic support
253
- const transaction = {
254
- _id: `${constants_1.TRANSACTION_ID_PREFIX}${Date.now()}`,
255
- _inputs: [],
256
- _outputs: [],
257
- _type: this.transactionType,
258
- signature: [],
259
- fromAddresses: this.transaction._fromAddresses,
260
- validationErrors: [],
261
- // FlareJS methods with atomic support
262
- toBroadcastFormat: () => `${constants_1.TRANSACTION_ID_PREFIX}${Date.now()}`,
263
- toJson: () => ({
264
- type: this.transactionType,
265
- }),
266
- explainTransaction: () => ({
267
- type: this.transactionType,
268
- inputs: [],
269
- outputs: [],
270
- outputAmount: constants_1.AMOUNT_STRING_ZERO,
271
- rewardAddresses: [],
272
- id: `${constants_1.FLARE_ATOMIC_PREFIX}${Date.now()}`,
273
- changeOutputs: [],
274
- changeAmount: constants_1.AMOUNT_STRING_ZERO,
275
- fee: { fee: this.transaction._fee.fee },
276
- }),
277
- isTransactionForCChain: false,
278
- loadInputsAndOutputs: () => {
279
- /* FlareJS atomic transaction loading */
280
- },
281
- inputs: () => [],
282
- outputs: () => [],
283
- fee: () => ({ fee: this.transaction._fee.fee }),
284
- feeRate: () => 0,
285
- id: () => `${constants_1.FLARE_ATOMIC_PREFIX}${Date.now()}`,
286
- type: this.transactionType,
287
- };
288
- return transaction;
289
- }
290
- catch (error) {
291
- throw new sdk_core_1.BuildTransactionError(`${constants_1.ERROR_ENHANCED_BUILD_FAILED}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN}`);
292
- }
293
- }
294
- /**
295
- * Parse and explain a transaction from hex using FlareJS compatibility
296
- */
297
- explainTransaction() {
298
- // FlareJS transaction parsing with atomic support
299
- try {
300
- return {
301
- type: this.transactionType,
302
- inputs: [],
303
- outputs: [],
304
- outputAmount: constants_1.AMOUNT_STRING_ZERO,
305
- rewardAddresses: [],
306
- id: `${constants_1.FLARE_ATOMIC_PARSED_PREFIX}${Date.now()}`,
307
- changeOutputs: [],
308
- changeAmount: constants_1.AMOUNT_STRING_ZERO,
309
- fee: { fee: this.transaction._fee.fee },
310
- };
311
- }
312
- catch (error) {
313
- throw new sdk_core_1.BuildTransactionError(`${constants_1.ERROR_ENHANCED_PARSE_FAILED}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN}`);
314
- }
315
- }
316
- }
317
- exports.AtomicTransactionBuilder = AtomicTransactionBuilder;
318
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"atomicTransactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/atomicTransactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { BuildTransactionError, TransactionType, BaseTransaction } from '@bitgo-beta/sdk-core';\nimport { Credential, Signature, TransferableInput, TransferableOutput } from '@flarenetwork/flarejs';\nimport { TransactionExplanation, DecodedUtxoObj } from './iface';\nimport {\n  ASSET_ID_LENGTH,\n  TRANSACTION_ID_HEX_LENGTH,\n  PRIVATE_KEY_HEX_LENGTH,\n  SECP256K1_SIGNATURE_LENGTH,\n  TRANSACTION_ID_PREFIX,\n  DEFAULT_NETWORK_ID,\n  EMPTY_BUFFER_SIZE,\n  HEX_PREFIX,\n  HEX_PREFIX_LENGTH,\n  DECIMAL_RADIX,\n  SIGNING_METHOD,\n  AMOUNT_STRING_ZERO,\n  DEFAULT_LOCKTIME,\n  DEFAULT_THRESHOLD,\n  ZERO_BIGINT,\n  ZERO_NUMBER,\n  ERROR_AMOUNT_POSITIVE,\n  ERROR_CREDENTIALS_ARRAY,\n  ERROR_UTXOS_REQUIRED,\n  ERROR_SIGNATURES_ARRAY,\n  ERROR_SIGNATURES_EMPTY,\n  ERROR_INVALID_PRIVATE_KEY,\n  ERROR_UTXOS_REQUIRED_BUILD,\n  ERROR_ENHANCED_BUILD_FAILED,\n  ERROR_ENHANCED_PARSE_FAILED,\n  ERROR_FLAREJS_SIGNING_FAILED,\n  ERROR_CREATE_CREDENTIAL_FAILED,\n  ERROR_UNKNOWN,\n  FLARE_ATOMIC_PREFIX,\n  FLARE_ATOMIC_PARSED_PREFIX,\n  HEX_ENCODING,\n} from './constants';\nimport { createFlexibleHexRegex } from './utils';\n\n/**\n * Flare P-chain atomic transaction builder with FlareJS credential support.\n * This provides the foundation for building Flare P-chain transactions with proper\n * credential handling using FlareJS Credential and Signature classes.\n */\nexport abstract class AtomicTransactionBuilder {\n  protected readonly _coinConfig: Readonly<CoinConfig>;\n  // External chain id (destination) for export transactions\n  protected _externalChainId: Buffer | undefined;\n\n  protected _utxos: DecodedUtxoObj[] = [];\n\n  protected transaction: {\n    _network: Record<string, unknown>;\n    _networkID: number;\n    _blockchainID: Buffer;\n    _assetId: Buffer;\n    _fromAddresses: string[];\n    _to: string[];\n    _locktime: bigint;\n    _threshold: number;\n    _fee: { fee: string; feeRate?: string; size?: number };\n    hasCredentials: boolean;\n    _tx?: unknown;\n    _signature?: unknown;\n    setTransaction: (tx: unknown) => void;\n  } = {\n    _network: {},\n    _networkID: DEFAULT_NETWORK_ID,\n    _blockchainID: Buffer.alloc(EMPTY_BUFFER_SIZE),\n    _assetId: Buffer.alloc(EMPTY_BUFFER_SIZE),\n    _fromAddresses: [],\n    _to: [],\n    _locktime: DEFAULT_LOCKTIME,\n    _threshold: DEFAULT_THRESHOLD,\n    _fee: { fee: AMOUNT_STRING_ZERO },\n    hasCredentials: false,\n    setTransaction: function (_tx: unknown) {\n      this._tx = _tx;\n    },\n  };\n\n  constructor(coinConfig: Readonly<CoinConfig>) {\n    this._coinConfig = coinConfig;\n  }\n\n  protected abstract get transactionType(): TransactionType;\n\n  /**\n   * Get the asset ID for Flare network transactions\n   * @returns Buffer containing the asset ID\n   */\n  protected getAssetId(): Buffer {\n    // Use the asset ID from transaction if already set\n    if (this.transaction._assetId && this.transaction._assetId.length > 0) {\n      return this.transaction._assetId;\n    }\n\n    // For native FLR transactions, return zero-filled buffer as placeholder\n    // In a real implementation, this would be obtained from the network configuration\n    // or FlareJS API to get the actual native asset ID\n    return Buffer.alloc(ASSET_ID_LENGTH);\n  }\n\n  validateAmount(amount: bigint): void {\n    if (amount <= ZERO_BIGINT) {\n      throw new BuildTransactionError(ERROR_AMOUNT_POSITIVE);\n    }\n  }\n\n  /**\n   * Validates that credentials array is properly formed\n   * @param credentials - Array of credentials to validate\n   */\n  protected validateCredentials(credentials: Credential[]): void {\n    if (!Array.isArray(credentials)) {\n      throw new BuildTransactionError(ERROR_CREDENTIALS_ARRAY);\n    }\n\n    credentials.forEach((credential, index) => {\n      if (!(credential instanceof Credential)) {\n        throw new BuildTransactionError(`Invalid credential at index ${index}`);\n      }\n    });\n  }\n\n  /**\n   * Creates inputs, outputs, and credentials for Flare P-chain atomic transactions.\n   * Based on AVAX P-chain implementation adapted for FlareJS.\n   *\n   * Note: This is a simplified implementation that creates the core structure.\n   * The FlareJS type system integration will be refined in future iterations.\n   *\n   * @param total - Total amount needed including fees\n   * @returns Object containing TransferableInput[], TransferableOutput[], and Credential[]\n   */\n  protected createInputOutput(total: bigint): {\n    inputs: TransferableInput[];\n    outputs: TransferableOutput[];\n    credentials: Credential[];\n  } {\n    if (!this._utxos || this._utxos.length === ZERO_NUMBER) {\n      throw new BuildTransactionError(ERROR_UTXOS_REQUIRED);\n    }\n\n    const inputs: TransferableInput[] = [];\n    const outputs: TransferableOutput[] = [];\n    const credentials: Credential[] = [];\n\n    let inputSum = 0n;\n    const addressIndices: { [address: string]: number } = {};\n    let nextAddressIndex = 0;\n\n    // Sort UTXOs by amount in descending order for optimal coin selection\n    const sortedUtxos = [...this._utxos].sort((a, b) => {\n      const amountA = BigInt(a.amount);\n      const amountB = BigInt(b.amount);\n      if (amountA > amountB) return -1;\n      if (amountA < amountB) return 1;\n      return 0;\n    });\n\n    // Process UTXOs to create inputs and credentials\n    for (const utxo of sortedUtxos) {\n      const utxoAmount = BigInt(utxo.amount);\n\n      if (inputSum >= total) {\n        break; // We have enough inputs\n      }\n\n      // Track input sum\n      inputSum += utxoAmount;\n\n      // Track address indices for signature ordering (mimics AVAX pattern)\n      const addressIndexArray: number[] = [];\n      for (const address of utxo.addresses) {\n        if (!(address in addressIndices)) {\n          addressIndices[address] = nextAddressIndex++;\n        }\n        addressIndexArray.push(addressIndices[address]);\n      }\n\n      // Store address indices on the UTXO for credential creation\n      utxo.addressesIndex = addressIndexArray;\n\n      // Create TransferableInput for atomic transactions\n      const transferableInput = {\n        txID: Buffer.from(utxo.txid || AMOUNT_STRING_ZERO.repeat(TRANSACTION_ID_HEX_LENGTH), HEX_ENCODING),\n        outputIndex: parseInt(utxo.outputidx || AMOUNT_STRING_ZERO, DECIMAL_RADIX),\n        assetID: this.getAssetId(),\n        input: {\n          amount: utxoAmount,\n          addressIndices: addressIndexArray,\n          threshold: utxo.threshold,\n        },\n      };\n\n      // Store the input (type assertion for compatibility)\n      inputs.push(transferableInput as unknown as TransferableInput);\n\n      // Create credential with placeholder signatures\n      // In a real implementation, these would be actual signatures\n      const signatures = Array.from({ length: utxo.threshold }, () => '');\n      const credential = this.createFlareCredential(0, signatures);\n      credentials.push(credential);\n    }\n\n    // Verify we have enough inputs\n    if (inputSum < total) {\n      throw new BuildTransactionError(`Insufficient funds: need ${total}, have ${inputSum}`);\n    }\n\n    // Create change output if we have excess input amount\n    if (inputSum > total) {\n      const changeAmount = inputSum - total;\n\n      // Create change output for atomic transactions\n      const changeOutput = {\n        assetID: this.getAssetId(),\n        output: {\n          amount: changeAmount,\n          addresses: this.transaction._fromAddresses,\n          threshold: 1,\n          locktime: 0n,\n        },\n      };\n\n      // Add the change output (type assertion for compatibility)\n      outputs.push(changeOutput as unknown as TransferableOutput);\n    }\n\n    return { inputs, outputs, credentials };\n  }\n\n  /**\n   * Set UTXOs for the transaction. This is required for creating inputs and outputs.\n   *\n   * @param utxos - Array of decoded UTXO objects\n   * @returns this builder instance for chaining\n   */\n  utxos(utxos: DecodedUtxoObj[]): this {\n    this._utxos = utxos;\n    return this;\n  }\n\n  /**\n   * Flare equivalent of Avalanche's SelectCredentialClass\n   * Creates a credential with the provided signatures\n   *\n   * @param credentialId - The credential ID (not used in FlareJS but kept for compatibility)\n   * @param signatures - Array of signature hex strings or empty strings for placeholders\n   * @returns Credential instance\n   */\n  protected createFlareCredential(_credentialId: number, signatures: string[]): Credential {\n    if (!Array.isArray(signatures)) {\n      throw new BuildTransactionError(ERROR_SIGNATURES_ARRAY);\n    }\n\n    if (signatures.length === ZERO_NUMBER) {\n      throw new BuildTransactionError(ERROR_SIGNATURES_EMPTY);\n    }\n\n    const sigs = signatures.map((sig, index) => {\n      // Handle empty/placeholder signatures\n      if (!sig || sig.length === 0) {\n        return new Signature(new Uint8Array(SECP256K1_SIGNATURE_LENGTH));\n      }\n\n      // Validate hex string format\n      const cleanSig = sig.startsWith(HEX_PREFIX) ? sig.slice(HEX_PREFIX_LENGTH) : sig;\n      if (!createFlexibleHexRegex().test(cleanSig)) {\n        throw new BuildTransactionError(`Invalid hex signature at index ${index}: contains non-hex characters`);\n      }\n\n      // Convert to buffer and validate length\n      const sigBuffer = Buffer.from(cleanSig, HEX_ENCODING);\n      if (sigBuffer.length > SECP256K1_SIGNATURE_LENGTH) {\n        throw new BuildTransactionError(\n          `Signature too long at index ${index}: ${sigBuffer.length} bytes (max ${SECP256K1_SIGNATURE_LENGTH})`\n        );\n      }\n\n      // Create fixed-length buffer and copy signature data\n      const fixedLengthBuffer = Buffer.alloc(SECP256K1_SIGNATURE_LENGTH);\n      sigBuffer.copy(fixedLengthBuffer);\n\n      try {\n        return new Signature(new Uint8Array(fixedLengthBuffer));\n      } catch (error) {\n        throw new BuildTransactionError(\n          `Failed to create signature at index ${index}: ${error instanceof Error ? error.message : ERROR_UNKNOWN}`\n        );\n      }\n    });\n\n    try {\n      return new Credential(sigs);\n    } catch (error) {\n      throw new BuildTransactionError(\n        `${ERROR_CREATE_CREDENTIAL_FAILED}: ${error instanceof Error ? error.message : ERROR_UNKNOWN}`\n      );\n    }\n  }\n\n  /**\n   * Base initBuilder used by concrete builders. For now just returns this so fluent API works.\n   */\n  initBuilder(_tx: unknown): this {\n    return this;\n  }\n\n  /**\n   * Sign transaction with private key using FlareJS compatibility\n   */\n  sign(params: { key: string }): this {\n    // FlareJS signing implementation with atomic transaction support\n    try {\n      // Validate private key format (placeholder implementation)\n      if (!params.key || params.key.length < PRIVATE_KEY_HEX_LENGTH) {\n        throw new BuildTransactionError(ERROR_INVALID_PRIVATE_KEY);\n      }\n\n      // Create signature structure\n      const signature = {\n        privateKey: params.key,\n        signingMethod: SIGNING_METHOD,\n      };\n\n      // Store signature for FlareJS compatibility\n      this.transaction._signature = signature;\n      this.transaction.hasCredentials = true;\n\n      return this;\n    } catch (error) {\n      throw new BuildTransactionError(\n        `${ERROR_FLAREJS_SIGNING_FAILED}: ${error instanceof Error ? error.message : ERROR_UNKNOWN}`\n      );\n    }\n  }\n\n  /**\n   * Build the transaction using FlareJS compatibility\n   */\n  async build(): Promise<BaseTransaction> {\n    // FlareJS UnsignedTx creation with atomic transaction support\n    try {\n      // Validate transaction requirements\n      if (!this._utxos || this._utxos.length === 0) {\n        throw new BuildTransactionError(ERROR_UTXOS_REQUIRED_BUILD);\n      }\n\n      // Create FlareJS transaction structure with atomic support\n      const transaction = {\n        _id: `${TRANSACTION_ID_PREFIX}${Date.now()}`,\n        _inputs: [],\n        _outputs: [],\n        _type: this.transactionType,\n        signature: [] as string[],\n\n        fromAddresses: this.transaction._fromAddresses,\n        validationErrors: [],\n\n        // FlareJS methods with atomic support\n        toBroadcastFormat: () => `${TRANSACTION_ID_PREFIX}${Date.now()}`,\n        toJson: () => ({\n          type: this.transactionType,\n        }),\n\n        explainTransaction: (): TransactionExplanation => ({\n          type: this.transactionType,\n          inputs: [],\n          outputs: [],\n          outputAmount: AMOUNT_STRING_ZERO,\n          rewardAddresses: [],\n          id: `${FLARE_ATOMIC_PREFIX}${Date.now()}`,\n          changeOutputs: [],\n          changeAmount: AMOUNT_STRING_ZERO,\n          fee: { fee: this.transaction._fee.fee },\n        }),\n\n        isTransactionForCChain: false,\n        loadInputsAndOutputs: () => {\n          /* FlareJS atomic transaction loading */\n        },\n        inputs: () => [],\n        outputs: () => [],\n        fee: () => ({ fee: this.transaction._fee.fee }),\n        feeRate: () => 0,\n        id: () => `${FLARE_ATOMIC_PREFIX}${Date.now()}`,\n        type: this.transactionType,\n      } as unknown as BaseTransaction;\n\n      return transaction;\n    } catch (error) {\n      throw new BuildTransactionError(\n        `${ERROR_ENHANCED_BUILD_FAILED}: ${error instanceof Error ? error.message : ERROR_UNKNOWN}`\n      );\n    }\n  }\n\n  /**\n   * Parse and explain a transaction from hex using FlareJS compatibility\n   */\n  explainTransaction(): TransactionExplanation {\n    // FlareJS transaction parsing with atomic support\n    try {\n      return {\n        type: this.transactionType,\n        inputs: [],\n        outputs: [],\n        outputAmount: AMOUNT_STRING_ZERO,\n        rewardAddresses: [],\n        id: `${FLARE_ATOMIC_PARSED_PREFIX}${Date.now()}`,\n        changeOutputs: [],\n        changeAmount: AMOUNT_STRING_ZERO,\n        fee: { fee: this.transaction._fee.fee },\n      };\n    } catch (error) {\n      throw new BuildTransactionError(\n        `${ERROR_ENHANCED_PARSE_FAILED}: ${error instanceof Error ? error.message : ERROR_UNKNOWN}`\n      );\n    }\n  }\n}\n"]}