@fuel-ts/account 0.0.0-rc-2037-20240418195040 → 0.0.0-rc-2021-20240418195117

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.

Potentially problematic release.


This version of @fuel-ts/account might be problematic. Click here for more details.

Files changed (66) hide show
  1. package/README.md +1 -1
  2. package/dist/account.d.ts +5 -4
  3. package/dist/account.d.ts.map +1 -1
  4. package/dist/configs.d.ts.map +1 -1
  5. package/dist/configs.global.js +1 -1
  6. package/dist/configs.global.js.map +1 -1
  7. package/dist/configs.js +1 -1
  8. package/dist/configs.js.map +1 -1
  9. package/dist/configs.mjs +1 -1
  10. package/dist/configs.mjs.map +1 -1
  11. package/dist/index.global.js +797 -596
  12. package/dist/index.global.js.map +1 -1
  13. package/dist/index.js +825 -633
  14. package/dist/index.js.map +1 -1
  15. package/dist/index.mjs +648 -451
  16. package/dist/index.mjs.map +1 -1
  17. package/dist/predicate/predicate.d.ts +11 -18
  18. package/dist/predicate/predicate.d.ts.map +1 -1
  19. package/dist/providers/__generated__/operations.d.ts +906 -324
  20. package/dist/providers/__generated__/operations.d.ts.map +1 -1
  21. package/dist/providers/coin-quantity.d.ts +1 -1
  22. package/dist/providers/coin-quantity.d.ts.map +1 -1
  23. package/dist/providers/coin.d.ts +2 -1
  24. package/dist/providers/coin.d.ts.map +1 -1
  25. package/dist/providers/message.d.ts +6 -1
  26. package/dist/providers/message.d.ts.map +1 -1
  27. package/dist/providers/provider.d.ts +37 -27
  28. package/dist/providers/provider.d.ts.map +1 -1
  29. package/dist/providers/transaction-request/create-transaction-request.d.ts.map +1 -1
  30. package/dist/providers/transaction-request/index.d.ts +0 -1
  31. package/dist/providers/transaction-request/index.d.ts.map +1 -1
  32. package/dist/providers/transaction-request/input.d.ts +2 -2
  33. package/dist/providers/transaction-request/input.d.ts.map +1 -1
  34. package/dist/providers/transaction-request/script-transaction-request.d.ts.map +1 -1
  35. package/dist/providers/transaction-request/transaction-request.d.ts +6 -7
  36. package/dist/providers/transaction-request/transaction-request.d.ts.map +1 -1
  37. package/dist/providers/transaction-request/utils.d.ts +3 -0
  38. package/dist/providers/transaction-request/utils.d.ts.map +1 -1
  39. package/dist/providers/transaction-response/transaction-response.d.ts.map +1 -1
  40. package/dist/providers/transaction-summary/assemble-transaction-summary.d.ts +2 -0
  41. package/dist/providers/transaction-summary/assemble-transaction-summary.d.ts.map +1 -1
  42. package/dist/providers/transaction-summary/calculate-transaction-fee.d.ts +3 -2
  43. package/dist/providers/transaction-summary/calculate-transaction-fee.d.ts.map +1 -1
  44. package/dist/providers/transaction-summary/get-transaction-summary.d.ts.map +1 -1
  45. package/dist/providers/utils/gas.d.ts +8 -2
  46. package/dist/providers/utils/gas.d.ts.map +1 -1
  47. package/dist/test-utils/index.d.ts +0 -1
  48. package/dist/test-utils/index.d.ts.map +1 -1
  49. package/dist/test-utils/launchNode.d.ts.map +1 -1
  50. package/dist/test-utils/seedTestWallet.d.ts +1 -1
  51. package/dist/test-utils/seedTestWallet.d.ts.map +1 -1
  52. package/dist/test-utils.global.js +1547 -1085
  53. package/dist/test-utils.global.js.map +1 -1
  54. package/dist/test-utils.js +804 -608
  55. package/dist/test-utils.js.map +1 -1
  56. package/dist/test-utils.mjs +641 -442
  57. package/dist/test-utils.mjs.map +1 -1
  58. package/dist/wallet/base-wallet-unlocked.d.ts +2 -2
  59. package/dist/wallet/base-wallet-unlocked.d.ts.map +1 -1
  60. package/package.json +16 -16
  61. package/dist/providers/transaction-request/helpers.d.ts +0 -10
  62. package/dist/providers/transaction-request/helpers.d.ts.map +0 -1
  63. package/dist/test-utils/resources.d.ts +0 -4
  64. package/dist/test-utils/resources.d.ts.map +0 -1
  65. package/dist/test-utils/transactionRequest.d.ts +0 -5
  66. package/dist/test-utils/transactionRequest.d.ts.map +0 -1
@@ -280,7 +280,7 @@
280
280
  }
281
281
  return num !== null && typeof num === "object" && num.constructor.wordSize === BN2.wordSize && Array.isArray(num.words);
282
282
  };
283
- BN2.max = function max2(left, right) {
283
+ BN2.max = function max(left, right) {
284
284
  if (left.cmp(right) > 0)
285
285
  return left;
286
286
  return right;
@@ -5104,7 +5104,7 @@
5104
5104
  function isBlob(obj) {
5105
5105
  return typeof obj === "object" && typeof obj.arrayBuffer === "function" && typeof obj.type === "string" && typeof obj.stream === "function" && typeof obj.constructor === "function" && typeof obj.constructor.name === "string" && /^(Blob|File)$/.test(obj.constructor.name) && /^(Blob|File)$/.test(obj[Symbol.toStringTag]);
5106
5106
  }
5107
- function clone(instance) {
5107
+ function clone3(instance) {
5108
5108
  let p1, p2;
5109
5109
  let body = instance.body;
5110
5110
  if (instance.bodyUsed) {
@@ -6038,7 +6038,7 @@
6038
6038
  * @return Response
6039
6039
  */
6040
6040
  clone() {
6041
- return new Response2(clone(this), {
6041
+ return new Response2(clone3(this), {
6042
6042
  url: this.url,
6043
6043
  status: this.status,
6044
6044
  statusText: this.statusText,
@@ -6088,7 +6088,7 @@
6088
6088
  if ((init.body != null || isRequest(input) && input.body !== null) && (method === "GET" || method === "HEAD")) {
6089
6089
  throw new TypeError("Request with GET/HEAD method cannot have body");
6090
6090
  }
6091
- let inputBody = init.body != null ? init.body : isRequest(input) && input.body !== null ? clone(input) : null;
6091
+ let inputBody = init.body != null ? init.body : isRequest(input) && input.body !== null ? clone3(input) : null;
6092
6092
  Body.call(this, inputBody, {
6093
6093
  timeout: init.timeout || input.timeout || 0,
6094
6094
  size: init.size || input.size || 0
@@ -31914,8 +31914,8 @@ spurious results.`);
31914
31914
  // ../versions/dist/index.mjs
31915
31915
  function getBuiltinVersions() {
31916
31916
  return {
31917
- FORC: "0.49.3",
31918
- FUEL_CORE: "0.22.1",
31917
+ FORC: "0.51.1",
31918
+ FUEL_CORE: "0.24.2",
31919
31919
  FUELS: "0.81.0"
31920
31920
  };
31921
31921
  }
@@ -32193,524 +32193,757 @@ This unreleased fuel-core build may include features and updates not yet support
32193
32193
  __publicField3(DateTime, "TAI64_NULL", "");
32194
32194
  var chainConfig_default = {
32195
32195
  chain_name: "local_testnet",
32196
- block_gas_limit: 5e9,
32197
- initial_state: {
32198
- coins: [
32199
- {
32200
- owner: "0x94ffcc53b892684acefaebc8a3d4a595e528a8cf664eeb3ef36f1020b0809d0d",
32201
- amount: "0xFFFFFFFFFFFFFFFF",
32202
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32203
- },
32204
- {
32205
- owner: "0x09c0b2d1a486c439a87bcba6b46a7a1a23f3897cc83a94521a96da5c23bc58db",
32206
- amount: "0xFFFFFFFFFFFFFFFF",
32207
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32208
- },
32209
- {
32210
- owner: "0x09c0b2d1a486c439a87bcba6b46a7a1a23f3897cc83a94521a96da5c23bc58db",
32211
- amount: "0xFFFFFFFFFFFFFFFF",
32212
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32213
- },
32214
- {
32215
- owner: "0x09c0b2d1a486c439a87bcba6b46a7a1a23f3897cc83a94521a96da5c23bc58db",
32216
- amount: "0xFFFFFFFFFFFFFFFF",
32217
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32218
- },
32219
- {
32220
- owner: "0x5d99ee966b42cd8fc7bdd1364b389153a9e78b42b7d4a691470674e817888d4e",
32221
- amount: "0xFFFFFFFFFFFFFFFF",
32222
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32223
- },
32224
- {
32225
- owner: "0x5d99ee966b42cd8fc7bdd1364b389153a9e78b42b7d4a691470674e817888d4e",
32226
- amount: "0xFFFFFFFFFFFFFFFF",
32227
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32228
- },
32229
- {
32230
- owner: "0x5d99ee966b42cd8fc7bdd1364b389153a9e78b42b7d4a691470674e817888d4e",
32231
- amount: "0xFFFFFFFFFFFFFFFF",
32232
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32233
- },
32234
- {
32235
- owner: "0xbdaad6a89e073e177895b3e5a9ccd15806749eda134a6438dae32fc5b6601f3f",
32236
- amount: "0xFFFFFFFFFFFFFFFF",
32237
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32238
- },
32239
- {
32240
- owner: "0xbdaad6a89e073e177895b3e5a9ccd15806749eda134a6438dae32fc5b6601f3f",
32241
- amount: "0xFFFFFFFFFFFFFFFF",
32242
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32243
- },
32244
- {
32245
- owner: "0xbdaad6a89e073e177895b3e5a9ccd15806749eda134a6438dae32fc5b6601f3f",
32246
- amount: "0xFFFFFFFFFFFFFFFF",
32247
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32248
- },
32249
- {
32250
- owner: "0x95a7aa6cc32743f8706c40ef49a7423b47da763bb4bbc055b1f07254dc729036",
32251
- amount: "0xFFFFFFFFFFFFFFFF",
32252
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32253
- },
32254
- {
32255
- owner: "0x95a7aa6cc32743f8706c40ef49a7423b47da763bb4bbc055b1f07254dc729036",
32256
- amount: "0xFFFFFFFFFFFFFFFF",
32257
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32258
- },
32259
- {
32260
- owner: "0x95a7aa6cc32743f8706c40ef49a7423b47da763bb4bbc055b1f07254dc729036",
32261
- amount: "0xFFFFFFFFFFFFFFFF",
32262
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32263
- },
32264
- {
32265
- owner: "0xcee104acd38b940c8f1c62c6d7ea00a0ad2241d6dee0509a4bf27297508870d3",
32266
- amount: "0xFFFFFFFFFFFFFFFF",
32267
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32268
- },
32269
- {
32270
- owner: "0xcee104acd38b940c8f1c62c6d7ea00a0ad2241d6dee0509a4bf27297508870d3",
32271
- amount: "0xFFFFFFFFFFFFFFFF",
32272
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32273
- },
32274
- {
32275
- owner: "0xcee104acd38b940c8f1c62c6d7ea00a0ad2241d6dee0509a4bf27297508870d3",
32276
- amount: "0xFFFFFFFFFFFFFFFF",
32277
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32278
- },
32279
- {
32280
- owner: "0x7e3626e306588eba79cafab73f0709e55ab8f4bdfe8c8b75034a430fc56ece89",
32281
- amount: "0xFFFFFFFFFFFFFFFF",
32282
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32283
- },
32284
- {
32285
- owner: "0x7e3626e306588eba79cafab73f0709e55ab8f4bdfe8c8b75034a430fc56ece89",
32286
- amount: "0xFFFFFFFFFFFFFFFF",
32287
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32288
- },
32289
- {
32290
- owner: "0x7e3626e306588eba79cafab73f0709e55ab8f4bdfe8c8b75034a430fc56ece89",
32291
- amount: "0xFFFFFFFFFFFFFFFF",
32292
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32293
- },
32294
- {
32295
- owner: "0x1c31df52b6df56407dd95f83082e8beb9cfc9532ac111d5bd8491651d95ba775",
32296
- amount: "0xFFFFFFFFFFFFFFFF",
32297
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32298
- },
32299
- {
32300
- owner: "0x1c31df52b6df56407dd95f83082e8beb9cfc9532ac111d5bd8491651d95ba775",
32301
- amount: "0xFFFFFFFFFFFFFFFF",
32302
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32303
- },
32304
- {
32305
- owner: "0x1c31df52b6df56407dd95f83082e8beb9cfc9532ac111d5bd8491651d95ba775",
32306
- amount: "0xFFFFFFFFFFFFFFFF",
32307
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32308
- },
32309
- {
32310
- owner: "0x09dd7a49174d6fcc9f4c6f7942c18060a935ddd03ee69b594189b8c3581276ea",
32311
- amount: "0xFFFFFFFFFFFFFFFF",
32312
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32313
- },
32314
- {
32315
- owner: "0x09dd7a49174d6fcc9f4c6f7942c18060a935ddd03ee69b594189b8c3581276ea",
32316
- amount: "0xFFFFFFFFFFFFFFFF",
32317
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32318
- },
32319
- {
32320
- owner: "0x09dd7a49174d6fcc9f4c6f7942c18060a935ddd03ee69b594189b8c3581276ea",
32321
- amount: "0xFFFFFFFFFFFFFFFF",
32322
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32323
- },
32324
- {
32325
- owner: "0x86604282dc604481b809845be49667607c470644f6822fc01eb0d22f167e08cf",
32326
- amount: "0xFFFFFFFFFFFFFFFF",
32327
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32328
- },
32329
- {
32330
- owner: "0x86604282dc604481b809845be49667607c470644f6822fc01eb0d22f167e08cf",
32331
- amount: "0xFFFFFFFFFFFFFFFF",
32332
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32333
- },
32334
- {
32335
- owner: "0x86604282dc604481b809845be49667607c470644f6822fc01eb0d22f167e08cf",
32336
- amount: "0xFFFFFFFFFFFFFFFF",
32337
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32338
- },
32339
- {
32340
- owner: "0xbca334a06d19db5041c78fe2f465b07be5bec828f38b7796b2877e7d1542c950",
32341
- amount: "0xFFFFFFFFFFFFFFFF",
32342
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32343
- },
32344
- {
32345
- owner: "0xbca334a06d19db5041c78fe2f465b07be5bec828f38b7796b2877e7d1542c950",
32346
- amount: "0xFFFFFFFFFFFFFFFF",
32347
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32348
- },
32349
- {
32350
- owner: "0xbca334a06d19db5041c78fe2f465b07be5bec828f38b7796b2877e7d1542c950",
32351
- amount: "0xFFFFFFFFFFFFFFFF",
32352
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32353
- },
32354
- {
32355
- owner: "0xbd9a1dc8d3ec3521c43f6c2c01611b4d0204c7610204ff0178488c8738a30bd2",
32356
- amount: "0xFFFFFFFFFFFFFFFF",
32357
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32358
- },
32359
- {
32360
- owner: "0xbd9a1dc8d3ec3521c43f6c2c01611b4d0204c7610204ff0178488c8738a30bd2",
32361
- amount: "0xFFFFFFFFFFFFFFFF",
32362
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32363
- },
32364
- {
32365
- owner: "0xbd9a1dc8d3ec3521c43f6c2c01611b4d0204c7610204ff0178488c8738a30bd2",
32366
- amount: "0xFFFFFFFFFFFFFFFF",
32367
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32368
- },
32369
- {
32370
- owner: "0xb32197cf75efe05bf453c26178139f09b391582065549c1422bc92555ecffb64",
32371
- amount: "0xFFFFFFFFFFFFFFFF",
32372
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32373
- },
32374
- {
32375
- owner: "0xb32197cf75efe05bf453c26178139f09b391582065549c1422bc92555ecffb64",
32376
- amount: "0xFFFFFFFFFFFFFFFF",
32377
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32378
- },
32379
- {
32380
- owner: "0xb32197cf75efe05bf453c26178139f09b391582065549c1422bc92555ecffb64",
32381
- amount: "0xFFFFFFFFFFFFFFFF",
32382
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32383
- },
32384
- {
32385
- owner: "0x3b24509ed4ab3c7959f5c9391c1445c59290cdb5f13d6f780922f376b7029f30",
32386
- amount: "0xFFFFFFFFFFFFFFFF",
32387
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32388
- },
32389
- {
32390
- owner: "0x3b24509ed4ab3c7959f5c9391c1445c59290cdb5f13d6f780922f376b7029f30",
32391
- amount: "0xFFFFFFFFFFFFFFFF",
32392
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32393
- },
32394
- {
32395
- owner: "0x3b24509ed4ab3c7959f5c9391c1445c59290cdb5f13d6f780922f376b7029f30",
32396
- amount: "0xFFFFFFFFFFFFFFFF",
32397
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32398
- },
32399
- {
32400
- owner: "0x77c6f40b7da70d885f68efaad7c661327482a63ea10dcb4271de819438254ae1",
32401
- amount: "0xFFFFFFFFFFFFFFFF",
32402
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32403
- },
32404
- {
32405
- owner: "0x77c6f40b7da70d885f68efaad7c661327482a63ea10dcb4271de819438254ae1",
32406
- amount: "0xFFFFFFFFFFFFFFFF",
32407
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32408
- },
32409
- {
32410
- owner: "0x77c6f40b7da70d885f68efaad7c661327482a63ea10dcb4271de819438254ae1",
32411
- amount: "0xFFFFFFFFFFFFFFFF",
32412
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32413
- },
32414
- {
32415
- owner: "0x6a2c4691c547c43924650dbd30620b184b5fe3fb6dbe5c4446110b08f6f405bf",
32416
- amount: "0xFFFFFFFFFFFFFFFF",
32417
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32418
- },
32419
- {
32420
- owner: "0x6a2c4691c547c43924650dbd30620b184b5fe3fb6dbe5c4446110b08f6f405bf",
32421
- amount: "0xFFFFFFFFFFFFFFFF",
32422
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32423
- },
32424
- {
32425
- owner: "0x6a2c4691c547c43924650dbd30620b184b5fe3fb6dbe5c4446110b08f6f405bf",
32426
- amount: "0xFFFFFFFFFFFFFFFF",
32427
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32428
- },
32429
- {
32430
- owner: "0x49075a7538e2c88ebe1926ce4d898198a2a4e790d14512943a9864bc536b3c82",
32431
- amount: "0xFFFFFFFFFFFFFFFF",
32432
- asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32433
- },
32434
- {
32435
- owner: "0x49075a7538e2c88ebe1926ce4d898198a2a4e790d14512943a9864bc536b3c82",
32436
- amount: "0xFFFFFFFFFFFFFFFF",
32437
- asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32438
- },
32439
- {
32440
- owner: "0x49075a7538e2c88ebe1926ce4d898198a2a4e790d14512943a9864bc536b3c82",
32441
- amount: "0xFFFFFFFFFFFFFFFF",
32442
- asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32443
- }
32444
- ],
32445
- messages: [
32446
- {
32447
- sender: "0xc43454aa38dd91f88109a4b7aef5efb96ce34e3f24992fe0f81d233ca686f80f",
32448
- recipient: "0x69a2b736b60159b43bb8a4f98c0589f6da5fa3a3d101e8e269c499eb942753ba",
32449
- nonce: "0101010101010101010101010101010101010101010101010101010101010101",
32450
- amount: "0x000000000000FFFF",
32451
- data: "",
32452
- da_height: "0x00"
32196
+ consensus_parameters: {
32197
+ V1: {
32198
+ tx_params: {
32199
+ V1: {
32200
+ max_inputs: 255,
32201
+ max_outputs: 255,
32202
+ max_witnesses: 255,
32203
+ max_gas_per_tx: 3e7,
32204
+ max_size: 112640
32205
+ }
32206
+ },
32207
+ predicate_params: {
32208
+ V1: {
32209
+ max_predicate_length: 102400,
32210
+ max_predicate_data_length: 102400,
32211
+ max_message_data_length: 102400,
32212
+ max_gas_per_predicate: 3e7
32213
+ }
32214
+ },
32215
+ script_params: {
32216
+ V1: {
32217
+ max_script_length: 102400,
32218
+ max_script_data_length: 102400
32219
+ }
32220
+ },
32221
+ contract_params: {
32222
+ V1: {
32223
+ contract_max_size: 102400,
32224
+ max_storage_slots: 1760
32225
+ }
32226
+ },
32227
+ fee_params: {
32228
+ V1: {
32229
+ gas_price_factor: 92,
32230
+ gas_per_byte: 63
32231
+ }
32232
+ },
32233
+ chain_id: 0,
32234
+ gas_costs: {
32235
+ V1: {
32236
+ add: 2,
32237
+ addi: 2,
32238
+ aloc: 1,
32239
+ and: 2,
32240
+ andi: 2,
32241
+ bal: 366,
32242
+ bhei: 2,
32243
+ bhsh: 2,
32244
+ burn: 33949,
32245
+ cb: 2,
32246
+ cfei: 2,
32247
+ cfsi: 2,
32248
+ div: 2,
32249
+ divi: 2,
32250
+ eck1: 3347,
32251
+ ecr1: 46165,
32252
+ ed19: 4210,
32253
+ eq: 2,
32254
+ exp: 2,
32255
+ expi: 2,
32256
+ flag: 1,
32257
+ gm: 2,
32258
+ gt: 2,
32259
+ gtf: 16,
32260
+ ji: 2,
32261
+ jmp: 2,
32262
+ jne: 2,
32263
+ jnei: 2,
32264
+ jnzi: 2,
32265
+ jmpf: 2,
32266
+ jmpb: 2,
32267
+ jnzf: 2,
32268
+ jnzb: 2,
32269
+ jnef: 2,
32270
+ jneb: 2,
32271
+ lb: 2,
32272
+ log: 754,
32273
+ lt: 2,
32274
+ lw: 2,
32275
+ mint: 35718,
32276
+ mlog: 2,
32277
+ mod: 2,
32278
+ modi: 2,
32279
+ move: 2,
32280
+ movi: 2,
32281
+ mroo: 5,
32282
+ mul: 2,
32283
+ muli: 2,
32284
+ mldv: 4,
32285
+ noop: 1,
32286
+ not: 2,
32287
+ or: 2,
32288
+ ori: 2,
32289
+ poph: 3,
32290
+ popl: 3,
32291
+ pshh: 4,
32292
+ pshl: 4,
32293
+ ret_contract: 733,
32294
+ rvrt_contract: 722,
32295
+ sb: 2,
32296
+ sll: 2,
32297
+ slli: 2,
32298
+ srl: 2,
32299
+ srli: 2,
32300
+ srw: 253,
32301
+ sub: 2,
32302
+ subi: 2,
32303
+ sw: 2,
32304
+ sww: 29053,
32305
+ time: 79,
32306
+ tr: 46242,
32307
+ tro: 33251,
32308
+ wdcm: 3,
32309
+ wqcm: 3,
32310
+ wdop: 3,
32311
+ wqop: 3,
32312
+ wdml: 3,
32313
+ wqml: 4,
32314
+ wddv: 5,
32315
+ wqdv: 7,
32316
+ wdmd: 11,
32317
+ wqmd: 18,
32318
+ wdam: 9,
32319
+ wqam: 12,
32320
+ wdmm: 11,
32321
+ wqmm: 11,
32322
+ xor: 2,
32323
+ xori: 2,
32324
+ call: {
32325
+ LightOperation: {
32326
+ base: 21687,
32327
+ units_per_gas: 4
32328
+ }
32329
+ },
32330
+ ccp: {
32331
+ LightOperation: {
32332
+ base: 59,
32333
+ units_per_gas: 20
32334
+ }
32335
+ },
32336
+ croo: {
32337
+ LightOperation: {
32338
+ base: 1,
32339
+ units_per_gas: 1
32340
+ }
32341
+ },
32342
+ csiz: {
32343
+ LightOperation: {
32344
+ base: 59,
32345
+ units_per_gas: 195
32346
+ }
32347
+ },
32348
+ k256: {
32349
+ LightOperation: {
32350
+ base: 282,
32351
+ units_per_gas: 3
32352
+ }
32353
+ },
32354
+ ldc: {
32355
+ LightOperation: {
32356
+ base: 45,
32357
+ units_per_gas: 65
32358
+ }
32359
+ },
32360
+ logd: {
32361
+ LightOperation: {
32362
+ base: 1134,
32363
+ units_per_gas: 2
32364
+ }
32365
+ },
32366
+ mcl: {
32367
+ LightOperation: {
32368
+ base: 3,
32369
+ units_per_gas: 523
32370
+ }
32371
+ },
32372
+ mcli: {
32373
+ LightOperation: {
32374
+ base: 3,
32375
+ units_per_gas: 526
32376
+ }
32377
+ },
32378
+ mcp: {
32379
+ LightOperation: {
32380
+ base: 3,
32381
+ units_per_gas: 448
32382
+ }
32383
+ },
32384
+ mcpi: {
32385
+ LightOperation: {
32386
+ base: 7,
32387
+ units_per_gas: 585
32388
+ }
32389
+ },
32390
+ meq: {
32391
+ LightOperation: {
32392
+ base: 11,
32393
+ units_per_gas: 1097
32394
+ }
32395
+ },
32396
+ retd_contract: {
32397
+ LightOperation: {
32398
+ base: 1086,
32399
+ units_per_gas: 2
32400
+ }
32401
+ },
32402
+ s256: {
32403
+ LightOperation: {
32404
+ base: 45,
32405
+ units_per_gas: 3
32406
+ }
32407
+ },
32408
+ scwq: {
32409
+ HeavyOperation: {
32410
+ base: 30375,
32411
+ gas_per_unit: 28628
32412
+ }
32413
+ },
32414
+ smo: {
32415
+ LightOperation: {
32416
+ base: 64196,
32417
+ units_per_gas: 1
32418
+ }
32419
+ },
32420
+ srwq: {
32421
+ HeavyOperation: {
32422
+ base: 262,
32423
+ gas_per_unit: 249
32424
+ }
32425
+ },
32426
+ swwq: {
32427
+ HeavyOperation: {
32428
+ base: 28484,
32429
+ gas_per_unit: 26613
32430
+ }
32431
+ },
32432
+ contract_root: {
32433
+ LightOperation: {
32434
+ base: 45,
32435
+ units_per_gas: 1
32436
+ }
32437
+ },
32438
+ state_root: {
32439
+ HeavyOperation: {
32440
+ base: 350,
32441
+ gas_per_unit: 176
32442
+ }
32443
+ },
32444
+ new_storage_per_byte: 63,
32445
+ vm_initialization: {
32446
+ LightOperation: {
32447
+ base: 1645,
32448
+ units_per_gas: 14
32449
+ }
32450
+ }
32451
+ }
32453
32452
  },
32454
- {
32455
- sender: "0x69a2b736b60159b43bb8a4f98c0589f6da5fa3a3d101e8e269c499eb942753ba",
32456
- recipient: "0xc43454aa38dd91f88109a4b7aef5efb96ce34e3f24992fe0f81d233ca686f80f",
32457
- nonce: "0e1ef2963832068b0e1ef2963832068b0e1ef2963832068b0e1ef2963832068b",
32458
- amount: "0xb04f3c08f59b309e",
32459
- data: "",
32460
- da_height: "0x00"
32461
- }
32462
- ]
32453
+ base_asset_id: "0000000000000000000000000000000000000000000000000000000000000000",
32454
+ block_gas_limit: 3e7,
32455
+ privileged_address: "0000000000000000000000000000000000000000000000000000000000000000"
32456
+ }
32463
32457
  },
32464
- consensus_parameters: {
32465
- tx_params: {
32466
- max_inputs: 255,
32467
- max_outputs: 255,
32468
- max_witnesses: 255,
32469
- max_gas_per_tx: 1e7,
32470
- max_size: 17825792
32458
+ consensus: {
32459
+ PoA: {
32460
+ signing_key: "0x94ffcc53b892684acefaebc8a3d4a595e528a8cf664eeb3ef36f1020b0809d0d"
32461
+ }
32462
+ }
32463
+ };
32464
+ var metadata_default = {
32465
+ chain_config: "chainConfig.json",
32466
+ table_encoding: {
32467
+ Json: {
32468
+ filepath: "stateConfig.json"
32469
+ }
32470
+ }
32471
+ };
32472
+ var stateConfig_default = {
32473
+ coins: [
32474
+ {
32475
+ tx_id: "0x260eabfd50937e92939fd92687e9302a72e91c5065f64f853f2ccbe02396fe09d665",
32476
+ output_index: 0,
32477
+ tx_pointer_block_height: 0,
32478
+ tx_pointer_tx_idx: 0,
32479
+ owner: "0x94ffcc53b892684acefaebc8a3d4a595e528a8cf664eeb3ef36f1020b0809d0d",
32480
+ amount: 18446744073709552e3,
32481
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32471
32482
  },
32472
- predicate_params: {
32473
- max_predicate_length: 1048576,
32474
- max_predicate_data_length: 1048576,
32475
- max_gas_per_predicate: 1e7,
32476
- max_message_data_length: 1048576
32483
+ {
32484
+ tx_id: "0x2a757c2317236f7883ac9bbbf7d402f034e0b725c544ef1c8725b1d2bd960f8c690f",
32485
+ output_index: 0,
32486
+ tx_pointer_block_height: 0,
32487
+ tx_pointer_tx_idx: 0,
32488
+ owner: "0x09c0b2d1a486c439a87bcba6b46a7a1a23f3897cc83a94521a96da5c23bc58db",
32489
+ amount: 18446744073709552e3,
32490
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32477
32491
  },
32478
- script_params: {
32479
- max_script_length: 1048576,
32480
- max_script_data_length: 1048576
32492
+ {
32493
+ tx_id: "0x634ef6cda00bac63992bbde80c6d694d484d58025a5ca0c9c848f0d35a5a3eee74b2",
32494
+ output_index: 0,
32495
+ tx_pointer_block_height: 0,
32496
+ tx_pointer_tx_idx: 0,
32497
+ owner: "0x09c0b2d1a486c439a87bcba6b46a7a1a23f3897cc83a94521a96da5c23bc58db",
32498
+ amount: 18446744073709552e3,
32499
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32481
32500
  },
32482
- contract_params: {
32483
- contract_max_size: 16777216,
32484
- max_storage_slots: 255
32501
+ {
32502
+ tx_id: "0xd3543bb1da137a7987a96a1bb71681fdd195ff25318c0d4a923aa30eb27ffa80bc7b",
32503
+ output_index: 0,
32504
+ tx_pointer_block_height: 0,
32505
+ tx_pointer_tx_idx: 0,
32506
+ owner: "0x09c0b2d1a486c439a87bcba6b46a7a1a23f3897cc83a94521a96da5c23bc58db",
32507
+ amount: 18446744073709552e3,
32508
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32485
32509
  },
32486
- fee_params: {
32487
- gas_price_factor: 92,
32488
- gas_per_byte: 4
32489
- }
32490
- },
32491
- gas_costs: {
32492
- add: 1,
32493
- addi: 1,
32494
- aloc: 1,
32495
- and: 1,
32496
- andi: 1,
32497
- bal: 13,
32498
- bhei: 1,
32499
- bhsh: 1,
32500
- burn: 132,
32501
- cb: 1,
32502
- cfei: 1,
32503
- cfsi: 1,
32504
- croo: 16,
32505
- div: 1,
32506
- divi: 1,
32507
- ecr1: 3e3,
32508
- eck1: 951,
32509
- ed19: 3e3,
32510
- eq: 1,
32511
- exp: 1,
32512
- expi: 1,
32513
- flag: 1,
32514
- gm: 1,
32515
- gt: 1,
32516
- gtf: 1,
32517
- ji: 1,
32518
- jmp: 1,
32519
- jne: 1,
32520
- jnei: 1,
32521
- jnzi: 1,
32522
- jmpf: 1,
32523
- jmpb: 1,
32524
- jnzf: 1,
32525
- jnzb: 1,
32526
- jnef: 1,
32527
- jneb: 1,
32528
- lb: 1,
32529
- log: 9,
32530
- lt: 1,
32531
- lw: 1,
32532
- mint: 135,
32533
- mlog: 1,
32534
- modOp: 1,
32535
- modi: 1,
32536
- moveOp: 1,
32537
- movi: 1,
32538
- mroo: 2,
32539
- mul: 1,
32540
- muli: 1,
32541
- mldv: 1,
32542
- noop: 1,
32543
- not: 1,
32544
- or: 1,
32545
- ori: 1,
32546
- poph: 2,
32547
- popl: 2,
32548
- pshh: 2,
32549
- pshl: 2,
32550
- ret: 13,
32551
- rvrt: 13,
32552
- sb: 1,
32553
- sll: 1,
32554
- slli: 1,
32555
- srl: 1,
32556
- srli: 1,
32557
- srw: 12,
32558
- sub: 1,
32559
- subi: 1,
32560
- sw: 1,
32561
- sww: 67,
32562
- time: 1,
32563
- tr: 105,
32564
- tro: 60,
32565
- wdcm: 1,
32566
- wqcm: 1,
32567
- wdop: 1,
32568
- wqop: 1,
32569
- wdml: 1,
32570
- wqml: 1,
32571
- wddv: 1,
32572
- wqdv: 2,
32573
- wdmd: 3,
32574
- wqmd: 4,
32575
- wdam: 2,
32576
- wqam: 3,
32577
- wdmm: 3,
32578
- wqmm: 3,
32579
- xor: 1,
32580
- xori: 1,
32581
- call: {
32582
- LightOperation: {
32583
- base: 144,
32584
- units_per_gas: 214
32585
- }
32510
+ {
32511
+ tx_id: "0xa4d42cbb02adb32f5f3a9eab33a0ee7bdab8910ad9f615dfc86a7bb9e49a732bc58c",
32512
+ output_index: 0,
32513
+ tx_pointer_block_height: 0,
32514
+ tx_pointer_tx_idx: 0,
32515
+ owner: "0x5d99ee966b42cd8fc7bdd1364b389153a9e78b42b7d4a691470674e817888d4e",
32516
+ amount: 18446744073709552e3,
32517
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32586
32518
  },
32587
- ccp: {
32588
- LightOperation: {
32589
- base: 15,
32590
- units_per_gas: 103
32591
- }
32519
+ {
32520
+ tx_id: "0xc197cb09b1d89a7862b238e9500631bd43f291aadb7ff55c8129335349634e9fde3f",
32521
+ output_index: 0,
32522
+ tx_pointer_block_height: 0,
32523
+ tx_pointer_tx_idx: 0,
32524
+ owner: "0x5d99ee966b42cd8fc7bdd1364b389153a9e78b42b7d4a691470674e817888d4e",
32525
+ amount: 18446744073709552e3,
32526
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32592
32527
  },
32593
- csiz: {
32594
- LightOperation: {
32595
- base: 17,
32596
- units_per_gas: 790
32597
- }
32528
+ {
32529
+ tx_id: "0x4c4fc2451b9a9b16c520c1b89ec8968ce46823dd0396d84f7e3155861352fdce12c5",
32530
+ output_index: 0,
32531
+ tx_pointer_block_height: 0,
32532
+ tx_pointer_tx_idx: 0,
32533
+ owner: "0x5d99ee966b42cd8fc7bdd1364b389153a9e78b42b7d4a691470674e817888d4e",
32534
+ amount: 18446744073709552e3,
32535
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32598
32536
  },
32599
- k256: {
32600
- LightOperation: {
32601
- base: 11,
32602
- units_per_gas: 214
32603
- }
32537
+ {
32538
+ tx_id: "0x68df8f08555086a1ab45591e6fe4bf2f538bcb80dd519108030b7e886d6a230c2531",
32539
+ output_index: 0,
32540
+ tx_pointer_block_height: 0,
32541
+ tx_pointer_tx_idx: 0,
32542
+ owner: "0xbdaad6a89e073e177895b3e5a9ccd15806749eda134a6438dae32fc5b6601f3f",
32543
+ amount: 18446744073709552e3,
32544
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32604
32545
  },
32605
- ldc: {
32606
- LightOperation: {
32607
- base: 15,
32608
- units_per_gas: 272
32609
- }
32546
+ {
32547
+ tx_id: "0x1b9bdaa290518373eb905e45ce7fcb89acedd24341ca7749ad47a938e4bf3ca9b7ce",
32548
+ output_index: 0,
32549
+ tx_pointer_block_height: 0,
32550
+ tx_pointer_tx_idx: 0,
32551
+ owner: "0xbdaad6a89e073e177895b3e5a9ccd15806749eda134a6438dae32fc5b6601f3f",
32552
+ amount: 18446744073709552e3,
32553
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32610
32554
  },
32611
- logd: {
32612
- LightOperation: {
32613
- base: 26,
32614
- units_per_gas: 64
32615
- }
32555
+ {
32556
+ tx_id: "0xa5a2e9db3d1285337fe1183dc1eabe8f9cdcd470daf95cd5c522bbae292f53977f26",
32557
+ output_index: 0,
32558
+ tx_pointer_block_height: 0,
32559
+ tx_pointer_tx_idx: 0,
32560
+ owner: "0xbdaad6a89e073e177895b3e5a9ccd15806749eda134a6438dae32fc5b6601f3f",
32561
+ amount: 18446744073709552e3,
32562
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32616
32563
  },
32617
- mcl: {
32618
- LightOperation: {
32619
- base: 1,
32620
- units_per_gas: 3333
32621
- }
32564
+ {
32565
+ tx_id: "0x13b685a1ea7c56309a92d69dd7e4808987ec90d62a1f9c9f2ec18e54746855c8c93c",
32566
+ output_index: 0,
32567
+ tx_pointer_block_height: 0,
32568
+ tx_pointer_tx_idx: 0,
32569
+ owner: "0x95a7aa6cc32743f8706c40ef49a7423b47da763bb4bbc055b1f07254dc729036",
32570
+ amount: 18446744073709552e3,
32571
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32622
32572
  },
32623
- mcli: {
32624
- LightOperation: {
32625
- base: 1,
32626
- units_per_gas: 3333
32627
- }
32573
+ {
32574
+ tx_id: "0xf8f00a234cf3fbab86befc3fd9346d7fd1ac085233c9cb58c7447f30c75cbf87ed38",
32575
+ output_index: 0,
32576
+ tx_pointer_block_height: 0,
32577
+ tx_pointer_tx_idx: 0,
32578
+ owner: "0x95a7aa6cc32743f8706c40ef49a7423b47da763bb4bbc055b1f07254dc729036",
32579
+ amount: 18446744073709552e3,
32580
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32628
32581
  },
32629
- mcp: {
32630
- LightOperation: {
32631
- base: 1,
32632
- units_per_gas: 2e3
32633
- }
32582
+ {
32583
+ tx_id: "0x2a36c870f624b60fbd6f2b71332ca7f704c69296ceae4ddbf3a8ede79408088934be",
32584
+ output_index: 0,
32585
+ tx_pointer_block_height: 0,
32586
+ tx_pointer_tx_idx: 0,
32587
+ owner: "0x95a7aa6cc32743f8706c40ef49a7423b47da763bb4bbc055b1f07254dc729036",
32588
+ amount: 18446744073709552e3,
32589
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32634
32590
  },
32635
- mcpi: {
32636
- LightOperation: {
32637
- base: 3,
32638
- units_per_gas: 2e3
32639
- }
32591
+ {
32592
+ tx_id: "0x9cd180d41e67a422da8a7683f036b463a7ed7efc0de31c1692adac90decbfebce78c",
32593
+ output_index: 0,
32594
+ tx_pointer_block_height: 0,
32595
+ tx_pointer_tx_idx: 0,
32596
+ owner: "0xcee104acd38b940c8f1c62c6d7ea00a0ad2241d6dee0509a4bf27297508870d3",
32597
+ amount: 18446744073709552e3,
32598
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32640
32599
  },
32641
- meq: {
32642
- LightOperation: {
32643
- base: 1,
32644
- units_per_gas: 2500
32645
- }
32600
+ {
32601
+ tx_id: "0xfeb4f2388fa22e6613ff85cf4e655f58acdfaa6299eba7f93b812cd1f0d7bbac48f0",
32602
+ output_index: 0,
32603
+ tx_pointer_block_height: 0,
32604
+ tx_pointer_tx_idx: 0,
32605
+ owner: "0xcee104acd38b940c8f1c62c6d7ea00a0ad2241d6dee0509a4bf27297508870d3",
32606
+ amount: 18446744073709552e3,
32607
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32646
32608
  },
32647
- retd: {
32648
- LightOperation: {
32649
- base: 29,
32650
- units_per_gas: 62
32651
- }
32609
+ {
32610
+ tx_id: "0xc4d20299f43358dc32ab853f6631340b09278511b6adbaf34597ade6ef37efd018f1",
32611
+ output_index: 0,
32612
+ tx_pointer_block_height: 0,
32613
+ tx_pointer_tx_idx: 0,
32614
+ owner: "0xcee104acd38b940c8f1c62c6d7ea00a0ad2241d6dee0509a4bf27297508870d3",
32615
+ amount: 18446744073709552e3,
32616
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32652
32617
  },
32653
- s256: {
32654
- LightOperation: {
32655
- base: 2,
32656
- units_per_gas: 214
32657
- }
32618
+ {
32619
+ tx_id: "0x437291414110b0aebaa8be5c0d9ff1e97d1130a24a6c9e028f2b1f6b0576be6aa961",
32620
+ output_index: 0,
32621
+ tx_pointer_block_height: 0,
32622
+ tx_pointer_tx_idx: 0,
32623
+ owner: "0x7e3626e306588eba79cafab73f0709e55ab8f4bdfe8c8b75034a430fc56ece89",
32624
+ amount: 18446744073709552e3,
32625
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32658
32626
  },
32659
- scwq: {
32660
- LightOperation: {
32661
- base: 13,
32662
- units_per_gas: 5
32663
- }
32627
+ {
32628
+ tx_id: "0x28131b9acc90c2058ee14f4094a474146ba5b779cb9021867164b3d41abad3d047a7",
32629
+ output_index: 0,
32630
+ tx_pointer_block_height: 0,
32631
+ tx_pointer_tx_idx: 0,
32632
+ owner: "0x7e3626e306588eba79cafab73f0709e55ab8f4bdfe8c8b75034a430fc56ece89",
32633
+ amount: 18446744073709552e3,
32634
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32664
32635
  },
32665
- smo: {
32666
- LightOperation: {
32667
- base: 209,
32668
- units_per_gas: 55
32669
- }
32636
+ {
32637
+ tx_id: "0x033bb5f9b0e4f530d50af3a0f12dd510f799af495ef88baea3cf854a37da728d214b",
32638
+ output_index: 0,
32639
+ tx_pointer_block_height: 0,
32640
+ tx_pointer_tx_idx: 0,
32641
+ owner: "0x7e3626e306588eba79cafab73f0709e55ab8f4bdfe8c8b75034a430fc56ece89",
32642
+ amount: 18446744073709552e3,
32643
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32670
32644
  },
32671
- srwq: {
32672
- LightOperation: {
32673
- base: 47,
32674
- units_per_gas: 5
32675
- }
32645
+ {
32646
+ tx_id: "0x460591398552eca338dd9577f362b91b0f9297f308258734870350004dcc303c67e9",
32647
+ output_index: 0,
32648
+ tx_pointer_block_height: 0,
32649
+ tx_pointer_tx_idx: 0,
32650
+ owner: "0x1c31df52b6df56407dd95f83082e8beb9cfc9532ac111d5bd8491651d95ba775",
32651
+ amount: 18446744073709552e3,
32652
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32676
32653
  },
32677
- swwq: {
32678
- LightOperation: {
32679
- base: 44,
32680
- units_per_gas: 5
32681
- }
32654
+ {
32655
+ tx_id: "0x447a7c37aee972dcba72f05255c5145dd63125f0fc46ef98c216f775ee0421e23d2b",
32656
+ output_index: 0,
32657
+ tx_pointer_block_height: 0,
32658
+ tx_pointer_tx_idx: 0,
32659
+ owner: "0x1c31df52b6df56407dd95f83082e8beb9cfc9532ac111d5bd8491651d95ba775",
32660
+ amount: 18446744073709552e3,
32661
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32682
32662
  },
32683
- contract_root: {
32684
- LightOperation: {
32685
- base: 75,
32686
- units_per_gas: 1
32687
- }
32663
+ {
32664
+ tx_id: "0xf4a5d727606260c7ac6333fa89e7aef474df8a13326716d4d02f6392ebb7b997d268",
32665
+ output_index: 0,
32666
+ tx_pointer_block_height: 0,
32667
+ tx_pointer_tx_idx: 0,
32668
+ owner: "0x1c31df52b6df56407dd95f83082e8beb9cfc9532ac111d5bd8491651d95ba775",
32669
+ amount: 18446744073709552e3,
32670
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32688
32671
  },
32689
- state_root: {
32690
- LightOperation: {
32691
- base: 412,
32692
- units_per_gas: 1
32693
- }
32672
+ {
32673
+ tx_id: "0x25a49b0731bf610f6706aa9e9e96e5967f7c50f4302a3c75d7c8141595896551c18d",
32674
+ output_index: 0,
32675
+ tx_pointer_block_height: 0,
32676
+ tx_pointer_tx_idx: 0,
32677
+ owner: "0x09dd7a49174d6fcc9f4c6f7942c18060a935ddd03ee69b594189b8c3581276ea",
32678
+ amount: 18446744073709552e3,
32679
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32694
32680
  },
32695
- vm_initialization: {
32696
- HeavyOperation: {
32697
- base: 2e3,
32698
- gas_per_unit: 0
32699
- }
32681
+ {
32682
+ tx_id: "0x0a6e3585881ef2edf3f7727762799089dc0b5923e8b3718b49044dd9ddcb33b68459",
32683
+ output_index: 0,
32684
+ tx_pointer_block_height: 0,
32685
+ tx_pointer_tx_idx: 0,
32686
+ owner: "0x09dd7a49174d6fcc9f4c6f7942c18060a935ddd03ee69b594189b8c3581276ea",
32687
+ amount: 18446744073709552e3,
32688
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32700
32689
  },
32701
- new_storage_per_byte: 1
32702
- },
32703
- consensus: {
32704
- PoA: {
32705
- signing_key: "0x94ffcc53b892684acefaebc8a3d4a595e528a8cf664eeb3ef36f1020b0809d0d"
32690
+ {
32691
+ tx_id: "0xf73bbe0635f7b6d59a090a21d87288b82164d0f6101da830ce64eff64a2d2ff2ac37",
32692
+ output_index: 0,
32693
+ tx_pointer_block_height: 0,
32694
+ tx_pointer_tx_idx: 0,
32695
+ owner: "0x09dd7a49174d6fcc9f4c6f7942c18060a935ddd03ee69b594189b8c3581276ea",
32696
+ amount: 18446744073709552e3,
32697
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32698
+ },
32699
+ {
32700
+ tx_id: "0x6cc44cb8d2a6462a591a77b6b9917eb6b22ad80d23d3cfd4f94c9da49c14b3cbac6e",
32701
+ output_index: 0,
32702
+ tx_pointer_block_height: 0,
32703
+ tx_pointer_tx_idx: 0,
32704
+ owner: "0x86604282dc604481b809845be49667607c470644f6822fc01eb0d22f167e08cf",
32705
+ amount: 18446744073709552e3,
32706
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32707
+ },
32708
+ {
32709
+ tx_id: "0xbf2305d284ea95227040df4cc727156cccc2ca6aa3b92ed86fea4db1c37e5905f926",
32710
+ output_index: 0,
32711
+ tx_pointer_block_height: 0,
32712
+ tx_pointer_tx_idx: 0,
32713
+ owner: "0x86604282dc604481b809845be49667607c470644f6822fc01eb0d22f167e08cf",
32714
+ amount: 18446744073709552e3,
32715
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32716
+ },
32717
+ {
32718
+ tx_id: "0xf4e1c76c72ecae699696f5e7a62ccf1425f7395080d0ca7b25ab63d1f841f425b807",
32719
+ output_index: 0,
32720
+ tx_pointer_block_height: 0,
32721
+ tx_pointer_tx_idx: 0,
32722
+ owner: "0x86604282dc604481b809845be49667607c470644f6822fc01eb0d22f167e08cf",
32723
+ amount: 18446744073709552e3,
32724
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32725
+ },
32726
+ {
32727
+ tx_id: "0x619c80ee9f4c27c2e134cec6c67bdb268ce7fb1d2ac229ca2a44ec7ac88b2da99669",
32728
+ output_index: 0,
32729
+ tx_pointer_block_height: 0,
32730
+ tx_pointer_tx_idx: 0,
32731
+ owner: "0xbca334a06d19db5041c78fe2f465b07be5bec828f38b7796b2877e7d1542c950",
32732
+ amount: 18446744073709552e3,
32733
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32734
+ },
32735
+ {
32736
+ tx_id: "0x978d5b6be047ffbf1474dc376a6baa33264629b809e4a8210d11aaa805ec6451585d",
32737
+ output_index: 0,
32738
+ tx_pointer_block_height: 0,
32739
+ tx_pointer_tx_idx: 0,
32740
+ owner: "0xbca334a06d19db5041c78fe2f465b07be5bec828f38b7796b2877e7d1542c950",
32741
+ amount: 18446744073709552e3,
32742
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32743
+ },
32744
+ {
32745
+ tx_id: "0x673ba12fca6e52429896096262b8c59b61751976e552649fb1fe7369488fc10aa83c",
32746
+ output_index: 0,
32747
+ tx_pointer_block_height: 0,
32748
+ tx_pointer_tx_idx: 0,
32749
+ owner: "0xbca334a06d19db5041c78fe2f465b07be5bec828f38b7796b2877e7d1542c950",
32750
+ amount: 18446744073709552e3,
32751
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32752
+ },
32753
+ {
32754
+ tx_id: "0xc42a165104b9fcfa4a9ebffc707781ace233f1c0609c24c36a5c4bfcd407480ddb6c",
32755
+ output_index: 0,
32756
+ tx_pointer_block_height: 0,
32757
+ tx_pointer_tx_idx: 0,
32758
+ owner: "0xbd9a1dc8d3ec3521c43f6c2c01611b4d0204c7610204ff0178488c8738a30bd2",
32759
+ amount: 18446744073709552e3,
32760
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32761
+ },
32762
+ {
32763
+ tx_id: "0xb353fbcd94abba347f3ba25e17744e98da26e608ebccbbbd2e9d004997644bdf993c",
32764
+ output_index: 0,
32765
+ tx_pointer_block_height: 0,
32766
+ tx_pointer_tx_idx: 0,
32767
+ owner: "0xbd9a1dc8d3ec3521c43f6c2c01611b4d0204c7610204ff0178488c8738a30bd2",
32768
+ amount: 18446744073709552e3,
32769
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32770
+ },
32771
+ {
32772
+ tx_id: "0xc34a6fcb241dec82f885019caf5e14bb6708b435afebfef0037ac447fbb6d30378a3",
32773
+ output_index: 0,
32774
+ tx_pointer_block_height: 0,
32775
+ tx_pointer_tx_idx: 0,
32776
+ owner: "0xbd9a1dc8d3ec3521c43f6c2c01611b4d0204c7610204ff0178488c8738a30bd2",
32777
+ amount: 18446744073709552e3,
32778
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32779
+ },
32780
+ {
32781
+ tx_id: "0x421dfb5811c905724f2f4c6370cd15eaeb590ddeb966f9a4b9f8d65991dfe5142e12",
32782
+ output_index: 0,
32783
+ tx_pointer_block_height: 0,
32784
+ tx_pointer_tx_idx: 0,
32785
+ owner: "0xb32197cf75efe05bf453c26178139f09b391582065549c1422bc92555ecffb64",
32786
+ amount: 18446744073709552e3,
32787
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32788
+ },
32789
+ {
32790
+ tx_id: "0xa952c0487eefac5dda612011c4c82554c8660834461b9b815c6ae257b56b68005235",
32791
+ output_index: 0,
32792
+ tx_pointer_block_height: 0,
32793
+ tx_pointer_tx_idx: 0,
32794
+ owner: "0xb32197cf75efe05bf453c26178139f09b391582065549c1422bc92555ecffb64",
32795
+ amount: 18446744073709552e3,
32796
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32797
+ },
32798
+ {
32799
+ tx_id: "0xebaccf91b3b213341d047b6e6af214f1f9729b3d6dadf9c1918a9fe412486af871db",
32800
+ output_index: 0,
32801
+ tx_pointer_block_height: 0,
32802
+ tx_pointer_tx_idx: 0,
32803
+ owner: "0xb32197cf75efe05bf453c26178139f09b391582065549c1422bc92555ecffb64",
32804
+ amount: 18446744073709552e3,
32805
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32806
+ },
32807
+ {
32808
+ tx_id: "0xda6d61c153e7d735954408274f4ffe8459c2dbab720ce22a1ae9ffedd33077b5b19d",
32809
+ output_index: 0,
32810
+ tx_pointer_block_height: 0,
32811
+ tx_pointer_tx_idx: 0,
32812
+ owner: "0x3b24509ed4ab3c7959f5c9391c1445c59290cdb5f13d6f780922f376b7029f30",
32813
+ amount: 18446744073709552e3,
32814
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32815
+ },
32816
+ {
32817
+ tx_id: "0x508871600ef68c4f1e021dd0db219c733107151338aa95de530bd10dc61f6a69c144",
32818
+ output_index: 0,
32819
+ tx_pointer_block_height: 0,
32820
+ tx_pointer_tx_idx: 0,
32821
+ owner: "0x3b24509ed4ab3c7959f5c9391c1445c59290cdb5f13d6f780922f376b7029f30",
32822
+ amount: 18446744073709552e3,
32823
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32824
+ },
32825
+ {
32826
+ tx_id: "0x509994738b4973e2dbbff9596b176a89fb07ee95f0ed575a4fe07a735a2a181f3200",
32827
+ output_index: 0,
32828
+ tx_pointer_block_height: 0,
32829
+ tx_pointer_tx_idx: 0,
32830
+ owner: "0x3b24509ed4ab3c7959f5c9391c1445c59290cdb5f13d6f780922f376b7029f30",
32831
+ amount: 18446744073709552e3,
32832
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32833
+ },
32834
+ {
32835
+ tx_id: "0x6cc0cb58df0e0606fc85481aaaf5f47e145a67240b298c184bcb7fd7367c3bbf9453",
32836
+ output_index: 0,
32837
+ tx_pointer_block_height: 0,
32838
+ tx_pointer_tx_idx: 0,
32839
+ owner: "0x77c6f40b7da70d885f68efaad7c661327482a63ea10dcb4271de819438254ae1",
32840
+ amount: 18446744073709552e3,
32841
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32842
+ },
32843
+ {
32844
+ tx_id: "0x9ddea761afc31516307e1553647ac6cc26d4a82fed9a9e6a03b994cdbf2293b3e3b6",
32845
+ output_index: 0,
32846
+ tx_pointer_block_height: 0,
32847
+ tx_pointer_tx_idx: 0,
32848
+ owner: "0x77c6f40b7da70d885f68efaad7c661327482a63ea10dcb4271de819438254ae1",
32849
+ amount: 18446744073709552e3,
32850
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32851
+ },
32852
+ {
32853
+ tx_id: "0x82dbc478ba63abf28b92d9dce0cb8c2e6c02833d436fe812a33cf78417e4a80c1306",
32854
+ output_index: 0,
32855
+ tx_pointer_block_height: 0,
32856
+ tx_pointer_tx_idx: 0,
32857
+ owner: "0x77c6f40b7da70d885f68efaad7c661327482a63ea10dcb4271de819438254ae1",
32858
+ amount: 18446744073709552e3,
32859
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32860
+ },
32861
+ {
32862
+ tx_id: "0xc3b0cb232c74009fd226a6246403f78bcc33d116579f41d9387c0d76c76942749c7c",
32863
+ output_index: 0,
32864
+ tx_pointer_block_height: 0,
32865
+ tx_pointer_tx_idx: 0,
32866
+ owner: "0x6a2c4691c547c43924650dbd30620b184b5fe3fb6dbe5c4446110b08f6f405bf",
32867
+ amount: 18446744073709552e3,
32868
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32869
+ },
32870
+ {
32871
+ tx_id: "0x708ee45d18f94ab06458712745c92c7b9b6049ba345219d6697eae5208ec0328aeaf",
32872
+ output_index: 0,
32873
+ tx_pointer_block_height: 0,
32874
+ tx_pointer_tx_idx: 0,
32875
+ owner: "0x6a2c4691c547c43924650dbd30620b184b5fe3fb6dbe5c4446110b08f6f405bf",
32876
+ amount: 18446744073709552e3,
32877
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32878
+ },
32879
+ {
32880
+ tx_id: "0xfe26968c44ac5becc608ce543075ae9e677b7631f3beb7a11ba20703fdca3c0e3569",
32881
+ output_index: 0,
32882
+ tx_pointer_block_height: 0,
32883
+ tx_pointer_tx_idx: 0,
32884
+ owner: "0x6a2c4691c547c43924650dbd30620b184b5fe3fb6dbe5c4446110b08f6f405bf",
32885
+ amount: 18446744073709552e3,
32886
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32887
+ },
32888
+ {
32889
+ tx_id: "0xe0ec1d2c991feac69be4d0e84ad7c964616de08e16dccc4d2000b1900ba31082b993",
32890
+ output_index: 0,
32891
+ tx_pointer_block_height: 0,
32892
+ tx_pointer_tx_idx: 0,
32893
+ owner: "0x49075a7538e2c88ebe1926ce4d898198a2a4e790d14512943a9864bc536b3c82",
32894
+ amount: 18446744073709552e3,
32895
+ asset_id: "0x0000000000000000000000000000000000000000000000000000000000000000"
32896
+ },
32897
+ {
32898
+ tx_id: "0xfa82dbdd72252d1e6c76ee818bbac0441c3a705aff447f041c8b9fc3cb03f9ccd7e2",
32899
+ output_index: 0,
32900
+ tx_pointer_block_height: 0,
32901
+ tx_pointer_tx_idx: 0,
32902
+ owner: "0x49075a7538e2c88ebe1926ce4d898198a2a4e790d14512943a9864bc536b3c82",
32903
+ amount: 18446744073709552e3,
32904
+ asset_id: "0x0101010101010101010101010101010101010101010101010101010101010101"
32905
+ },
32906
+ {
32907
+ tx_id: "0x324f45e47cef892ac3e0759f3b72207c77046f9938267af4bd4af2ae031b97cb36c8",
32908
+ output_index: 0,
32909
+ tx_pointer_block_height: 0,
32910
+ tx_pointer_tx_idx: 0,
32911
+ owner: "0x49075a7538e2c88ebe1926ce4d898198a2a4e790d14512943a9864bc536b3c82",
32912
+ amount: 18446744073709552e3,
32913
+ asset_id: "0x0202020202020202020202020202020202020202020202020202020202020202"
32706
32914
  }
32707
- }
32915
+ ],
32916
+ messages: [
32917
+ {
32918
+ sender: "0xc43454aa38dd91f88109a4b7aef5efb96ce34e3f24992fe0f81d233ca686f80f",
32919
+ recipient: "0x69a2b736b60159b43bb8a4f98c0589f6da5fa3a3d101e8e269c499eb942753ba",
32920
+ nonce: "0101010101010101010101010101010101010101010101010101010101010101",
32921
+ amount: 18446744073709552e3,
32922
+ data: "",
32923
+ da_height: 0
32924
+ },
32925
+ {
32926
+ sender: "0x69a2b736b60159b43bb8a4f98c0589f6da5fa3a3d101e8e269c499eb942753ba",
32927
+ recipient: "0xc43454aa38dd91f88109a4b7aef5efb96ce34e3f24992fe0f81d233ca686f80f",
32928
+ nonce: "0e1ef2963832068b0e1ef2963832068b0e1ef2963832068b0e1ef2963832068b",
32929
+ amount: 12704439083013452e3,
32930
+ data: "",
32931
+ da_height: 0
32932
+ }
32933
+ ],
32934
+ contracts: [],
32935
+ block_height: 0,
32936
+ da_block_height: 0
32937
+ };
32938
+ var defaultChainConfigs = {
32939
+ chainConfigJson: chainConfig_default,
32940
+ metadataJson: metadata_default,
32941
+ stateConfigJson: stateConfig_default
32708
32942
  };
32709
- var defaultChainConfig = chainConfig_default;
32710
32943
  var defaultConsensusKey = "0xa449b1ffee0e2205fa924c6740cc48b3b473aa28587df6dab12abc245d1f5298";
32711
32944
 
32712
32945
  // ../crypto/dist/index.mjs
32713
- var import_crypto8 = __toESM(__require("crypto"), 1);
32946
+ var import_crypto9 = __toESM(__require("crypto"), 1);
32714
32947
 
32715
32948
  // ../../node_modules/.pnpm/ethers@6.7.1/node_modules/ethers/lib.esm/_version.js
32716
32949
  var version = "6.7.1";
@@ -33782,6 +34015,27 @@ This unreleased fuel-core build may include features and updates not yet support
33782
34015
  };
33783
34016
  Object.freeze(pbkdf22);
33784
34017
 
34018
+ // ../../node_modules/.pnpm/ethers@6.7.1/node_modules/ethers/lib.esm/crypto/random.js
34019
+ var locked5 = false;
34020
+ var _randomBytes = function(length) {
34021
+ return new Uint8Array((0, import_crypto2.randomBytes)(length));
34022
+ };
34023
+ var __randomBytes = _randomBytes;
34024
+ function randomBytes3(length) {
34025
+ return __randomBytes(length);
34026
+ }
34027
+ randomBytes3._ = _randomBytes;
34028
+ randomBytes3.lock = function() {
34029
+ locked5 = true;
34030
+ };
34031
+ randomBytes3.register = function(func) {
34032
+ if (locked5) {
34033
+ throw new Error("randomBytes is locked");
34034
+ }
34035
+ __randomBytes = func;
34036
+ };
34037
+ Object.freeze(randomBytes3);
34038
+
33785
34039
  // ../../node_modules/.pnpm/ethers@6.7.1/node_modules/ethers/lib.esm/address/address.js
33786
34040
  var BN_03 = BigInt(0);
33787
34041
  var BN_36 = BigInt(36);
@@ -34366,8 +34620,8 @@ This unreleased fuel-core build may include features and updates not yet support
34366
34620
  }
34367
34621
 
34368
34622
  // ../crypto/dist/index.mjs
34369
- var import_crypto9 = __toESM(__require("crypto"), 1);
34370
34623
  var import_crypto10 = __toESM(__require("crypto"), 1);
34624
+ var import_crypto11 = __toESM(__require("crypto"), 1);
34371
34625
  var scrypt3 = (params) => {
34372
34626
  const { password, salt, n, p, r, dklen } = params;
34373
34627
  const derivedKey = scrypt(password, salt, { N: n, r, p, dkLen: dklen });
@@ -34376,7 +34630,7 @@ This unreleased fuel-core build may include features and updates not yet support
34376
34630
  var keccak2562 = (data) => keccak_256(data);
34377
34631
  var bufferFromString = (string, encoding = "base64") => Uint8Array.from(Buffer.from(string, encoding));
34378
34632
  var randomBytes4 = (length) => {
34379
- const randomValues = Uint8Array.from(import_crypto9.default.randomBytes(length));
34633
+ const randomValues = Uint8Array.from(import_crypto10.default.randomBytes(length));
34380
34634
  return randomValues;
34381
34635
  };
34382
34636
  var stringFromBuffer = (buffer, encoding = "base64") => Buffer.from(buffer).toString(encoding);
@@ -34391,7 +34645,7 @@ This unreleased fuel-core build may include features and updates not yet support
34391
34645
  const salt = randomBytes4(32);
34392
34646
  const secret = keyFromPassword(password, salt);
34393
34647
  const dataBuffer = Uint8Array.from(Buffer.from(JSON.stringify(data), "utf-8"));
34394
- const cipher = await import_crypto8.default.createCipheriv(ALGORITHM, secret, iv);
34648
+ const cipher = await import_crypto9.default.createCipheriv(ALGORITHM, secret, iv);
34395
34649
  let cipherData = cipher.update(dataBuffer);
34396
34650
  cipherData = Buffer.concat([cipherData, cipher.final()]);
34397
34651
  return {
@@ -34405,7 +34659,7 @@ This unreleased fuel-core build may include features and updates not yet support
34405
34659
  const salt = bufferFromString(keystore.salt);
34406
34660
  const secret = keyFromPassword(password, salt);
34407
34661
  const encryptedText = bufferFromString(keystore.data);
34408
- const decipher = await import_crypto8.default.createDecipheriv(ALGORITHM, secret, iv);
34662
+ const decipher = await import_crypto9.default.createDecipheriv(ALGORITHM, secret, iv);
34409
34663
  const decrypted = decipher.update(encryptedText);
34410
34664
  const deBuff = Buffer.concat([decrypted, decipher.final()]);
34411
34665
  const decryptedData = Buffer.from(deBuff).toString("utf-8");
@@ -34416,12 +34670,12 @@ This unreleased fuel-core build may include features and updates not yet support
34416
34670
  }
34417
34671
  };
34418
34672
  async function encryptJsonWalletData(data, key, iv) {
34419
- const cipher = await import_crypto10.default.createCipheriv("aes-128-ctr", key.subarray(0, 16), iv);
34673
+ const cipher = await import_crypto11.default.createCipheriv("aes-128-ctr", key.subarray(0, 16), iv);
34420
34674
  const encrypted = Buffer.concat([cipher.update(data), cipher.final()]);
34421
34675
  return new Uint8Array(encrypted);
34422
34676
  }
34423
34677
  async function decryptJsonWalletData(data, key, iv) {
34424
- const decipher = import_crypto10.default.createDecipheriv("aes-128-ctr", key.subarray(0, 16), iv);
34678
+ const decipher = import_crypto11.default.createDecipheriv("aes-128-ctr", key.subarray(0, 16), iv);
34425
34679
  const decrypted = await Buffer.concat([decipher.update(data), decipher.final()]);
34426
34680
  return new Uint8Array(decrypted);
34427
34681
  }
@@ -34978,32 +35232,182 @@ This unreleased fuel-core build may include features and updates not yet support
34978
35232
  function toBytes3(value, bytesPadding) {
34979
35233
  return bn(value).toBytes(bytesPadding);
34980
35234
  }
34981
- function max(...numbers) {
34982
- return numbers.reduce((prev, cur) => bn(cur).gt(prev) ? bn(cur) : prev, bn(0));
35235
+
35236
+ // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_isPlaceholder.js
35237
+ function _isPlaceholder(a) {
35238
+ return a != null && typeof a === "object" && a["@@functional/placeholder"] === true;
35239
+ }
35240
+
35241
+ // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_curry1.js
35242
+ function _curry1(fn) {
35243
+ return function f1(a) {
35244
+ if (arguments.length === 0 || _isPlaceholder(a)) {
35245
+ return f1;
35246
+ } else {
35247
+ return fn.apply(this, arguments);
35248
+ }
35249
+ };
35250
+ }
35251
+
35252
+ // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_isArray.js
35253
+ var isArray_default = Array.isArray || function _isArray(val) {
35254
+ return val != null && val.length >= 0 && Object.prototype.toString.call(val) === "[object Array]";
35255
+ };
35256
+
35257
+ // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/type.js
35258
+ var type = /* @__PURE__ */ _curry1(function type2(val) {
35259
+ return val === null ? "Null" : val === void 0 ? "Undefined" : Object.prototype.toString.call(val).slice(8, -1);
35260
+ });
35261
+ var type_default = type;
35262
+
35263
+ // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_toISOString.js
35264
+ var pad = function pad2(n) {
35265
+ return (n < 10 ? "0" : "") + n;
35266
+ };
35267
+ var _toISOString = typeof Date.prototype.toISOString === "function" ? function _toISOString2(d) {
35268
+ return d.toISOString();
35269
+ } : function _toISOString3(d) {
35270
+ return d.getUTCFullYear() + "-" + pad(d.getUTCMonth() + 1) + "-" + pad(d.getUTCDate()) + "T" + pad(d.getUTCHours()) + ":" + pad(d.getUTCMinutes()) + ":" + pad(d.getUTCSeconds()) + "." + (d.getUTCMilliseconds() / 1e3).toFixed(3).slice(2, 5) + "Z";
35271
+ };
35272
+
35273
+ // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_isInteger.js
35274
+ var isInteger_default = Number.isInteger || function _isInteger(n) {
35275
+ return n << 0 === n;
35276
+ };
35277
+
35278
+ // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_cloneRegExp.js
35279
+ function _cloneRegExp(pattern) {
35280
+ return new RegExp(pattern.source, pattern.flags ? pattern.flags : (pattern.global ? "g" : "") + (pattern.ignoreCase ? "i" : "") + (pattern.multiline ? "m" : "") + (pattern.sticky ? "y" : "") + (pattern.unicode ? "u" : "") + (pattern.dotAll ? "s" : ""));
35281
+ }
35282
+
35283
+ // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_clone.js
35284
+ function _clone(value, deep, map) {
35285
+ map || (map = new _ObjectMap());
35286
+ if (_isPrimitive(value)) {
35287
+ return value;
35288
+ }
35289
+ var copy = function copy2(copiedValue) {
35290
+ var cachedCopy = map.get(value);
35291
+ if (cachedCopy) {
35292
+ return cachedCopy;
35293
+ }
35294
+ map.set(value, copiedValue);
35295
+ for (var key in value) {
35296
+ if (Object.prototype.hasOwnProperty.call(value, key)) {
35297
+ copiedValue[key] = deep ? _clone(value[key], true, map) : value[key];
35298
+ }
35299
+ }
35300
+ return copiedValue;
35301
+ };
35302
+ switch (type_default(value)) {
35303
+ case "Object":
35304
+ return copy(Object.create(Object.getPrototypeOf(value)));
35305
+ case "Array":
35306
+ return copy([]);
35307
+ case "Date":
35308
+ return new Date(value.valueOf());
35309
+ case "RegExp":
35310
+ return _cloneRegExp(value);
35311
+ case "Int8Array":
35312
+ case "Uint8Array":
35313
+ case "Uint8ClampedArray":
35314
+ case "Int16Array":
35315
+ case "Uint16Array":
35316
+ case "Int32Array":
35317
+ case "Uint32Array":
35318
+ case "Float32Array":
35319
+ case "Float64Array":
35320
+ case "BigInt64Array":
35321
+ case "BigUint64Array":
35322
+ return value.slice();
35323
+ default:
35324
+ return value;
35325
+ }
35326
+ }
35327
+ function _isPrimitive(param) {
35328
+ var type3 = typeof param;
35329
+ return param == null || type3 != "object" && type3 != "function";
34983
35330
  }
35331
+ var _ObjectMap = /* @__PURE__ */ function() {
35332
+ function _ObjectMap2() {
35333
+ this.map = {};
35334
+ this.length = 0;
35335
+ }
35336
+ _ObjectMap2.prototype.set = function(key, value) {
35337
+ const hashedKey = this.hash(key);
35338
+ let bucket = this.map[hashedKey];
35339
+ if (!bucket) {
35340
+ this.map[hashedKey] = bucket = [];
35341
+ }
35342
+ bucket.push([key, value]);
35343
+ this.length += 1;
35344
+ };
35345
+ _ObjectMap2.prototype.hash = function(key) {
35346
+ let hashedKey = [];
35347
+ for (var value in key) {
35348
+ hashedKey.push(Object.prototype.toString.call(key[value]));
35349
+ }
35350
+ return hashedKey.join();
35351
+ };
35352
+ _ObjectMap2.prototype.get = function(key) {
35353
+ if (this.length <= 180) {
35354
+ for (const p in this.map) {
35355
+ const bucket2 = this.map[p];
35356
+ for (let i = 0; i < bucket2.length; i += 1) {
35357
+ const element = bucket2[i];
35358
+ if (element[0] === key) {
35359
+ return element[1];
35360
+ }
35361
+ }
35362
+ }
35363
+ return;
35364
+ }
35365
+ const hashedKey = this.hash(key);
35366
+ const bucket = this.map[hashedKey];
35367
+ if (!bucket) {
35368
+ return;
35369
+ }
35370
+ for (let i = 0; i < bucket.length; i += 1) {
35371
+ const element = bucket[i];
35372
+ if (element[0] === key) {
35373
+ return element[1];
35374
+ }
35375
+ }
35376
+ };
35377
+ return _ObjectMap2;
35378
+ }();
35379
+
35380
+ // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/clone.js
35381
+ var clone = /* @__PURE__ */ _curry1(function clone2(value) {
35382
+ return value != null && typeof value.clone === "function" ? value.clone() : _clone(value, true);
35383
+ });
35384
+ var clone_default = clone;
35385
+
35386
+ // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/trim.js
35387
+ var hasProtoTrim = typeof String.prototype.trim === "function";
34984
35388
 
34985
35389
  // src/providers/coin-quantity.ts
34986
35390
  var coinQuantityfy = (coinQuantityLike) => {
34987
35391
  let assetId;
34988
35392
  let amount;
34989
- let max2;
35393
+ let max;
34990
35394
  if (Array.isArray(coinQuantityLike)) {
34991
35395
  amount = coinQuantityLike[0];
34992
35396
  assetId = coinQuantityLike[1] ?? BaseAssetId;
34993
- max2 = coinQuantityLike[2] ?? void 0;
35397
+ max = coinQuantityLike[2] ?? void 0;
34994
35398
  } else {
34995
35399
  amount = coinQuantityLike.amount;
34996
35400
  assetId = coinQuantityLike.assetId ?? BaseAssetId;
34997
- max2 = coinQuantityLike.max ?? void 0;
35401
+ max = coinQuantityLike.max ?? void 0;
34998
35402
  }
34999
35403
  const bnAmount = bn(amount);
35000
35404
  return {
35001
35405
  assetId: hexlify(assetId),
35002
35406
  amount: bnAmount.lt(1) ? bn(1) : bnAmount,
35003
- max: max2 ? bn(max2) : void 0
35407
+ max: max ? bn(max) : void 0
35004
35408
  };
35005
35409
  };
35006
- var addAmountToAsset = (params) => {
35410
+ var addAmountToCoinQuantities = (params) => {
35007
35411
  const { amount, assetId } = params;
35008
35412
  const coinQuantities = [...params.coinQuantities];
35009
35413
  const assetIdx = coinQuantities.findIndex((coinQuantity) => coinQuantity.assetId === assetId);
@@ -35070,7 +35474,7 @@ This unreleased fuel-core build may include features and updates not yet support
35070
35474
  var ENCODING_V1 = "1";
35071
35475
  var WORD_SIZE = 8;
35072
35476
  var BYTES_32 = 32;
35073
- var UTXO_ID_LEN = BYTES_32 + 1;
35477
+ var UTXO_ID_LEN = BYTES_32 + 2;
35074
35478
  var ASSET_ID_LEN = BYTES_32;
35075
35479
  var ADDRESS_LEN = BYTES_32;
35076
35480
  var NONCE_LEN = BYTES_32;
@@ -35078,9 +35482,9 @@ This unreleased fuel-core build may include features and updates not yet support
35078
35482
  var TX_POINTER_LEN = WORD_SIZE * 2;
35079
35483
  var MAX_BYTES = 2 ** 32 - 1;
35080
35484
  var calculateVmTxMemory = ({ maxInputs }) => BYTES_32 + // Tx ID
35081
- WORD_SIZE + // Tx size
35485
+ ASSET_ID_LEN + // Base asset ID
35082
35486
  // Asset ID/Balance coin input pairs
35083
- maxInputs * (ASSET_ID_LEN + WORD_SIZE);
35487
+ maxInputs * (ASSET_ID_LEN + WORD_SIZE) + WORD_SIZE;
35084
35488
  var SCRIPT_FIXED_SIZE = WORD_SIZE + // Identifier
35085
35489
  WORD_SIZE + // Gas limit
35086
35490
  WORD_SIZE + // Script size
@@ -35098,7 +35502,6 @@ This unreleased fuel-core build may include features and updates not yet support
35098
35502
  ASSET_ID_LEN + // Asset id
35099
35503
  TX_POINTER_LEN + // TxPointer
35100
35504
  WORD_SIZE + // Witnesses index
35101
- WORD_SIZE + // Maturity
35102
35505
  WORD_SIZE + // Predicate size
35103
35506
  WORD_SIZE + // Predicate data size
35104
35507
  WORD_SIZE;
@@ -35420,7 +35823,7 @@ This unreleased fuel-core build may include features and updates not yet support
35420
35823
  constructor(name, coders) {
35421
35824
  const caseIndexCoder = new BigNumberCoder("u64");
35422
35825
  const encodedValueSize = Object.values(coders).reduce(
35423
- (max2, coder) => Math.max(max2, coder.encodedLength),
35826
+ (max, coder) => Math.max(max, coder.encodedLength),
35424
35827
  0
35425
35828
  );
35426
35829
  super(`enum ${name}`, `enum ${name}`, caseIndexCoder.encodedLength + encodedValueSize);
@@ -36124,7 +36527,7 @@ This unreleased fuel-core build may include features and updates not yet support
36124
36527
  constructor(name, coders) {
36125
36528
  const caseIndexCoder = new BigNumberCoder("u64");
36126
36529
  const encodedValueSize = Object.values(coders).reduce(
36127
- (max2, coder) => Math.max(max2, coder.encodedLength),
36530
+ (max, coder) => Math.max(max, coder.encodedLength),
36128
36531
  0
36129
36532
  );
36130
36533
  super(`enum ${name}`, `enum ${name}`, caseIndexCoder.encodedLength + encodedValueSize);
@@ -36836,18 +37239,19 @@ This unreleased fuel-core build may include features and updates not yet support
36836
37239
  encode(value) {
36837
37240
  const parts = [];
36838
37241
  parts.push(new B256Coder().encode(value.txID));
36839
- parts.push(new NumberCoder("u8").encode(value.outputIndex));
37242
+ parts.push(new NumberCoder("u16").encode(value.outputIndex));
36840
37243
  parts.push(new B256Coder().encode(value.owner));
36841
37244
  parts.push(new BigNumberCoder("u64").encode(value.amount));
36842
37245
  parts.push(new B256Coder().encode(value.assetId));
36843
37246
  parts.push(new TxPointerCoder().encode(value.txPointer));
36844
- parts.push(new NumberCoder("u8").encode(value.witnessIndex));
36845
- parts.push(new NumberCoder("u32").encode(value.maturity));
37247
+ parts.push(new NumberCoder("u16").encode(value.witnessIndex));
36846
37248
  parts.push(new BigNumberCoder("u64").encode(value.predicateGasUsed));
36847
- parts.push(new NumberCoder("u32").encode(value.predicateLength));
36848
- parts.push(new NumberCoder("u32").encode(value.predicateDataLength));
36849
- parts.push(new ByteArrayCoder(value.predicateLength).encode(value.predicate));
36850
- parts.push(new ByteArrayCoder(value.predicateDataLength).encode(value.predicateData));
37249
+ parts.push(new BigNumberCoder("u64").encode(value.predicateLength));
37250
+ parts.push(new BigNumberCoder("u64").encode(value.predicateDataLength));
37251
+ parts.push(new ByteArrayCoder(value.predicateLength.toNumber()).encode(value.predicate));
37252
+ parts.push(
37253
+ new ByteArrayCoder(value.predicateDataLength.toNumber()).encode(value.predicateData)
37254
+ );
36851
37255
  return concat(parts);
36852
37256
  }
36853
37257
  decode(data, offset) {
@@ -36855,7 +37259,7 @@ This unreleased fuel-core build may include features and updates not yet support
36855
37259
  let o = offset;
36856
37260
  [decoded, o] = new B256Coder().decode(data, o);
36857
37261
  const txID = decoded;
36858
- [decoded, o] = new NumberCoder("u8").decode(data, o);
37262
+ [decoded, o] = new NumberCoder("u16").decode(data, o);
36859
37263
  const outputIndex = decoded;
36860
37264
  [decoded, o] = new B256Coder().decode(data, o);
36861
37265
  const owner = decoded;
@@ -36865,19 +37269,17 @@ This unreleased fuel-core build may include features and updates not yet support
36865
37269
  const assetId = decoded;
36866
37270
  [decoded, o] = new TxPointerCoder().decode(data, o);
36867
37271
  const txPointer = decoded;
36868
- [decoded, o] = new NumberCoder("u8").decode(data, o);
37272
+ [decoded, o] = new NumberCoder("u16").decode(data, o);
36869
37273
  const witnessIndex = Number(decoded);
36870
- [decoded, o] = new NumberCoder("u32").decode(data, o);
36871
- const maturity = decoded;
36872
37274
  [decoded, o] = new BigNumberCoder("u64").decode(data, o);
36873
37275
  const predicateGasUsed = decoded;
36874
- [decoded, o] = new NumberCoder("u32").decode(data, o);
37276
+ [decoded, o] = new BigNumberCoder("u64").decode(data, o);
36875
37277
  const predicateLength = decoded;
36876
- [decoded, o] = new NumberCoder("u32").decode(data, o);
37278
+ [decoded, o] = new BigNumberCoder("u64").decode(data, o);
36877
37279
  const predicateDataLength = decoded;
36878
- [decoded, o] = new ByteArrayCoder(predicateLength).decode(data, o);
37280
+ [decoded, o] = new ByteArrayCoder(predicateLength.toNumber()).decode(data, o);
36879
37281
  const predicate = decoded;
36880
- [decoded, o] = new ByteArrayCoder(predicateDataLength).decode(data, o);
37282
+ [decoded, o] = new ByteArrayCoder(predicateDataLength.toNumber()).decode(data, o);
36881
37283
  const predicateData = decoded;
36882
37284
  return [
36883
37285
  {
@@ -36889,7 +37291,6 @@ This unreleased fuel-core build may include features and updates not yet support
36889
37291
  assetId,
36890
37292
  txPointer,
36891
37293
  witnessIndex,
36892
- maturity,
36893
37294
  predicateGasUsed,
36894
37295
  predicateLength,
36895
37296
  predicateDataLength,
@@ -36907,7 +37308,7 @@ This unreleased fuel-core build may include features and updates not yet support
36907
37308
  encode(value) {
36908
37309
  const parts = [];
36909
37310
  parts.push(new B256Coder().encode(value.txID));
36910
- parts.push(new NumberCoder("u8").encode(value.outputIndex));
37311
+ parts.push(new NumberCoder("u16").encode(value.outputIndex));
36911
37312
  parts.push(new B256Coder().encode(value.balanceRoot));
36912
37313
  parts.push(new B256Coder().encode(value.stateRoot));
36913
37314
  parts.push(new TxPointerCoder().encode(value.txPointer));
@@ -36919,7 +37320,7 @@ This unreleased fuel-core build may include features and updates not yet support
36919
37320
  let o = offset;
36920
37321
  [decoded, o] = new B256Coder().decode(data, o);
36921
37322
  const txID = decoded;
36922
- [decoded, o] = new NumberCoder("u8").decode(data, o);
37323
+ [decoded, o] = new NumberCoder("u16").decode(data, o);
36923
37324
  const outputIndex = decoded;
36924
37325
  [decoded, o] = new B256Coder().decode(data, o);
36925
37326
  const balanceRoot = decoded;
@@ -36968,14 +37369,16 @@ This unreleased fuel-core build may include features and updates not yet support
36968
37369
  parts.push(new ByteArrayCoder(32).encode(value.recipient));
36969
37370
  parts.push(new BigNumberCoder("u64").encode(value.amount));
36970
37371
  parts.push(new ByteArrayCoder(32).encode(value.nonce));
36971
- parts.push(new NumberCoder("u8").encode(value.witnessIndex));
37372
+ parts.push(new NumberCoder("u16").encode(value.witnessIndex));
36972
37373
  parts.push(new BigNumberCoder("u64").encode(value.predicateGasUsed));
36973
- parts.push(new NumberCoder("u32").encode(data.length));
36974
- parts.push(new NumberCoder("u32").encode(value.predicateLength));
36975
- parts.push(new NumberCoder("u32").encode(value.predicateDataLength));
37374
+ parts.push(new BigNumberCoder("u64").encode(data.length));
37375
+ parts.push(new BigNumberCoder("u64").encode(value.predicateLength));
37376
+ parts.push(new BigNumberCoder("u64").encode(value.predicateDataLength));
36976
37377
  parts.push(new ByteArrayCoder(data.length).encode(data));
36977
- parts.push(new ByteArrayCoder(value.predicateLength).encode(value.predicate));
36978
- parts.push(new ByteArrayCoder(value.predicateDataLength).encode(value.predicateData));
37378
+ parts.push(new ByteArrayCoder(value.predicateLength.toNumber()).encode(value.predicate));
37379
+ parts.push(
37380
+ new ByteArrayCoder(value.predicateDataLength.toNumber()).encode(value.predicateData)
37381
+ );
36979
37382
  return concat(parts);
36980
37383
  }
36981
37384
  static decodeData(messageData) {
@@ -36995,21 +37398,21 @@ This unreleased fuel-core build may include features and updates not yet support
36995
37398
  const amount = decoded;
36996
37399
  [decoded, o] = new B256Coder().decode(data, o);
36997
37400
  const nonce = decoded;
36998
- [decoded, o] = new NumberCoder("u8").decode(data, o);
37401
+ [decoded, o] = new NumberCoder("u16").decode(data, o);
36999
37402
  const witnessIndex = Number(decoded);
37000
37403
  [decoded, o] = new BigNumberCoder("u64").decode(data, o);
37001
37404
  const predicateGasUsed = decoded;
37002
37405
  [decoded, o] = new NumberCoder("u32").decode(data, o);
37003
37406
  const dataLength2 = decoded;
37004
- [decoded, o] = new NumberCoder("u32").decode(data, o);
37407
+ [decoded, o] = new BigNumberCoder("u64").decode(data, o);
37005
37408
  const predicateLength = decoded;
37006
- [decoded, o] = new NumberCoder("u32").decode(data, o);
37409
+ [decoded, o] = new BigNumberCoder("u64").decode(data, o);
37007
37410
  const predicateDataLength = decoded;
37008
37411
  [decoded, o] = new ByteArrayCoder(dataLength2).decode(data, o);
37009
37412
  const messageData = decoded;
37010
- [decoded, o] = new ByteArrayCoder(predicateLength).decode(data, o);
37413
+ [decoded, o] = new ByteArrayCoder(predicateLength.toNumber()).decode(data, o);
37011
37414
  const predicate = decoded;
37012
- [decoded, o] = new ByteArrayCoder(predicateDataLength).decode(data, o);
37415
+ [decoded, o] = new ByteArrayCoder(predicateDataLength.toNumber()).decode(data, o);
37013
37416
  const predicateData = decoded;
37014
37417
  return [
37015
37418
  {
@@ -37321,7 +37724,7 @@ This unreleased fuel-core build may include features and updates not yet support
37321
37724
  }
37322
37725
  };
37323
37726
  var PolicyType = /* @__PURE__ */ ((PolicyType2) => {
37324
- PolicyType2[PolicyType2["GasPrice"] = 1] = "GasPrice";
37727
+ PolicyType2[PolicyType2["Tip"] = 1] = "Tip";
37325
37728
  PolicyType2[PolicyType2["WitnessLimit"] = 2] = "WitnessLimit";
37326
37729
  PolicyType2[PolicyType2["Maturity"] = 4] = "Maturity";
37327
37730
  PolicyType2[PolicyType2["MaxFee"] = 8] = "MaxFee";
@@ -37369,9 +37772,9 @@ This unreleased fuel-core build may include features and updates not yet support
37369
37772
  let o = offset;
37370
37773
  const policies = [];
37371
37774
  if (policyTypes & 1) {
37372
- const [gasPrice, nextOffset] = new BigNumberCoder("u64").decode(data, o);
37775
+ const [tip, nextOffset] = new BigNumberCoder("u64").decode(data, o);
37373
37776
  o = nextOffset;
37374
- policies.push({ type: 1, data: gasPrice });
37777
+ policies.push({ type: 1, data: tip });
37375
37778
  }
37376
37779
  if (policyTypes & 2) {
37377
37780
  const [witnessLimit, nextOffset] = new BigNumberCoder("u64").decode(data, o);
@@ -37603,15 +38006,15 @@ This unreleased fuel-core build may include features and updates not yet support
37603
38006
  encode(value) {
37604
38007
  const parts = [];
37605
38008
  parts.push(new BigNumberCoder("u64").encode(value.scriptGasLimit));
37606
- parts.push(new NumberCoder("u32").encode(value.scriptLength));
37607
- parts.push(new NumberCoder("u32").encode(value.scriptDataLength));
37608
- parts.push(new NumberCoder("u32").encode(value.policyTypes));
37609
- parts.push(new NumberCoder("u8").encode(value.inputsCount));
37610
- parts.push(new NumberCoder("u8").encode(value.outputsCount));
37611
- parts.push(new NumberCoder("u8").encode(value.witnessesCount));
37612
38009
  parts.push(new B256Coder().encode(value.receiptsRoot));
37613
- parts.push(new ByteArrayCoder(value.scriptLength).encode(value.script));
37614
- parts.push(new ByteArrayCoder(value.scriptDataLength).encode(value.scriptData));
38010
+ parts.push(new BigNumberCoder("u64").encode(value.scriptLength));
38011
+ parts.push(new BigNumberCoder("u64").encode(value.scriptDataLength));
38012
+ parts.push(new NumberCoder("u32").encode(value.policyTypes));
38013
+ parts.push(new NumberCoder("u16").encode(value.inputsCount));
38014
+ parts.push(new NumberCoder("u16").encode(value.outputsCount));
38015
+ parts.push(new NumberCoder("u16").encode(value.witnessesCount));
38016
+ parts.push(new ByteArrayCoder(value.scriptLength.toNumber()).encode(value.script));
38017
+ parts.push(new ByteArrayCoder(value.scriptDataLength.toNumber()).encode(value.scriptData));
37615
38018
  parts.push(new PoliciesCoder().encode(value.policies));
37616
38019
  parts.push(new ArrayCoder(new InputCoder(), value.inputsCount).encode(value.inputs));
37617
38020
  parts.push(new ArrayCoder(new OutputCoder(), value.outputsCount).encode(value.outputs));
@@ -37623,23 +38026,23 @@ This unreleased fuel-core build may include features and updates not yet support
37623
38026
  let o = offset;
37624
38027
  [decoded, o] = new BigNumberCoder("u64").decode(data, o);
37625
38028
  const scriptGasLimit = decoded;
37626
- [decoded, o] = new NumberCoder("u32").decode(data, o);
38029
+ [decoded, o] = new B256Coder().decode(data, o);
38030
+ const receiptsRoot = decoded;
38031
+ [decoded, o] = new BigNumberCoder("u64").decode(data, o);
37627
38032
  const scriptLength = decoded;
37628
- [decoded, o] = new NumberCoder("u32").decode(data, o);
38033
+ [decoded, o] = new BigNumberCoder("u64").decode(data, o);
37629
38034
  const scriptDataLength = decoded;
37630
38035
  [decoded, o] = new NumberCoder("u32").decode(data, o);
37631
38036
  const policyTypes = decoded;
37632
- [decoded, o] = new NumberCoder("u8").decode(data, o);
38037
+ [decoded, o] = new NumberCoder("u16").decode(data, o);
37633
38038
  const inputsCount = decoded;
37634
- [decoded, o] = new NumberCoder("u8").decode(data, o);
38039
+ [decoded, o] = new NumberCoder("u16").decode(data, o);
37635
38040
  const outputsCount = decoded;
37636
- [decoded, o] = new NumberCoder("u8").decode(data, o);
38041
+ [decoded, o] = new NumberCoder("u16").decode(data, o);
37637
38042
  const witnessesCount = decoded;
37638
- [decoded, o] = new B256Coder().decode(data, o);
37639
- const receiptsRoot = decoded;
37640
- [decoded, o] = new ByteArrayCoder(scriptLength).decode(data, o);
38043
+ [decoded, o] = new ByteArrayCoder(scriptLength.toNumber()).decode(data, o);
37641
38044
  const script = decoded;
37642
- [decoded, o] = new ByteArrayCoder(scriptDataLength).decode(data, o);
38045
+ [decoded, o] = new ByteArrayCoder(scriptDataLength.toNumber()).decode(data, o);
37643
38046
  const scriptData = decoded;
37644
38047
  [decoded, o] = new PoliciesCoder().decode(data, o, policyTypes);
37645
38048
  const policies = decoded;
@@ -37677,18 +38080,19 @@ This unreleased fuel-core build may include features and updates not yet support
37677
38080
  }
37678
38081
  encode(value) {
37679
38082
  const parts = [];
37680
- parts.push(new NumberCoder("u32").encode(value.bytecodeLength));
37681
- parts.push(new NumberCoder("u8").encode(value.bytecodeWitnessIndex));
37682
- parts.push(new NumberCoder("u32").encode(value.policyTypes));
37683
- parts.push(new NumberCoder("u16").encode(value.storageSlotsCount));
37684
- parts.push(new NumberCoder("u8").encode(value.inputsCount));
37685
- parts.push(new NumberCoder("u8").encode(value.outputsCount));
37686
- parts.push(new NumberCoder("u8").encode(value.witnessesCount));
38083
+ parts.push(new NumberCoder("u16").encode(value.bytecodeWitnessIndex));
37687
38084
  parts.push(new B256Coder().encode(value.salt));
37688
- parts.push(new PoliciesCoder().encode(value.policies));
38085
+ parts.push(new BigNumberCoder("u64").encode(value.storageSlotsCount));
38086
+ parts.push(new NumberCoder("u32").encode(value.policyTypes));
38087
+ parts.push(new NumberCoder("u16").encode(value.inputsCount));
38088
+ parts.push(new NumberCoder("u16").encode(value.outputsCount));
38089
+ parts.push(new NumberCoder("u16").encode(value.witnessesCount));
37689
38090
  parts.push(
37690
- new ArrayCoder(new StorageSlotCoder(), value.storageSlotsCount).encode(value.storageSlots)
38091
+ new ArrayCoder(new StorageSlotCoder(), value.storageSlotsCount.toNumber()).encode(
38092
+ value.storageSlots
38093
+ )
37691
38094
  );
38095
+ parts.push(new PoliciesCoder().encode(value.policies));
37692
38096
  parts.push(new ArrayCoder(new InputCoder(), value.inputsCount).encode(value.inputs));
37693
38097
  parts.push(new ArrayCoder(new OutputCoder(), value.outputsCount).encode(value.outputs));
37694
38098
  parts.push(new ArrayCoder(new WitnessCoder(), value.witnessesCount).encode(value.witnesses));
@@ -37697,26 +38101,27 @@ This unreleased fuel-core build may include features and updates not yet support
37697
38101
  decode(data, offset) {
37698
38102
  let decoded;
37699
38103
  let o = offset;
37700
- [decoded, o] = new NumberCoder("u32").decode(data, o);
37701
- const bytecodeLength = decoded;
37702
- [decoded, o] = new NumberCoder("u8").decode(data, o);
38104
+ [decoded, o] = new NumberCoder("u16").decode(data, o);
37703
38105
  const bytecodeWitnessIndex = decoded;
38106
+ [decoded, o] = new B256Coder().decode(data, o);
38107
+ const salt = decoded;
38108
+ [decoded, o] = new BigNumberCoder("u64").decode(data, o);
38109
+ const storageSlotsCount = decoded;
37704
38110
  [decoded, o] = new NumberCoder("u32").decode(data, o);
37705
38111
  const policyTypes = decoded;
37706
38112
  [decoded, o] = new NumberCoder("u16").decode(data, o);
37707
- const storageSlotsCount = decoded;
37708
- [decoded, o] = new NumberCoder("u8").decode(data, o);
37709
38113
  const inputsCount = decoded;
37710
- [decoded, o] = new NumberCoder("u8").decode(data, o);
38114
+ [decoded, o] = new NumberCoder("u16").decode(data, o);
37711
38115
  const outputsCount = decoded;
37712
- [decoded, o] = new NumberCoder("u8").decode(data, o);
38116
+ [decoded, o] = new NumberCoder("u16").decode(data, o);
37713
38117
  const witnessesCount = decoded;
37714
- [decoded, o] = new B256Coder().decode(data, o);
37715
- const salt = decoded;
38118
+ [decoded, o] = new ArrayCoder(new StorageSlotCoder(), storageSlotsCount.toNumber()).decode(
38119
+ data,
38120
+ o
38121
+ );
38122
+ const storageSlots = decoded;
37716
38123
  [decoded, o] = new PoliciesCoder().decode(data, o, policyTypes);
37717
38124
  const policies = decoded;
37718
- [decoded, o] = new ArrayCoder(new StorageSlotCoder(), storageSlotsCount).decode(data, o);
37719
- const storageSlots = decoded;
37720
38125
  [decoded, o] = new ArrayCoder(new InputCoder(), inputsCount).decode(data, o);
37721
38126
  const inputs = decoded;
37722
38127
  [decoded, o] = new ArrayCoder(new OutputCoder(), outputsCount).decode(data, o);
@@ -37726,7 +38131,6 @@ This unreleased fuel-core build may include features and updates not yet support
37726
38131
  return [
37727
38132
  {
37728
38133
  type: 1,
37729
- bytecodeLength,
37730
38134
  bytecodeWitnessIndex,
37731
38135
  policyTypes,
37732
38136
  storageSlotsCount,
@@ -37755,6 +38159,7 @@ This unreleased fuel-core build may include features and updates not yet support
37755
38159
  parts.push(new OutputContractCoder().encode(value.outputContract));
37756
38160
  parts.push(new BigNumberCoder("u64").encode(value.mintAmount));
37757
38161
  parts.push(new B256Coder().encode(value.mintAssetId));
38162
+ parts.push(new BigNumberCoder("u64").encode(value.gasPrice));
37758
38163
  return concat(parts);
37759
38164
  }
37760
38165
  decode(data, offset) {
@@ -37770,6 +38175,8 @@ This unreleased fuel-core build may include features and updates not yet support
37770
38175
  const mintAmount = decoded;
37771
38176
  [decoded, o] = new B256Coder().decode(data, o);
37772
38177
  const mintAssetId = decoded;
38178
+ [decoded, o] = new BigNumberCoder("u64").decode(data, o);
38179
+ const gasPrice = decoded;
37773
38180
  return [
37774
38181
  {
37775
38182
  type: 2,
@@ -37777,7 +38184,8 @@ This unreleased fuel-core build may include features and updates not yet support
37777
38184
  inputContract,
37778
38185
  outputContract,
37779
38186
  mintAmount,
37780
- mintAssetId
38187
+ mintAssetId,
38188
+ gasPrice
37781
38189
  },
37782
38190
  o
37783
38191
  ];
@@ -38084,159 +38492,6 @@ This unreleased fuel-core build may include features and updates not yet support
38084
38492
  // src/providers/provider.ts
38085
38493
  var import_graphql_request = __toESM(require_dist2());
38086
38494
 
38087
- // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_isPlaceholder.js
38088
- function _isPlaceholder(a) {
38089
- return a != null && typeof a === "object" && a["@@functional/placeholder"] === true;
38090
- }
38091
-
38092
- // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_curry1.js
38093
- function _curry1(fn) {
38094
- return function f1(a) {
38095
- if (arguments.length === 0 || _isPlaceholder(a)) {
38096
- return f1;
38097
- } else {
38098
- return fn.apply(this, arguments);
38099
- }
38100
- };
38101
- }
38102
-
38103
- // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_isArray.js
38104
- var isArray_default = Array.isArray || function _isArray(val) {
38105
- return val != null && val.length >= 0 && Object.prototype.toString.call(val) === "[object Array]";
38106
- };
38107
-
38108
- // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/type.js
38109
- var type = /* @__PURE__ */ _curry1(function type2(val) {
38110
- return val === null ? "Null" : val === void 0 ? "Undefined" : Object.prototype.toString.call(val).slice(8, -1);
38111
- });
38112
- var type_default = type;
38113
-
38114
- // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_toISOString.js
38115
- var pad = function pad2(n) {
38116
- return (n < 10 ? "0" : "") + n;
38117
- };
38118
- var _toISOString = typeof Date.prototype.toISOString === "function" ? function _toISOString2(d) {
38119
- return d.toISOString();
38120
- } : function _toISOString3(d) {
38121
- return d.getUTCFullYear() + "-" + pad(d.getUTCMonth() + 1) + "-" + pad(d.getUTCDate()) + "T" + pad(d.getUTCHours()) + ":" + pad(d.getUTCMinutes()) + ":" + pad(d.getUTCSeconds()) + "." + (d.getUTCMilliseconds() / 1e3).toFixed(3).slice(2, 5) + "Z";
38122
- };
38123
-
38124
- // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_isInteger.js
38125
- var isInteger_default = Number.isInteger || function _isInteger(n) {
38126
- return n << 0 === n;
38127
- };
38128
-
38129
- // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_cloneRegExp.js
38130
- function _cloneRegExp(pattern) {
38131
- return new RegExp(pattern.source, pattern.flags ? pattern.flags : (pattern.global ? "g" : "") + (pattern.ignoreCase ? "i" : "") + (pattern.multiline ? "m" : "") + (pattern.sticky ? "y" : "") + (pattern.unicode ? "u" : "") + (pattern.dotAll ? "s" : ""));
38132
- }
38133
-
38134
- // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/internal/_clone.js
38135
- function _clone(value, deep, map) {
38136
- map || (map = new _ObjectMap());
38137
- if (_isPrimitive(value)) {
38138
- return value;
38139
- }
38140
- var copy = function copy2(copiedValue) {
38141
- var cachedCopy = map.get(value);
38142
- if (cachedCopy) {
38143
- return cachedCopy;
38144
- }
38145
- map.set(value, copiedValue);
38146
- for (var key in value) {
38147
- if (Object.prototype.hasOwnProperty.call(value, key)) {
38148
- copiedValue[key] = deep ? _clone(value[key], true, map) : value[key];
38149
- }
38150
- }
38151
- return copiedValue;
38152
- };
38153
- switch (type_default(value)) {
38154
- case "Object":
38155
- return copy(Object.create(Object.getPrototypeOf(value)));
38156
- case "Array":
38157
- return copy([]);
38158
- case "Date":
38159
- return new Date(value.valueOf());
38160
- case "RegExp":
38161
- return _cloneRegExp(value);
38162
- case "Int8Array":
38163
- case "Uint8Array":
38164
- case "Uint8ClampedArray":
38165
- case "Int16Array":
38166
- case "Uint16Array":
38167
- case "Int32Array":
38168
- case "Uint32Array":
38169
- case "Float32Array":
38170
- case "Float64Array":
38171
- case "BigInt64Array":
38172
- case "BigUint64Array":
38173
- return value.slice();
38174
- default:
38175
- return value;
38176
- }
38177
- }
38178
- function _isPrimitive(param) {
38179
- var type3 = typeof param;
38180
- return param == null || type3 != "object" && type3 != "function";
38181
- }
38182
- var _ObjectMap = /* @__PURE__ */ function() {
38183
- function _ObjectMap2() {
38184
- this.map = {};
38185
- this.length = 0;
38186
- }
38187
- _ObjectMap2.prototype.set = function(key, value) {
38188
- const hashedKey = this.hash(key);
38189
- let bucket = this.map[hashedKey];
38190
- if (!bucket) {
38191
- this.map[hashedKey] = bucket = [];
38192
- }
38193
- bucket.push([key, value]);
38194
- this.length += 1;
38195
- };
38196
- _ObjectMap2.prototype.hash = function(key) {
38197
- let hashedKey = [];
38198
- for (var value in key) {
38199
- hashedKey.push(Object.prototype.toString.call(key[value]));
38200
- }
38201
- return hashedKey.join();
38202
- };
38203
- _ObjectMap2.prototype.get = function(key) {
38204
- if (this.length <= 180) {
38205
- for (const p in this.map) {
38206
- const bucket2 = this.map[p];
38207
- for (let i = 0; i < bucket2.length; i += 1) {
38208
- const element = bucket2[i];
38209
- if (element[0] === key) {
38210
- return element[1];
38211
- }
38212
- }
38213
- }
38214
- return;
38215
- }
38216
- const hashedKey = this.hash(key);
38217
- const bucket = this.map[hashedKey];
38218
- if (!bucket) {
38219
- return;
38220
- }
38221
- for (let i = 0; i < bucket.length; i += 1) {
38222
- const element = bucket[i];
38223
- if (element[0] === key) {
38224
- return element[1];
38225
- }
38226
- }
38227
- };
38228
- return _ObjectMap2;
38229
- }();
38230
-
38231
- // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/clone.js
38232
- var clone2 = /* @__PURE__ */ _curry1(function clone3(value) {
38233
- return value != null && typeof value.clone === "function" ? value.clone() : _clone(value, true);
38234
- });
38235
- var clone_default = clone2;
38236
-
38237
- // ../../node_modules/.pnpm/ramda@0.29.0/node_modules/ramda/es/trim.js
38238
- var hasProtoTrim = typeof String.prototype.trim === "function";
38239
-
38240
38495
  // ../../node_modules/.pnpm/tslib@2.6.0/node_modules/tslib/tslib.es6.mjs
38241
38496
  var __assign = function() {
38242
38497
  __assign = Object.assign || function __assign2(t) {
@@ -41404,14 +41659,10 @@ spurious results.`);
41404
41659
  // src/providers/__generated__/operations.ts
41405
41660
  var ReceiptFragmentFragmentDoc = lib_default2`
41406
41661
  fragment receiptFragment on Receipt {
41407
- contract {
41408
- id
41409
- }
41662
+ id
41410
41663
  pc
41411
41664
  is
41412
- to {
41413
- id
41414
- }
41665
+ to
41415
41666
  toAddress
41416
41667
  amount
41417
41668
  assetId
@@ -41449,10 +41700,16 @@ spurious results.`);
41449
41700
  id
41450
41701
  }
41451
41702
  time
41703
+ receipts {
41704
+ ...receiptFragment
41705
+ }
41452
41706
  programState {
41453
41707
  returnType
41454
41708
  data
41455
41709
  }
41710
+ receipts {
41711
+ ...receiptFragment
41712
+ }
41456
41713
  }
41457
41714
  ... on FailureStatus {
41458
41715
  block {
@@ -41460,26 +41717,24 @@ spurious results.`);
41460
41717
  }
41461
41718
  time
41462
41719
  reason
41720
+ receipts {
41721
+ ...receiptFragment
41722
+ }
41463
41723
  }
41464
41724
  ... on SqueezedOutStatus {
41465
41725
  reason
41466
41726
  }
41467
41727
  }
41468
- `;
41728
+ ${ReceiptFragmentFragmentDoc}`;
41469
41729
  var TransactionFragmentFragmentDoc = lib_default2`
41470
41730
  fragment transactionFragment on Transaction {
41471
41731
  id
41472
41732
  rawPayload
41473
- gasPrice
41474
- receipts {
41475
- ...receiptFragment
41476
- }
41477
41733
  status {
41478
41734
  ...transactionStatusFragment
41479
41735
  }
41480
41736
  }
41481
- ${ReceiptFragmentFragmentDoc}
41482
- ${TransactionStatusFragmentFragmentDoc}`;
41737
+ ${TransactionStatusFragmentFragmentDoc}`;
41483
41738
  var InputEstimatePredicatesFragmentFragmentDoc = lib_default2`
41484
41739
  fragment inputEstimatePredicatesFragment on Input {
41485
41740
  ... on InputCoin {
@@ -41497,6 +41752,46 @@ ${TransactionStatusFragmentFragmentDoc}`;
41497
41752
  }
41498
41753
  }
41499
41754
  ${InputEstimatePredicatesFragmentFragmentDoc}`;
41755
+ var DryRunFailureStatusFragmentFragmentDoc = lib_default2`
41756
+ fragment dryRunFailureStatusFragment on DryRunFailureStatus {
41757
+ reason
41758
+ programState {
41759
+ returnType
41760
+ data
41761
+ }
41762
+ }
41763
+ `;
41764
+ var DryRunSuccessStatusFragmentFragmentDoc = lib_default2`
41765
+ fragment dryRunSuccessStatusFragment on DryRunSuccessStatus {
41766
+ programState {
41767
+ returnType
41768
+ data
41769
+ }
41770
+ }
41771
+ `;
41772
+ var DryRunTransactionStatusFragmentFragmentDoc = lib_default2`
41773
+ fragment dryRunTransactionStatusFragment on DryRunTransactionStatus {
41774
+ ... on DryRunFailureStatus {
41775
+ ...dryRunFailureStatusFragment
41776
+ }
41777
+ ... on DryRunSuccessStatus {
41778
+ ...dryRunSuccessStatusFragment
41779
+ }
41780
+ }
41781
+ ${DryRunFailureStatusFragmentFragmentDoc}
41782
+ ${DryRunSuccessStatusFragmentFragmentDoc}`;
41783
+ var DryRunTransactionExecutionStatusFragmentFragmentDoc = lib_default2`
41784
+ fragment dryRunTransactionExecutionStatusFragment on DryRunTransactionExecutionStatus {
41785
+ id
41786
+ status {
41787
+ ...dryRunTransactionStatusFragment
41788
+ }
41789
+ receipts {
41790
+ ...receiptFragment
41791
+ }
41792
+ }
41793
+ ${DryRunTransactionStatusFragmentFragmentDoc}
41794
+ ${ReceiptFragmentFragmentDoc}`;
41500
41795
  var CoinFragmentFragmentDoc = lib_default2`
41501
41796
  fragment coinFragment on Coin {
41502
41797
  __typename
@@ -41504,7 +41799,6 @@ ${TransactionStatusFragmentFragmentDoc}`;
41504
41799
  owner
41505
41800
  amount
41506
41801
  assetId
41507
- maturity
41508
41802
  blockCreated
41509
41803
  txCreatedIdx
41510
41804
  }
@@ -41543,26 +41837,32 @@ ${TransactionStatusFragmentFragmentDoc}`;
41543
41837
  messageBlockHeader {
41544
41838
  id
41545
41839
  daHeight
41840
+ consensusParametersVersion
41841
+ stateTransitionBytecodeVersion
41546
41842
  transactionsCount
41843
+ messageReceiptCount
41547
41844
  transactionsRoot
41845
+ messageOutboxRoot
41846
+ eventInboxRoot
41548
41847
  height
41549
41848
  prevRoot
41550
41849
  time
41551
41850
  applicationHash
41552
- messageReceiptRoot
41553
- messageReceiptCount
41554
41851
  }
41555
41852
  commitBlockHeader {
41556
41853
  id
41557
41854
  daHeight
41855
+ consensusParametersVersion
41856
+ stateTransitionBytecodeVersion
41558
41857
  transactionsCount
41858
+ messageReceiptCount
41559
41859
  transactionsRoot
41860
+ messageOutboxRoot
41861
+ eventInboxRoot
41560
41862
  height
41561
41863
  prevRoot
41562
41864
  time
41563
41865
  applicationHash
41564
- messageReceiptRoot
41565
- messageReceiptCount
41566
41866
  }
41567
41867
  sender
41568
41868
  recipient
@@ -41581,8 +41881,8 @@ ${TransactionStatusFragmentFragmentDoc}`;
41581
41881
  var BlockFragmentFragmentDoc = lib_default2`
41582
41882
  fragment blockFragment on Block {
41583
41883
  id
41884
+ height
41584
41885
  header {
41585
- height
41586
41886
  time
41587
41887
  }
41588
41888
  transactions {
@@ -41640,6 +41940,11 @@ ${TransactionStatusFragmentFragmentDoc}`;
41640
41940
  `;
41641
41941
  var GasCostsFragmentFragmentDoc = lib_default2`
41642
41942
  fragment GasCostsFragment on GasCosts {
41943
+ version {
41944
+ ... on Version {
41945
+ value
41946
+ }
41947
+ }
41643
41948
  add
41644
41949
  addi
41645
41950
  aloc
@@ -41652,7 +41957,6 @@ ${TransactionStatusFragmentFragmentDoc}`;
41652
41957
  cb
41653
41958
  cfei
41654
41959
  cfsi
41655
- croo
41656
41960
  div
41657
41961
  divi
41658
41962
  ecr1
@@ -41735,6 +42039,9 @@ ${TransactionStatusFragmentFragmentDoc}`;
41735
42039
  ccp {
41736
42040
  ...DependentCostFragment
41737
42041
  }
42042
+ croo {
42043
+ ...DependentCostFragment
42044
+ }
41738
42045
  csiz {
41739
42046
  ...DependentCostFragment
41740
42047
  }
@@ -41794,6 +42101,11 @@ ${TransactionStatusFragmentFragmentDoc}`;
41794
42101
  ${DependentCostFragmentFragmentDoc}`;
41795
42102
  var ConsensusParametersFragmentFragmentDoc = lib_default2`
41796
42103
  fragment consensusParametersFragment on ConsensusParameters {
42104
+ version {
42105
+ ... on Version {
42106
+ value
42107
+ }
42108
+ }
41797
42109
  txParams {
41798
42110
  ...TxParametersFragment
41799
42111
  }
@@ -41853,18 +42165,9 @@ ${ConsensusParametersFragmentFragmentDoc}`;
41853
42165
  fragment nodeInfoFragment on NodeInfo {
41854
42166
  utxoValidation
41855
42167
  vmBacktrace
41856
- minGasPrice
41857
42168
  maxTx
41858
42169
  maxDepth
41859
42170
  nodeVersion
41860
- peers {
41861
- id
41862
- addresses
41863
- clientVersion
41864
- blockHeight
41865
- lastHeartbeatMs
41866
- appScore
41867
- }
41868
42171
  }
41869
42172
  `;
41870
42173
  var GetVersionDocument = lib_default2`
@@ -41899,13 +42202,9 @@ ${ConsensusParametersFragmentFragmentDoc}`;
41899
42202
  query getTransactionWithReceipts($transactionId: TransactionId!) {
41900
42203
  transaction(id: $transactionId) {
41901
42204
  ...transactionFragment
41902
- receipts {
41903
- ...receiptFragment
41904
- }
41905
42205
  }
41906
42206
  }
41907
- ${TransactionFragmentFragmentDoc}
41908
- ${ReceiptFragmentFragmentDoc}`;
42207
+ ${TransactionFragmentFragmentDoc}`;
41909
42208
  var GetTransactionsDocument = lib_default2`
41910
42209
  query getTransactions($after: String, $before: String, $first: Int, $last: Int) {
41911
42210
  transactions(after: $after, before: $before, first: $first, last: $last) {
@@ -42033,6 +42332,20 @@ ${MessageCoinFragmentFragmentDoc}`;
42033
42332
  }
42034
42333
  }
42035
42334
  ${BalanceFragmentFragmentDoc}`;
42335
+ var GetLatestGasPriceDocument = lib_default2`
42336
+ query getLatestGasPrice {
42337
+ latestGasPrice {
42338
+ gasPrice
42339
+ }
42340
+ }
42341
+ `;
42342
+ var EstimateGasPriceDocument = lib_default2`
42343
+ query estimateGasPrice($blockHorizon: U32!) {
42344
+ estimateGasPrice(blockHorizon: $blockHorizon) {
42345
+ gasPrice
42346
+ }
42347
+ }
42348
+ `;
42036
42349
  var GetBalancesDocument = lib_default2`
42037
42350
  query getBalances($filter: BalanceFilterInput!, $after: String, $before: String, $first: Int, $last: Int) {
42038
42351
  balances(
@@ -42087,12 +42400,12 @@ ${MessageCoinFragmentFragmentDoc}`;
42087
42400
  }
42088
42401
  `;
42089
42402
  var DryRunDocument = lib_default2`
42090
- mutation dryRun($encodedTransaction: HexString!, $utxoValidation: Boolean) {
42091
- dryRun(tx: $encodedTransaction, utxoValidation: $utxoValidation) {
42092
- ...receiptFragment
42403
+ mutation dryRun($encodedTransactions: [HexString!]!, $utxoValidation: Boolean) {
42404
+ dryRun(txs: $encodedTransactions, utxoValidation: $utxoValidation) {
42405
+ ...dryRunTransactionExecutionStatusFragment
42093
42406
  }
42094
42407
  }
42095
- ${ReceiptFragmentFragmentDoc}`;
42408
+ ${DryRunTransactionExecutionStatusFragmentFragmentDoc}`;
42096
42409
  var SubmitDocument = lib_default2`
42097
42410
  mutation submit($encodedTransaction: HexString!) {
42098
42411
  submit(tx: $encodedTransaction) {
@@ -42175,6 +42488,12 @@ ${MessageCoinFragmentFragmentDoc}`;
42175
42488
  getBalance(variables, options) {
42176
42489
  return requester(GetBalanceDocument, variables, options);
42177
42490
  },
42491
+ getLatestGasPrice(variables, options) {
42492
+ return requester(GetLatestGasPriceDocument, variables, options);
42493
+ },
42494
+ estimateGasPrice(variables, options) {
42495
+ return requester(EstimateGasPriceDocument, variables, options);
42496
+ },
42178
42497
  getBalances(variables, options) {
42179
42498
  return requester(GetBalancesDocument, variables, options);
42180
42499
  },
@@ -42358,10 +42677,9 @@ ${MessageCoinFragmentFragmentDoc}`;
42358
42677
  txIndex: toNumber2(arrayify(value.txPointer).slice(8, 16))
42359
42678
  },
42360
42679
  witnessIndex: value.witnessIndex,
42361
- maturity: value.maturity ?? 0,
42362
42680
  predicateGasUsed: bn(value.predicateGasUsed),
42363
- predicateLength: predicate.length,
42364
- predicateDataLength: predicateData.length,
42681
+ predicateLength: bn(predicate.length),
42682
+ predicateDataLength: bn(predicateData.length),
42365
42683
  predicate: hexlify(predicate),
42366
42684
  predicateData: hexlify(predicateData)
42367
42685
  };
@@ -42392,8 +42710,8 @@ ${MessageCoinFragmentFragmentDoc}`;
42392
42710
  nonce: hexlify(value.nonce),
42393
42711
  witnessIndex: value.witnessIndex,
42394
42712
  predicateGasUsed: bn(value.predicateGasUsed),
42395
- predicateLength: predicate.length,
42396
- predicateDataLength: predicateData.length,
42713
+ predicateLength: bn(predicate.length),
42714
+ predicateDataLength: bn(predicateData.length),
42397
42715
  predicate: hexlify(predicate),
42398
42716
  predicateData: hexlify(predicateData),
42399
42717
  data: hexlify(data),
@@ -42550,8 +42868,8 @@ ${MessageCoinFragmentFragmentDoc}`;
42550
42868
  case "CALL" /* Call */: {
42551
42869
  const callReceipt = {
42552
42870
  type: ReceiptType.Call,
42553
- from: hexOrZero(receipt.contract?.id),
42554
- to: hexOrZero(receipt?.to?.id),
42871
+ from: hexOrZero(receipt.id || receipt.contractId),
42872
+ to: hexOrZero(receipt?.to),
42555
42873
  amount: bn(receipt.amount),
42556
42874
  assetId: hexOrZero(receipt.assetId),
42557
42875
  gas: bn(receipt.gas),
@@ -42565,7 +42883,7 @@ ${MessageCoinFragmentFragmentDoc}`;
42565
42883
  case "RETURN" /* Return */: {
42566
42884
  const returnReceipt = {
42567
42885
  type: ReceiptType.Return,
42568
- id: hexOrZero(receipt.contract?.id),
42886
+ id: hexOrZero(receipt.id || receipt.contractId),
42569
42887
  val: bn(receipt.val),
42570
42888
  pc: bn(receipt.pc),
42571
42889
  is: bn(receipt.is)
@@ -42575,7 +42893,7 @@ ${MessageCoinFragmentFragmentDoc}`;
42575
42893
  case "RETURN_DATA" /* ReturnData */: {
42576
42894
  const returnDataReceipt = {
42577
42895
  type: ReceiptType.ReturnData,
42578
- id: hexOrZero(receipt.contract?.id),
42896
+ id: hexOrZero(receipt.id || receipt.contractId),
42579
42897
  ptr: bn(receipt.ptr),
42580
42898
  len: bn(receipt.len),
42581
42899
  digest: hexOrZero(receipt.digest),
@@ -42587,7 +42905,7 @@ ${MessageCoinFragmentFragmentDoc}`;
42587
42905
  case "PANIC" /* Panic */: {
42588
42906
  const panicReceipt = {
42589
42907
  type: ReceiptType.Panic,
42590
- id: hexOrZero(receipt.contract?.id),
42908
+ id: hexOrZero(receipt.id),
42591
42909
  reason: bn(receipt.reason),
42592
42910
  pc: bn(receipt.pc),
42593
42911
  is: bn(receipt.is),
@@ -42598,7 +42916,7 @@ ${MessageCoinFragmentFragmentDoc}`;
42598
42916
  case "REVERT" /* Revert */: {
42599
42917
  const revertReceipt = {
42600
42918
  type: ReceiptType.Revert,
42601
- id: hexOrZero(receipt.contract?.id),
42919
+ id: hexOrZero(receipt.id || receipt.contractId),
42602
42920
  val: bn(receipt.ra),
42603
42921
  pc: bn(receipt.pc),
42604
42922
  is: bn(receipt.is)
@@ -42608,7 +42926,7 @@ ${MessageCoinFragmentFragmentDoc}`;
42608
42926
  case "LOG" /* Log */: {
42609
42927
  const logReceipt = {
42610
42928
  type: ReceiptType.Log,
42611
- id: hexOrZero(receipt.contract?.id),
42929
+ id: hexOrZero(receipt.id || receipt.contractId),
42612
42930
  val0: bn(receipt.ra),
42613
42931
  val1: bn(receipt.rb),
42614
42932
  val2: bn(receipt.rc),
@@ -42621,7 +42939,7 @@ ${MessageCoinFragmentFragmentDoc}`;
42621
42939
  case "LOG_DATA" /* LogData */: {
42622
42940
  const logDataReceipt = {
42623
42941
  type: ReceiptType.LogData,
42624
- id: hexOrZero(receipt.contract?.id),
42942
+ id: hexOrZero(receipt.id || receipt.contractId),
42625
42943
  val0: bn(receipt.ra),
42626
42944
  val1: bn(receipt.rb),
42627
42945
  ptr: bn(receipt.ptr),
@@ -42635,8 +42953,8 @@ ${MessageCoinFragmentFragmentDoc}`;
42635
42953
  case "TRANSFER" /* Transfer */: {
42636
42954
  const transferReceipt = {
42637
42955
  type: ReceiptType.Transfer,
42638
- from: hexOrZero(receipt.contract?.id),
42639
- to: hexOrZero(receipt.toAddress || receipt?.to?.id),
42956
+ from: hexOrZero(receipt.id || receipt.contractId),
42957
+ to: hexOrZero(receipt.toAddress || receipt?.to),
42640
42958
  amount: bn(receipt.amount),
42641
42959
  assetId: hexOrZero(receipt.assetId),
42642
42960
  pc: bn(receipt.pc),
@@ -42647,8 +42965,8 @@ ${MessageCoinFragmentFragmentDoc}`;
42647
42965
  case "TRANSFER_OUT" /* TransferOut */: {
42648
42966
  const transferOutReceipt = {
42649
42967
  type: ReceiptType.TransferOut,
42650
- from: hexOrZero(receipt.contract?.id),
42651
- to: hexOrZero(receipt.toAddress || receipt.to?.id),
42968
+ from: hexOrZero(receipt.id || receipt.contractId),
42969
+ to: hexOrZero(receipt.toAddress || receipt.to),
42652
42970
  amount: bn(receipt.amount),
42653
42971
  assetId: hexOrZero(receipt.assetId),
42654
42972
  pc: bn(receipt.pc),
@@ -42691,7 +43009,7 @@ ${MessageCoinFragmentFragmentDoc}`;
42691
43009
  return receiptMessageOut;
42692
43010
  }
42693
43011
  case "MINT" /* Mint */: {
42694
- const contractId = hexOrZero(receipt.contract?.id);
43012
+ const contractId = hexOrZero(receipt.id || receipt.contractId);
42695
43013
  const subId = hexOrZero(receipt.subId);
42696
43014
  const assetId = ReceiptMintCoder.getAssetId(contractId, subId);
42697
43015
  const mintReceipt = {
@@ -42706,7 +43024,7 @@ ${MessageCoinFragmentFragmentDoc}`;
42706
43024
  return mintReceipt;
42707
43025
  }
42708
43026
  case "BURN" /* Burn */: {
42709
- const contractId = hexOrZero(receipt.contract?.id);
43027
+ const contractId = hexOrZero(receipt.id || receipt.contractId);
42710
43028
  const subId = hexOrZero(receipt.subId);
42711
43029
  const assetId = ReceiptBurnCoder.getAssetId(contractId, subId);
42712
43030
  const burnReceipt = {
@@ -42726,7 +43044,6 @@ ${MessageCoinFragmentFragmentDoc}`;
42726
43044
  }
42727
43045
 
42728
43046
  // src/providers/utils/gas.ts
42729
- var calculatePriceWithFactor = (gas, gasPrice, priceFactor) => bn(Math.ceil(gas.mul(gasPrice).toNumber() / priceFactor.toNumber()));
42730
43047
  var getGasUsedFromReceipts = (receipts) => {
42731
43048
  const scriptResult = receipts.filter(
42732
43049
  (receipt) => receipt.type === ReceiptType.ScriptResult
@@ -42747,18 +43064,28 @@ ${MessageCoinFragmentFragmentDoc}`;
42747
43064
  }
42748
43065
  function gasUsedByInputs(inputs, txBytesSize, gasCosts) {
42749
43066
  const witnessCache = [];
42750
- const totalGas = inputs.reduce((total, input) => {
43067
+ const chargeableInputs = inputs.filter((input) => {
43068
+ const isCoinOrMessage = "owner" in input || "sender" in input;
43069
+ if (isCoinOrMessage) {
43070
+ if ("predicate" in input && input.predicate && input.predicate !== "0x") {
43071
+ return true;
43072
+ }
43073
+ if (!witnessCache.includes(input.witnessIndex)) {
43074
+ witnessCache.push(input.witnessIndex);
43075
+ return true;
43076
+ }
43077
+ }
43078
+ return false;
43079
+ });
43080
+ const vmInitializationCost = resolveGasDependentCosts(txBytesSize, gasCosts.vmInitialization);
43081
+ const totalGas = chargeableInputs.reduce((total, input) => {
42751
43082
  if ("predicate" in input && input.predicate && input.predicate !== "0x") {
42752
43083
  return total.add(
42753
- resolveGasDependentCosts(txBytesSize, gasCosts.vmInitialization).add(resolveGasDependentCosts(arrayify(input.predicate).length, gasCosts.contractRoot)).add(bn(input.predicateGasUsed))
43084
+ vmInitializationCost.add(resolveGasDependentCosts(arrayify(input.predicate).length, gasCosts.contractRoot)).add(bn(input.predicateGasUsed))
42754
43085
  );
42755
43086
  }
42756
- if ("witnessIndex" in input && !witnessCache.includes(input.witnessIndex)) {
42757
- witnessCache.push(input.witnessIndex);
42758
- return total.add(gasCosts.ecr1);
42759
- }
42760
- return total;
42761
- }, bn());
43087
+ return total.add(gasCosts.ecr1);
43088
+ }, bn(0));
42762
43089
  return totalGas;
42763
43090
  }
42764
43091
  function getMinGas(params) {
@@ -42770,12 +43097,20 @@ ${MessageCoinFragmentFragmentDoc}`;
42770
43097
  return minGas;
42771
43098
  }
42772
43099
  function getMaxGas(params) {
42773
- const { gasPerByte, witnessesLength, witnessLimit, minGas, gasLimit = bn(0) } = params;
43100
+ const {
43101
+ gasPerByte,
43102
+ witnessesLength,
43103
+ witnessLimit,
43104
+ minGas,
43105
+ gasLimit = bn(0),
43106
+ maxGasPerTx
43107
+ } = params;
42774
43108
  let remainingAllowedWitnessGas = bn(0);
42775
43109
  if (witnessLimit?.gt(0) && witnessLimit.gte(witnessesLength)) {
42776
43110
  remainingAllowedWitnessGas = bn(witnessLimit).sub(witnessesLength).mul(gasPerByte);
42777
43111
  }
42778
- return remainingAllowedWitnessGas.add(minGas).add(gasLimit);
43112
+ const maxGas = remainingAllowedWitnessGas.add(minGas).add(gasLimit);
43113
+ return maxGas.gte(maxGasPerTx) ? maxGasPerTx : maxGas;
42779
43114
  }
42780
43115
  function calculateMetadataGasForTxCreate({
42781
43116
  gasCosts,
@@ -42797,6 +43132,10 @@ ${MessageCoinFragmentFragmentDoc}`;
42797
43132
  }) {
42798
43133
  return resolveGasDependentCosts(txBytesSize, gasCosts.s256);
42799
43134
  }
43135
+ var calculateGasFee = (params) => {
43136
+ const { gas, gasPrice, priceFactor, tip } = params;
43137
+ return gas.mul(gasPrice).div(priceFactor).add(tip);
43138
+ };
42800
43139
 
42801
43140
  // src/providers/utils/json.ts
42802
43141
  function normalize2(object) {
@@ -42914,11 +43253,6 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
42914
43253
  name = "NoWitnessAtIndexError";
42915
43254
  };
42916
43255
 
42917
- // src/providers/transaction-request/helpers.ts
42918
- var isRequestInputCoin = (input) => input.type === InputType.Coin;
42919
- var isRequestInputMessage = (input) => input.type === InputType.Message;
42920
- var isRequestInputResource = (input) => isRequestInputCoin(input) || isRequestInputMessage(input);
42921
-
42922
43256
  // src/providers/transaction-request/witness.ts
42923
43257
  var witnessify = (value) => {
42924
43258
  const data = arrayify(value);
@@ -42931,7 +43265,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
42931
43265
  // src/providers/transaction-request/transaction-request.ts
42932
43266
  var BaseTransactionRequest = class {
42933
43267
  /** Gas price for transaction */
42934
- gasPrice;
43268
+ tip;
42935
43269
  /** Block until which tx cannot be included */
42936
43270
  maturity;
42937
43271
  /** The maximum fee payable by this transaction using BASE_ASSET. */
@@ -42950,7 +43284,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
42950
43284
  * @param baseTransactionRequest - Optional object containing properties to initialize the transaction request.
42951
43285
  */
42952
43286
  constructor({
42953
- gasPrice,
43287
+ tip,
42954
43288
  maturity,
42955
43289
  maxFee,
42956
43290
  witnessLimit,
@@ -42958,7 +43292,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
42958
43292
  outputs,
42959
43293
  witnesses
42960
43294
  } = {}) {
42961
- this.gasPrice = bn(gasPrice);
43295
+ this.tip = bn(tip);
42962
43296
  this.maturity = maturity ?? 0;
42963
43297
  this.witnessLimit = witnessLimit ? bn(witnessLimit) : void 0;
42964
43298
  this.maxFee = maxFee ? bn(maxFee) : void 0;
@@ -42969,9 +43303,9 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
42969
43303
  static getPolicyMeta(req) {
42970
43304
  let policyTypes = 0;
42971
43305
  const policies = [];
42972
- if (req.gasPrice) {
42973
- policyTypes += PolicyType.GasPrice;
42974
- policies.push({ data: req.gasPrice, type: PolicyType.GasPrice });
43306
+ if (req.tip) {
43307
+ policyTypes += PolicyType.Tip;
43308
+ policies.push({ data: req.tip, type: PolicyType.Tip });
42975
43309
  }
42976
43310
  if (req.witnessLimit) {
42977
43311
  policyTypes += PolicyType.WitnessLimit;
@@ -43159,9 +43493,9 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43159
43493
  * @param predicateData - Predicate data bytes.
43160
43494
  */
43161
43495
  addCoinInput(coin) {
43162
- const { assetId, owner, amount, id, predicate } = coin;
43496
+ const { assetId, owner, amount } = coin;
43163
43497
  let witnessIndex;
43164
- if (predicate) {
43498
+ if (coin.predicate) {
43165
43499
  witnessIndex = 0;
43166
43500
  } else {
43167
43501
  witnessIndex = this.getCoinInputWitnessIndexByOwner(owner);
@@ -43170,14 +43504,13 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43170
43504
  }
43171
43505
  }
43172
43506
  const input = {
43173
- id,
43507
+ ...coin,
43174
43508
  type: InputType.Coin,
43175
43509
  owner: owner.toB256(),
43176
43510
  amount,
43177
43511
  assetId,
43178
43512
  txPointer: "0x00000000000000000000000000000000",
43179
- witnessIndex,
43180
- predicate
43513
+ witnessIndex
43181
43514
  };
43182
43515
  this.pushInput(input);
43183
43516
  this.addChangeOutput(owner, assetId);
@@ -43191,10 +43524,10 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43191
43524
  * @param predicateData - Predicate data bytes.
43192
43525
  */
43193
43526
  addMessageInput(message) {
43194
- const { recipient, sender, amount, predicate, nonce } = message;
43527
+ const { recipient, sender, amount } = message;
43195
43528
  const assetId = BaseAssetId;
43196
43529
  let witnessIndex;
43197
- if (predicate) {
43530
+ if (message.predicate) {
43198
43531
  witnessIndex = 0;
43199
43532
  } else {
43200
43533
  witnessIndex = this.getCoinInputWitnessIndexByOwner(recipient);
@@ -43203,13 +43536,12 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43203
43536
  }
43204
43537
  }
43205
43538
  const input = {
43206
- nonce,
43539
+ ...message,
43207
43540
  type: InputType.Message,
43208
43541
  sender: sender.toB256(),
43209
43542
  recipient: recipient.toB256(),
43210
43543
  amount,
43211
- witnessIndex,
43212
- predicate
43544
+ witnessIndex
43213
43545
  };
43214
43546
  this.pushInput(input);
43215
43547
  this.addChangeOutput(recipient, assetId);
@@ -43319,7 +43651,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43319
43651
  }
43320
43652
  calculateMaxGas(chainInfo, minGas) {
43321
43653
  const { consensusParameters } = chainInfo;
43322
- const { gasPerByte } = consensusParameters;
43654
+ const { gasPerByte, maxGasPerTx } = consensusParameters;
43323
43655
  const witnessesLength = this.toTransaction().witnesses.reduce(
43324
43656
  (acc, wit) => acc + wit.dataLength,
43325
43657
  0
@@ -43328,7 +43660,8 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43328
43660
  gasPerByte,
43329
43661
  minGas,
43330
43662
  witnessesLength,
43331
- witnessLimit: this.witnessLimit
43663
+ witnessLimit: this.witnessLimit,
43664
+ maxGasPerTx
43332
43665
  });
43333
43666
  }
43334
43667
  /**
@@ -43346,17 +43679,20 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43346
43679
  });
43347
43680
  const updateAssetInput = (assetId, quantity) => {
43348
43681
  const assetInput = findAssetInput(assetId);
43682
+ let usedQuantity = quantity;
43683
+ if (assetId === BaseAssetId) {
43684
+ usedQuantity = bn("1000000000000000000");
43685
+ }
43349
43686
  if (assetInput && "assetId" in assetInput) {
43350
43687
  assetInput.id = hexlify(randomBytes22(UTXO_ID_LEN));
43351
- assetInput.amount = quantity;
43688
+ assetInput.amount = usedQuantity;
43352
43689
  } else {
43353
43690
  this.addResources([
43354
43691
  {
43355
43692
  id: hexlify(randomBytes22(UTXO_ID_LEN)),
43356
- amount: quantity,
43693
+ amount: usedQuantity,
43357
43694
  assetId,
43358
43695
  owner: resourcesOwner || Address.fromRandom(),
43359
- maturity: 0,
43360
43696
  blockCreated: bn(1),
43361
43697
  txCreatedIdx: bn(1)
43362
43698
  }
@@ -43388,11 +43724,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43388
43724
  toJSON() {
43389
43725
  return normalizeJSON(this);
43390
43726
  }
43391
- removeWitness(index) {
43392
- this.witnesses.splice(index, 1);
43393
- this.adjustWitnessIndexes(index);
43394
- }
43395
- updatePredicateInputs(inputs) {
43727
+ updatePredicateGasUsed(inputs) {
43396
43728
  this.inputs.forEach((i) => {
43397
43729
  let correspondingInput;
43398
43730
  switch (i.type) {
@@ -43414,10 +43746,12 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43414
43746
  }
43415
43747
  });
43416
43748
  }
43417
- adjustWitnessIndexes(removedIndex) {
43418
- this.inputs.filter(isRequestInputResource).forEach((input) => {
43419
- if (input.witnessIndex > removedIndex) {
43420
- input.witnessIndex -= 1;
43749
+ shiftPredicateData() {
43750
+ this.inputs.forEach((input) => {
43751
+ if ("predicateData" in input && "paddPredicateData" in input && typeof input.paddPredicateData === "function") {
43752
+ input.predicateData = input.paddPredicateData(
43753
+ BaseTransactionRequest.getPolicyMeta(this).policies.length
43754
+ );
43421
43755
  }
43422
43756
  });
43423
43757
  }
@@ -43554,9 +43888,8 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43554
43888
  return {
43555
43889
  type: TransactionType.Create,
43556
43890
  ...baseTransaction,
43557
- bytecodeLength: baseTransaction.witnesses[bytecodeWitnessIndex].dataLength / 4,
43558
43891
  bytecodeWitnessIndex,
43559
- storageSlotsCount: storageSlots.length,
43892
+ storageSlotsCount: bn(storageSlots.length),
43560
43893
  salt: this.salt ? hexlify(this.salt) : ZeroBytes32,
43561
43894
  storageSlots
43562
43895
  };
@@ -43670,8 +44003,8 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43670
44003
  type: TransactionType.Script,
43671
44004
  scriptGasLimit: this.gasLimit,
43672
44005
  ...super.getBaseTransaction(),
43673
- scriptLength: script.length,
43674
- scriptDataLength: scriptData.length,
44006
+ scriptLength: bn(script.length),
44007
+ scriptDataLength: bn(scriptData.length),
43675
44008
  receiptsRoot: ZeroBytes32,
43676
44009
  script: hexlify(script),
43677
44010
  scriptData: hexlify(scriptData)
@@ -43735,7 +44068,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43735
44068
  }
43736
44069
  calculateMaxGas(chainInfo, minGas) {
43737
44070
  const { consensusParameters } = chainInfo;
43738
- const { gasPerByte } = consensusParameters;
44071
+ const { gasPerByte, maxGasPerTx } = consensusParameters;
43739
44072
  const witnessesLength = this.toTransaction().witnesses.reduce(
43740
44073
  (acc, wit) => acc + wit.dataLength,
43741
44074
  0
@@ -43745,7 +44078,8 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43745
44078
  minGas,
43746
44079
  witnessesLength,
43747
44080
  witnessLimit: this.witnessLimit,
43748
- gasLimit: this.gasLimit
44081
+ gasLimit: this.gasLimit,
44082
+ maxGasPerTx
43749
44083
  });
43750
44084
  }
43751
44085
  /**
@@ -43818,13 +44152,29 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43818
44152
  }
43819
44153
  }
43820
44154
  };
44155
+ var cacheTxInputsFromOwner = (inputs, owner) => inputs.reduce(
44156
+ (acc, input) => {
44157
+ if (input.type === InputType.Coin && input.owner === owner) {
44158
+ acc.utxos.push(input.id);
44159
+ }
44160
+ if (input.type === InputType.Message && input.recipient === owner) {
44161
+ acc.messages.push(input.nonce);
44162
+ }
44163
+ return acc;
44164
+ },
44165
+ {
44166
+ utxos: [],
44167
+ messages: []
44168
+ }
44169
+ );
43821
44170
 
43822
44171
  // src/providers/transaction-summary/calculate-transaction-fee.ts
43823
44172
  var calculateTransactionFee = (params) => {
43824
44173
  const {
43825
- gasUsed,
44174
+ gasPrice,
43826
44175
  rawPayload,
43827
- consensusParameters: { gasCosts, feeParams }
44176
+ tip,
44177
+ consensusParameters: { gasCosts, feeParams, maxGasPerTx }
43828
44178
  } = params;
43829
44179
  const gasPerByte = bn(feeParams.gasPerByte);
43830
44180
  const gasPriceFactor = bn(feeParams.gasPriceFactor);
@@ -43834,8 +44184,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43834
44184
  return {
43835
44185
  fee: bn(0),
43836
44186
  minFee: bn(0),
43837
- maxFee: bn(0),
43838
- feeFromGasUsed: bn(0)
44187
+ maxFee: bn(0)
43839
44188
  };
43840
44189
  }
43841
44190
  const { type: type3, witnesses, inputs, policies } = transaction;
@@ -43867,7 +44216,6 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43867
44216
  metadataGas,
43868
44217
  txBytesSize: transactionBytes.length
43869
44218
  });
43870
- const gasPrice = bn(policies.find((policy) => policy.type === PolicyType.GasPrice)?.data);
43871
44219
  const witnessLimit = policies.find((policy) => policy.type === PolicyType.WitnessLimit)?.data;
43872
44220
  const witnessesLength = witnesses.reduce((acc, wit) => acc + wit.dataLength, 0);
43873
44221
  const maxGas = getMaxGas({
@@ -43875,17 +44223,25 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
43875
44223
  minGas,
43876
44224
  witnessesLength,
43877
44225
  gasLimit,
43878
- witnessLimit
44226
+ witnessLimit,
44227
+ maxGasPerTx
44228
+ });
44229
+ const minFee = calculateGasFee({
44230
+ gasPrice,
44231
+ gas: minGas,
44232
+ priceFactor: gasPriceFactor,
44233
+ tip
44234
+ });
44235
+ const maxFee = calculateGasFee({
44236
+ gasPrice,
44237
+ gas: maxGas,
44238
+ priceFactor: gasPriceFactor,
44239
+ tip
43879
44240
  });
43880
- const feeFromGasUsed = calculatePriceWithFactor(gasUsed, gasPrice, gasPriceFactor);
43881
- const minFee = calculatePriceWithFactor(minGas, gasPrice, gasPriceFactor);
43882
- const maxFee = calculatePriceWithFactor(maxGas, gasPrice, gasPriceFactor);
43883
- const fee = minFee.add(feeFromGasUsed);
43884
44241
  return {
43885
- fee,
43886
44242
  minFee,
43887
44243
  maxFee,
43888
- feeFromGasUsed
44244
+ fee: maxFee
43889
44245
  };
43890
44246
  };
43891
44247
 
@@ -44439,7 +44795,9 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
44439
44795
  gqlTransactionStatus,
44440
44796
  abiMap = {},
44441
44797
  maxInputs,
44442
- gasCosts
44798
+ gasCosts,
44799
+ maxGasPerTx,
44800
+ gasPrice
44443
44801
  } = params;
44444
44802
  const gasUsed = getGasUsedFromReceipts(receipts);
44445
44803
  const rawPayload = hexlify(transactionBytes);
@@ -44453,11 +44811,14 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
44453
44811
  maxInputs
44454
44812
  });
44455
44813
  const typeName = getTransactionTypeName(transaction.type);
44814
+ const tip = bn(transaction.policies?.find((policy) => policy.type === PolicyType.Tip)?.data);
44456
44815
  const { fee } = calculateTransactionFee({
44457
- gasUsed,
44816
+ gasPrice,
44458
44817
  rawPayload,
44818
+ tip,
44459
44819
  consensusParameters: {
44460
44820
  gasCosts,
44821
+ maxGasPerTx,
44461
44822
  feeParams: {
44462
44823
  gasPerByte,
44463
44824
  gasPriceFactor
@@ -44593,8 +44954,13 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
44593
44954
  const decodedTransaction = this.decodeTransaction(
44594
44955
  transaction
44595
44956
  );
44596
- const receipts = transaction.receipts?.map(processGqlReceipt) || [];
44597
- const { gasPerByte, gasPriceFactor, gasCosts } = this.provider.getGasConfig();
44957
+ let txReceipts = [];
44958
+ if (transaction?.status && "receipts" in transaction.status) {
44959
+ txReceipts = transaction.status.receipts;
44960
+ }
44961
+ const receipts = txReceipts.map(processGqlReceipt) || [];
44962
+ const { gasPerByte, gasPriceFactor, gasCosts, maxGasPerTx } = this.provider.getGasConfig();
44963
+ const gasPrice = await this.provider.getLatestGasPrice();
44598
44964
  const maxInputs = this.provider.getChain().consensusParameters.maxInputs;
44599
44965
  const transactionSummary = assembleTransactionSummary({
44600
44966
  id: this.id,
@@ -44606,7 +44972,9 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
44606
44972
  gasPriceFactor,
44607
44973
  abiMap: contractsAbiMap,
44608
44974
  maxInputs,
44609
- gasCosts
44975
+ gasCosts,
44976
+ maxGasPerTx,
44977
+ gasPrice
44610
44978
  });
44611
44979
  return transactionSummary;
44612
44980
  }
@@ -44755,7 +45123,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
44755
45123
  gasCosts,
44756
45124
  latestBlock: {
44757
45125
  id: latestBlock.id,
44758
- height: bn(latestBlock.header.height),
45126
+ height: bn(latestBlock.height),
44759
45127
  time: latestBlock.header.time,
44760
45128
  transactions: latestBlock.transactions.map((i) => ({
44761
45129
  id: i.id
@@ -44849,10 +45217,8 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
44849
45217
  * Returns some helpful parameters related to gas fees.
44850
45218
  */
44851
45219
  getGasConfig() {
44852
- const { minGasPrice } = this.getNode();
44853
45220
  const { maxGasPerTx, maxGasPerPredicate, gasPriceFactor, gasPerByte, gasCosts } = this.getChain().consensusParameters;
44854
45221
  return {
44855
- minGasPrice,
44856
45222
  maxGasPerTx,
44857
45223
  maxGasPerPredicate,
44858
45224
  gasPriceFactor,
@@ -44950,7 +45316,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
44950
45316
  */
44951
45317
  async getBlockNumber() {
44952
45318
  const { chain } = await this.operations.getChain();
44953
- return bn(chain.latestBlock.header.height, 10);
45319
+ return bn(chain.latestBlock.height, 10);
44954
45320
  }
44955
45321
  /**
44956
45322
  * Returns the chain information.
@@ -44962,11 +45328,9 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
44962
45328
  const processedNodeInfo = {
44963
45329
  maxDepth: bn(nodeInfo.maxDepth),
44964
45330
  maxTx: bn(nodeInfo.maxTx),
44965
- minGasPrice: bn(nodeInfo.minGasPrice),
44966
45331
  nodeVersion: nodeInfo.nodeVersion,
44967
45332
  utxoValidation: nodeInfo.utxoValidation,
44968
- vmBacktrace: nodeInfo.vmBacktrace,
44969
- peers: nodeInfo.peers
45333
+ vmBacktrace: nodeInfo.vmBacktrace
44970
45334
  };
44971
45335
  _Provider.nodeInfoCache[this.url] = processedNodeInfo;
44972
45336
  return processedNodeInfo;
@@ -45052,14 +45416,13 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45052
45416
  return this.estimateTxDependencies(transactionRequest);
45053
45417
  }
45054
45418
  const encodedTransaction = hexlify(transactionRequest.toTransactionBytes());
45055
- const { dryRun: gqlReceipts } = await this.operations.dryRun({
45056
- encodedTransaction,
45419
+ const { dryRun: dryRunStatuses } = await this.operations.dryRun({
45420
+ encodedTransactions: encodedTransaction,
45057
45421
  utxoValidation: utxoValidation || false
45058
45422
  });
45059
- const receipts = gqlReceipts.map(processGqlReceipt);
45060
- return {
45061
- receipts
45062
- };
45423
+ const [{ receipts: rawReceipts, status }] = dryRunStatuses;
45424
+ const receipts = rawReceipts.map(processGqlReceipt);
45425
+ return { receipts, dryrunStatus: status };
45063
45426
  }
45064
45427
  /**
45065
45428
  * Verifies whether enough gas is available to complete transaction.
@@ -45098,9 +45461,6 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45098
45461
  * If there are missing variable outputs,
45099
45462
  * `addVariableOutputs` is called on the transaction.
45100
45463
  *
45101
- * @privateRemarks
45102
- * TODO: Investigate support for missing contract IDs
45103
- * TODO: Add support for missing output messages
45104
45464
  *
45105
45465
  * @param transactionRequest - The transaction request object.
45106
45466
  * @returns A promise.
@@ -45113,16 +45473,19 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45113
45473
  missingContractIds: []
45114
45474
  };
45115
45475
  }
45116
- await this.estimatePredicates(transactionRequest);
45117
45476
  let receipts = [];
45118
45477
  const missingContractIds = [];
45119
45478
  let outputVariables = 0;
45479
+ let dryrunStatus;
45120
45480
  for (let attempt = 0; attempt < MAX_RETRIES; attempt++) {
45121
- const { dryRun: gqlReceipts } = await this.operations.dryRun({
45122
- encodedTransaction: hexlify(transactionRequest.toTransactionBytes()),
45481
+ const {
45482
+ dryRun: [{ receipts: rawReceipts, status }]
45483
+ } = await this.operations.dryRun({
45484
+ encodedTransactions: [hexlify(transactionRequest.toTransactionBytes())],
45123
45485
  utxoValidation: false
45124
45486
  });
45125
- receipts = gqlReceipts.map(processGqlReceipt);
45487
+ receipts = rawReceipts.map(processGqlReceipt);
45488
+ dryrunStatus = status;
45126
45489
  const { missingOutputVariables, missingOutputContractIds } = getReceiptsWithMissingData(receipts);
45127
45490
  const hasMissingOutputs = missingOutputVariables.length !== 0 || missingOutputContractIds.length !== 0;
45128
45491
  if (hasMissingOutputs) {
@@ -45132,6 +45495,10 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45132
45495
  transactionRequest.addContractInputAndOutput(Address.fromString(contractId));
45133
45496
  missingContractIds.push(contractId);
45134
45497
  });
45498
+ const { maxFee } = await this.estimateTxGasAndFee({
45499
+ transactionRequest
45500
+ });
45501
+ transactionRequest.maxFee = maxFee;
45135
45502
  } else {
45136
45503
  break;
45137
45504
  }
@@ -45139,37 +45506,139 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45139
45506
  return {
45140
45507
  receipts,
45141
45508
  outputVariables,
45142
- missingContractIds
45509
+ missingContractIds,
45510
+ dryrunStatus
45143
45511
  };
45144
45512
  }
45513
+ /**
45514
+ * Dry runs multiple transactions and checks for missing dependencies in batches.
45515
+ *
45516
+ * Transactions are dry run in batches. After each dry run, transactions requiring
45517
+ * further modifications are identified. The method iteratively updates these transactions
45518
+ * and performs subsequent dry runs until all dependencies for each transaction are satisfied.
45519
+ *
45520
+ * @param transactionRequests - Array of transaction request objects.
45521
+ * @returns A promise that resolves to an array of results for each transaction.
45522
+ */
45523
+ async estimateMultipleTxDependencies(transactionRequests) {
45524
+ const results = transactionRequests.map(() => ({
45525
+ receipts: [],
45526
+ outputVariables: 0,
45527
+ missingContractIds: [],
45528
+ dryrunStatus: void 0
45529
+ }));
45530
+ const allRequests = clone_default(transactionRequests);
45531
+ const serializedTransactionsMap = /* @__PURE__ */ new Map();
45532
+ allRequests.forEach((req, index) => {
45533
+ if (req.type === TransactionType.Script) {
45534
+ serializedTransactionsMap.set(index, hexlify(req.toTransactionBytes()));
45535
+ }
45536
+ });
45537
+ let transactionsToProcess = Array.from(serializedTransactionsMap.keys());
45538
+ let attempt = 0;
45539
+ while (transactionsToProcess.length > 0 && attempt < MAX_RETRIES) {
45540
+ const encodedTransactions = transactionsToProcess.map(
45541
+ (index) => serializedTransactionsMap.get(index)
45542
+ );
45543
+ const dryRunResults = await this.operations.dryRun({
45544
+ encodedTransactions,
45545
+ utxoValidation: false
45546
+ });
45547
+ const nextRoundTransactions = [];
45548
+ for (let i = 0; i < dryRunResults.dryRun.length; i++) {
45549
+ const currentResultIndex = transactionsToProcess[i];
45550
+ const { receipts: rawReceipts, status } = dryRunResults.dryRun[i];
45551
+ results[currentResultIndex].receipts = rawReceipts.map(processGqlReceipt);
45552
+ results[currentResultIndex].dryrunStatus = status;
45553
+ const { missingOutputVariables, missingOutputContractIds } = getReceiptsWithMissingData(
45554
+ results[currentResultIndex].receipts
45555
+ );
45556
+ const hasMissingOutputs = missingOutputVariables.length > 0 || missingOutputContractIds.length > 0;
45557
+ const requestToProcess = allRequests[currentResultIndex];
45558
+ if (hasMissingOutputs && requestToProcess?.type === TransactionType.Script) {
45559
+ results[currentResultIndex].outputVariables += missingOutputVariables.length;
45560
+ requestToProcess.addVariableOutputs(missingOutputVariables.length);
45561
+ missingOutputContractIds.forEach(({ contractId }) => {
45562
+ requestToProcess.addContractInputAndOutput(Address.fromString(contractId));
45563
+ results[currentResultIndex].missingContractIds.push(contractId);
45564
+ });
45565
+ const { maxFee } = await this.estimateTxGasAndFee({
45566
+ transactionRequest: requestToProcess
45567
+ });
45568
+ requestToProcess.maxFee = maxFee;
45569
+ serializedTransactionsMap.set(
45570
+ currentResultIndex,
45571
+ hexlify(requestToProcess.toTransactionBytes())
45572
+ );
45573
+ nextRoundTransactions.push(currentResultIndex);
45574
+ allRequests[currentResultIndex] = requestToProcess;
45575
+ }
45576
+ }
45577
+ transactionsToProcess = nextRoundTransactions;
45578
+ attempt += 1;
45579
+ }
45580
+ return results;
45581
+ }
45582
+ async dryRunMultipleTransactions(transactionRequests, { utxoValidation, estimateTxDependencies = true } = {}) {
45583
+ if (estimateTxDependencies) {
45584
+ return this.estimateMultipleTxDependencies(transactionRequests);
45585
+ }
45586
+ const encodedTransactions = transactionRequests.map((tx) => hexlify(tx.toTransactionBytes()));
45587
+ const { dryRun: dryRunStatuses } = await this.operations.dryRun({
45588
+ encodedTransactions,
45589
+ utxoValidation: utxoValidation || false
45590
+ });
45591
+ const results = dryRunStatuses.map(({ receipts: rawReceipts, status }) => {
45592
+ const receipts = rawReceipts.map(processGqlReceipt);
45593
+ return { receipts, dryrunStatus: status };
45594
+ });
45595
+ return results;
45596
+ }
45145
45597
  /**
45146
45598
  * Estimates the transaction gas and fee based on the provided transaction request.
45147
45599
  * @param transactionRequest - The transaction request object.
45148
45600
  * @returns An object containing the estimated minimum gas, minimum fee, maximum gas, and maximum fee.
45149
45601
  */
45150
- estimateTxGasAndFee(params) {
45602
+ async estimateTxGasAndFee(params) {
45151
45603
  const { transactionRequest } = params;
45152
- const { gasPriceFactor, minGasPrice, maxGasPerTx } = this.getGasConfig();
45604
+ let { gasPrice } = params;
45153
45605
  const chainInfo = this.getChain();
45154
- const gasPrice = transactionRequest.gasPrice.eq(0) ? minGasPrice : transactionRequest.gasPrice;
45155
- transactionRequest.gasPrice = gasPrice;
45606
+ const { gasPriceFactor, maxGasPerTx } = this.getGasConfig();
45156
45607
  const minGas = transactionRequest.calculateMinGas(chainInfo);
45157
- const minFee = calculatePriceWithFactor(minGas, gasPrice, gasPriceFactor).normalizeZeroToOne();
45608
+ if (!gasPrice) {
45609
+ gasPrice = await this.estimateGasPrice(10);
45610
+ }
45611
+ const minFee = calculateGasFee({
45612
+ gasPrice: bn(gasPrice),
45613
+ gas: minGas,
45614
+ priceFactor: gasPriceFactor,
45615
+ tip: transactionRequest.tip
45616
+ }).add(1);
45617
+ let gasLimit = bn(0);
45158
45618
  if (transactionRequest.type === TransactionType.Script) {
45619
+ gasLimit = transactionRequest.gasLimit;
45159
45620
  if (transactionRequest.gasLimit.eq(0)) {
45160
45621
  transactionRequest.gasLimit = minGas;
45161
45622
  transactionRequest.gasLimit = maxGasPerTx.sub(
45162
45623
  transactionRequest.calculateMaxGas(chainInfo, minGas)
45163
45624
  );
45625
+ gasLimit = transactionRequest.gasLimit;
45164
45626
  }
45165
45627
  }
45166
45628
  const maxGas = transactionRequest.calculateMaxGas(chainInfo, minGas);
45167
- const maxFee = calculatePriceWithFactor(maxGas, gasPrice, gasPriceFactor).normalizeZeroToOne();
45629
+ const maxFee = calculateGasFee({
45630
+ gasPrice: bn(gasPrice),
45631
+ gas: maxGas,
45632
+ priceFactor: gasPriceFactor,
45633
+ tip: transactionRequest.tip
45634
+ }).add(1);
45168
45635
  return {
45169
45636
  minGas,
45170
45637
  minFee,
45171
45638
  maxGas,
45172
- maxFee
45639
+ maxFee,
45640
+ gasPrice,
45641
+ gasLimit
45173
45642
  };
45174
45643
  }
45175
45644
  /**
@@ -45187,15 +45656,17 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45187
45656
  if (estimateTxDependencies) {
45188
45657
  return this.estimateTxDependencies(transactionRequest);
45189
45658
  }
45190
- const encodedTransaction = hexlify(transactionRequest.toTransactionBytes());
45191
- const { dryRun: gqlReceipts } = await this.operations.dryRun({
45192
- encodedTransaction,
45659
+ const encodedTransactions = [hexlify(transactionRequest.toTransactionBytes())];
45660
+ const { dryRun: dryRunStatuses } = await this.operations.dryRun({
45661
+ encodedTransactions,
45193
45662
  utxoValidation: true
45194
45663
  });
45195
- const receipts = gqlReceipts.map(processGqlReceipt);
45196
- return {
45197
- receipts
45198
- };
45664
+ const callResult = dryRunStatuses.map((dryRunStatus) => {
45665
+ const { id, receipts, status } = dryRunStatus;
45666
+ const processedReceipts = receipts.map(processGqlReceipt);
45667
+ return { id, receipts: processedReceipts, status };
45668
+ });
45669
+ return { receipts: callResult[0].receipts };
45199
45670
  }
45200
45671
  /**
45201
45672
  * Returns a transaction cost to enable user
@@ -45212,77 +45683,79 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45212
45683
  * @param tolerance - The tolerance to add on top of the gasUsed.
45213
45684
  * @returns A promise that resolves to the transaction cost object.
45214
45685
  */
45215
- async getTransactionCost(transactionRequestLike, forwardingQuantities = [], {
45216
- estimateTxDependencies = true,
45217
- estimatePredicates = true,
45218
- resourcesOwner,
45219
- signatureCallback
45220
- } = {}) {
45686
+ async getTransactionCost(transactionRequestLike, { resourcesOwner, signatureCallback, quantitiesToContract = [] } = {}) {
45221
45687
  const txRequestClone = clone_default(transactionRequestify(transactionRequestLike));
45222
- const { minGasPrice } = this.getGasConfig();
45223
- const setGasPrice = max(txRequestClone.gasPrice, minGasPrice);
45224
45688
  const isScriptTransaction = txRequestClone.type === TransactionType.Script;
45225
45689
  const coinOutputsQuantities = txRequestClone.getCoinOutputsQuantities();
45226
- const allQuantities = mergeQuantities(coinOutputsQuantities, forwardingQuantities);
45690
+ const allQuantities = mergeQuantities(coinOutputsQuantities, quantitiesToContract);
45227
45691
  txRequestClone.fundWithFakeUtxos(allQuantities, resourcesOwner?.address);
45692
+ txRequestClone.maxFee = bn(0);
45228
45693
  if (isScriptTransaction) {
45229
45694
  txRequestClone.gasLimit = bn(0);
45230
45695
  }
45231
- if (estimatePredicates) {
45232
- if (resourcesOwner && "populateTransactionPredicateData" in resourcesOwner) {
45233
- resourcesOwner.populateTransactionPredicateData(txRequestClone);
45234
- }
45235
- await this.estimatePredicates(txRequestClone);
45696
+ if (resourcesOwner && "populateTransactionPredicateData" in resourcesOwner) {
45697
+ resourcesOwner.populateTransactionPredicateData(txRequestClone);
45236
45698
  }
45699
+ const signedRequest = clone_default(txRequestClone);
45700
+ let addedSignatures = 0;
45237
45701
  if (signatureCallback && isScriptTransaction) {
45238
- await signatureCallback(txRequestClone);
45702
+ const lengthBefore = signedRequest.witnesses.length;
45703
+ await signatureCallback(signedRequest);
45704
+ addedSignatures = signedRequest.witnesses.length - lengthBefore;
45239
45705
  }
45240
- let { maxFee, maxGas, minFee, minGas } = this.estimateTxGasAndFee({
45241
- transactionRequest: txRequestClone
45706
+ await this.estimatePredicates(signedRequest);
45707
+ let { maxFee, maxGas, minFee, minGas, gasPrice, gasLimit } = await this.estimateTxGasAndFee({
45708
+ transactionRequest: signedRequest
45242
45709
  });
45243
45710
  let receipts = [];
45244
45711
  let missingContractIds = [];
45245
45712
  let outputVariables = 0;
45246
45713
  let gasUsed = bn(0);
45247
- if (isScriptTransaction && estimateTxDependencies) {
45248
- txRequestClone.gasPrice = bn(0);
45714
+ txRequestClone.updatePredicateGasUsed(signedRequest.inputs);
45715
+ txRequestClone.maxFee = maxFee;
45716
+ if (isScriptTransaction) {
45717
+ txRequestClone.gasLimit = gasLimit;
45718
+ if (signatureCallback) {
45719
+ await signatureCallback(txRequestClone);
45720
+ }
45249
45721
  const result = await this.estimateTxDependencies(txRequestClone);
45250
45722
  receipts = result.receipts;
45251
45723
  outputVariables = result.outputVariables;
45252
45724
  missingContractIds = result.missingContractIds;
45253
45725
  gasUsed = isScriptTransaction ? getGasUsedFromReceipts(receipts) : gasUsed;
45254
45726
  txRequestClone.gasLimit = gasUsed;
45255
- txRequestClone.gasPrice = setGasPrice;
45256
- ({ maxFee, maxGas, minFee, minGas } = this.estimateTxGasAndFee({
45257
- transactionRequest: txRequestClone
45727
+ ({ maxFee, maxGas, minFee, minGas, gasPrice } = await this.estimateTxGasAndFee({
45728
+ transactionRequest: txRequestClone,
45729
+ gasPrice
45258
45730
  }));
45259
45731
  }
45260
45732
  return {
45261
45733
  requiredQuantities: allQuantities,
45262
45734
  receipts,
45263
45735
  gasUsed,
45264
- minGasPrice,
45265
- gasPrice: setGasPrice,
45736
+ gasPrice,
45266
45737
  minGas,
45267
45738
  maxGas,
45268
45739
  minFee,
45269
45740
  maxFee,
45270
- estimatedInputs: txRequestClone.inputs,
45271
45741
  outputVariables,
45272
- missingContractIds
45742
+ missingContractIds,
45743
+ addedSignatures,
45744
+ estimatedPredicates: txRequestClone.inputs
45273
45745
  };
45274
45746
  }
45275
- async getResourcesForTransaction(owner, transactionRequestLike, forwardingQuantities = []) {
45747
+ async getResourcesForTransaction(owner, transactionRequestLike, quantitiesToContract = []) {
45276
45748
  const ownerAddress = Address.fromAddressOrString(owner);
45277
45749
  const transactionRequest = transactionRequestify(clone_default(transactionRequestLike));
45278
- const transactionCost = await this.getTransactionCost(transactionRequest, forwardingQuantities);
45750
+ const transactionCost = await this.getTransactionCost(transactionRequest, {
45751
+ quantitiesToContract
45752
+ });
45279
45753
  transactionRequest.addResources(
45280
45754
  await this.getResourcesToSpend(ownerAddress, transactionCost.requiredQuantities)
45281
45755
  );
45282
- const { requiredQuantities, ...txCost } = await this.getTransactionCost(
45283
- transactionRequest,
45284
- forwardingQuantities
45285
- );
45756
+ const { requiredQuantities, ...txCost } = await this.getTransactionCost(transactionRequest, {
45757
+ quantitiesToContract
45758
+ });
45286
45759
  const resources = await this.getResourcesToSpend(ownerAddress, requiredQuantities);
45287
45760
  return {
45288
45761
  resources,
@@ -45306,7 +45779,6 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45306
45779
  assetId: coin.assetId,
45307
45780
  amount: bn(coin.amount),
45308
45781
  owner: Address.fromAddressOrString(coin.owner),
45309
- maturity: bn(coin.maturity).toNumber(),
45310
45782
  blockCreated: bn(coin.blockCreated),
45311
45783
  txCreatedIdx: bn(coin.txCreatedIdx)
45312
45784
  }));
@@ -45358,7 +45830,6 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45358
45830
  amount: bn(coin.amount),
45359
45831
  assetId: coin.assetId,
45360
45832
  owner: Address.fromAddressOrString(coin.owner),
45361
- maturity: bn(coin.maturity).toNumber(),
45362
45833
  blockCreated: bn(coin.blockCreated),
45363
45834
  txCreatedIdx: bn(coin.txCreatedIdx)
45364
45835
  };
@@ -45391,7 +45862,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45391
45862
  }
45392
45863
  return {
45393
45864
  id: block2.id,
45394
- height: bn(block2.header.height),
45865
+ height: bn(block2.height),
45395
45866
  time: block2.header.time,
45396
45867
  transactionIds: block2.transactions.map((tx) => tx.id)
45397
45868
  };
@@ -45406,7 +45877,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45406
45877
  const { blocks: fetchedData } = await this.operations.getBlocks(params);
45407
45878
  const blocks = fetchedData.edges.map(({ node: block2 }) => ({
45408
45879
  id: block2.id,
45409
- height: bn(block2.header.height),
45880
+ height: bn(block2.height),
45410
45881
  time: block2.header.time,
45411
45882
  transactionIds: block2.transactions.map((tx) => tx.id)
45412
45883
  }));
@@ -45433,7 +45904,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45433
45904
  }
45434
45905
  return {
45435
45906
  id: block2.id,
45436
- height: bn(block2.header.height, 10),
45907
+ height: bn(block2.height, 10),
45437
45908
  time: block2.header.time,
45438
45909
  transactionIds: block2.transactions.map((tx) => tx.id),
45439
45910
  transactions: block2.transactions.map(
@@ -45613,8 +46084,11 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45613
46084
  prevRoot: messageBlockHeader.prevRoot,
45614
46085
  time: messageBlockHeader.time,
45615
46086
  applicationHash: messageBlockHeader.applicationHash,
45616
- messageReceiptRoot: messageBlockHeader.messageReceiptRoot,
45617
- messageReceiptCount: bn(messageBlockHeader.messageReceiptCount)
46087
+ messageReceiptCount: bn(messageBlockHeader.messageReceiptCount),
46088
+ messageOutboxRoot: messageBlockHeader.messageOutboxRoot,
46089
+ consensusParametersVersion: messageBlockHeader.consensusParametersVersion,
46090
+ eventInboxRoot: messageBlockHeader.eventInboxRoot,
46091
+ stateTransitionBytecodeVersion: messageBlockHeader.stateTransitionBytecodeVersion
45618
46092
  },
45619
46093
  commitBlockHeader: {
45620
46094
  id: commitBlockHeader.id,
@@ -45625,8 +46099,11 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45625
46099
  prevRoot: commitBlockHeader.prevRoot,
45626
46100
  time: commitBlockHeader.time,
45627
46101
  applicationHash: commitBlockHeader.applicationHash,
45628
- messageReceiptRoot: commitBlockHeader.messageReceiptRoot,
45629
- messageReceiptCount: bn(commitBlockHeader.messageReceiptCount)
46102
+ messageReceiptCount: bn(commitBlockHeader.messageReceiptCount),
46103
+ messageOutboxRoot: commitBlockHeader.messageOutboxRoot,
46104
+ consensusParametersVersion: commitBlockHeader.consensusParametersVersion,
46105
+ eventInboxRoot: commitBlockHeader.eventInboxRoot,
46106
+ stateTransitionBytecodeVersion: commitBlockHeader.stateTransitionBytecodeVersion
45630
46107
  },
45631
46108
  sender: Address.fromAddressOrString(sender),
45632
46109
  recipient: Address.fromAddressOrString(recipient),
@@ -45635,6 +46112,16 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45635
46112
  data
45636
46113
  };
45637
46114
  }
46115
+ async getLatestGasPrice() {
46116
+ const { latestGasPrice } = await this.operations.getLatestGasPrice();
46117
+ return bn(latestGasPrice.gasPrice);
46118
+ }
46119
+ async estimateGasPrice(blockHorizon) {
46120
+ const { estimateGasPrice } = await this.operations.estimateGasPrice({
46121
+ blockHorizon: String(blockHorizon)
46122
+ });
46123
+ return bn(estimateGasPrice.gasPrice);
46124
+ }
45638
46125
  /**
45639
46126
  * Returns Message Proof for given transaction id and the message id from MessageOut receipt.
45640
46127
  *
@@ -45918,36 +46405,33 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45918
46405
  * @param fee - The estimated transaction fee.
45919
46406
  * @returns A promise that resolves when the resources are added to the transaction.
45920
46407
  */
45921
- async fund(request, coinQuantities, fee) {
45922
- const updatedQuantities = addAmountToAsset({
46408
+ async fund(request, params) {
46409
+ const { addedSignatures, estimatedPredicates, maxFee: fee, requiredQuantities } = params;
46410
+ const txRequest = request;
46411
+ const requiredQuantitiesWithFee = addAmountToCoinQuantities({
45923
46412
  amount: bn(fee),
45924
46413
  assetId: BaseAssetId,
45925
- coinQuantities
46414
+ coinQuantities: requiredQuantities
45926
46415
  });
45927
46416
  const quantitiesDict = {};
45928
- updatedQuantities.forEach(({ amount, assetId }) => {
46417
+ requiredQuantitiesWithFee.forEach(({ amount, assetId }) => {
45929
46418
  quantitiesDict[assetId] = {
45930
46419
  required: amount,
45931
46420
  owned: bn(0)
45932
46421
  };
45933
46422
  });
45934
- const cachedUtxos = [];
45935
- const cachedMessages = [];
45936
- const owner = this.address.toB256();
45937
- request.inputs.forEach((input) => {
46423
+ txRequest.inputs.forEach((input) => {
45938
46424
  const isResource = "amount" in input;
45939
46425
  if (isResource) {
45940
46426
  const isCoin2 = "owner" in input;
45941
46427
  if (isCoin2) {
45942
46428
  const assetId = String(input.assetId);
45943
- if (input.owner === owner && quantitiesDict[assetId]) {
46429
+ if (quantitiesDict[assetId]) {
45944
46430
  const amount = bn(input.amount);
45945
46431
  quantitiesDict[assetId].owned = quantitiesDict[assetId].owned.add(amount);
45946
- cachedUtxos.push(input.id);
45947
46432
  }
45948
- } else if (input.recipient === owner && input.amount && quantitiesDict[BaseAssetId]) {
46433
+ } else if (input.amount && quantitiesDict[BaseAssetId]) {
45949
46434
  quantitiesDict[BaseAssetId].owned = quantitiesDict[BaseAssetId].owned.add(input.amount);
45950
- cachedMessages.push(input.nonce);
45951
46435
  }
45952
46436
  }
45953
46437
  });
@@ -45962,12 +46446,23 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45962
46446
  });
45963
46447
  const needsToBeFunded = missingQuantities.length;
45964
46448
  if (needsToBeFunded) {
45965
- const resources = await this.getResourcesToSpend(missingQuantities, {
45966
- messages: cachedMessages,
45967
- utxos: cachedUtxos
45968
- });
45969
- request.addResources(resources);
46449
+ const excludedIds = cacheTxInputsFromOwner(txRequest.inputs, this.address.toB256());
46450
+ const resources = await this.getResourcesToSpend(missingQuantities, excludedIds);
46451
+ txRequest.addResources(resources);
46452
+ }
46453
+ txRequest.shiftPredicateData();
46454
+ txRequest.updatePredicateGasUsed(estimatedPredicates);
46455
+ const requestToBeReEstimate = clone_default(txRequest);
46456
+ if (addedSignatures) {
46457
+ Array.from({ length: addedSignatures }).forEach(
46458
+ () => requestToBeReEstimate.addEmptyWitness()
46459
+ );
45970
46460
  }
46461
+ const { maxFee } = await this.provider.estimateTxGasAndFee({
46462
+ transactionRequest: requestToBeReEstimate
46463
+ });
46464
+ txRequest.maxFee = maxFee;
46465
+ return txRequest;
45971
46466
  }
45972
46467
  /**
45973
46468
  * A helper that creates a transfer transaction request and returns it.
@@ -45975,28 +46470,25 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
45975
46470
  * @param destination - The address of the destination.
45976
46471
  * @param amount - The amount of coins to transfer.
45977
46472
  * @param assetId - The asset ID of the coins to transfer.
45978
- * @param txParams - The transaction parameters (gasLimit, gasPrice, maturity).
46473
+ * @param txParams - The transaction parameters (gasLimit, tip, maturity, maxFee, witnessLimit).
45979
46474
  * @returns A promise that resolves to the prepared transaction request.
45980
46475
  */
45981
46476
  async createTransfer(destination, amount, assetId = BaseAssetId, txParams = {}) {
45982
- const { minGasPrice } = this.provider.getGasConfig();
45983
- const params = { gasPrice: minGasPrice, ...txParams };
45984
- const request = new ScriptTransactionRequest(params);
46477
+ const request = new ScriptTransactionRequest(txParams);
45985
46478
  request.addCoinOutput(Address.fromAddressOrString(destination), amount, assetId);
45986
- const { maxFee, requiredQuantities, gasUsed, estimatedInputs } = await this.provider.getTransactionCost(request, [], {
46479
+ const txCost = await this.provider.getTransactionCost(request, {
45987
46480
  estimateTxDependencies: true,
45988
46481
  resourcesOwner: this
45989
46482
  });
45990
- request.gasPrice = bn(txParams.gasPrice ?? minGasPrice);
45991
- request.gasLimit = bn(txParams.gasLimit ?? gasUsed);
45992
- this.validateGas({
45993
- gasUsed,
45994
- gasPrice: request.gasPrice,
45995
- gasLimit: request.gasLimit,
45996
- minGasPrice
45997
- });
45998
- await this.fund(request, requiredQuantities, maxFee);
45999
- request.updatePredicateInputs(estimatedInputs);
46483
+ if ("gasLimit" in txParams) {
46484
+ this.validateGas({
46485
+ gasUsed: txCost.gasUsed,
46486
+ gasLimit: request.gasLimit
46487
+ });
46488
+ }
46489
+ request.gasLimit = txCost.gasUsed;
46490
+ request.maxFee = txCost.maxFee;
46491
+ await this.fund(request, txCost);
46000
46492
  return request;
46001
46493
  }
46002
46494
  /**
@@ -46035,31 +46527,30 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
46035
46527
  );
46036
46528
  }
46037
46529
  const contractAddress = Address.fromAddressOrString(contractId);
46038
- const { minGasPrice } = this.provider.getGasConfig();
46039
- const params = { gasPrice: minGasPrice, ...txParams };
46040
46530
  const { script, scriptData } = await assembleTransferToContractScript({
46041
46531
  hexlifiedContractId: contractAddress.toB256(),
46042
46532
  amountToTransfer: bn(amount),
46043
46533
  assetId
46044
46534
  });
46045
46535
  const request = new ScriptTransactionRequest({
46046
- ...params,
46536
+ ...txParams,
46047
46537
  script,
46048
46538
  scriptData
46049
46539
  });
46050
46540
  request.addContractInputAndOutput(contractAddress);
46051
- const { maxFee, requiredQuantities, gasUsed } = await this.provider.getTransactionCost(
46052
- request,
46053
- [{ amount: bn(amount), assetId: String(assetId) }]
46054
- );
46055
- request.gasLimit = bn(params.gasLimit ?? gasUsed);
46056
- this.validateGas({
46057
- gasUsed,
46058
- gasPrice: request.gasPrice,
46059
- gasLimit: request.gasLimit,
46060
- minGasPrice
46541
+ const txCost = await this.provider.getTransactionCost(request, {
46542
+ resourcesOwner: this,
46543
+ quantitiesToContract: [{ amount: bn(amount), assetId: String(assetId) }]
46061
46544
  });
46062
- await this.fund(request, requiredQuantities, maxFee);
46545
+ if (txParams.gasLimit) {
46546
+ this.validateGas({
46547
+ gasUsed: txCost.gasUsed,
46548
+ gasLimit: request.gasLimit
46549
+ });
46550
+ }
46551
+ request.gasLimit = txCost.gasUsed;
46552
+ request.maxFee = txCost.maxFee;
46553
+ await this.fund(request, txCost);
46063
46554
  return this.sendTransaction(request);
46064
46555
  }
46065
46556
  /**
@@ -46071,7 +46562,6 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
46071
46562
  * @returns A promise that resolves to the transaction response.
46072
46563
  */
46073
46564
  async withdrawToBaseLayer(recipient, amount, txParams = {}) {
46074
- const { minGasPrice } = this.provider.getGasConfig();
46075
46565
  const recipientAddress = Address.fromAddressOrString(recipient);
46076
46566
  const recipientDataArray = arrayify(
46077
46567
  "0x".concat(recipientAddress.toHexString().substring(2).padStart(64, "0"))
@@ -46084,21 +46574,19 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
46084
46574
  ...recipientDataArray,
46085
46575
  ...amountDataArray
46086
46576
  ]);
46087
- const params = { script, gasPrice: minGasPrice, ...txParams };
46577
+ const params = { script, ...txParams };
46088
46578
  const request = new ScriptTransactionRequest(params);
46089
- const forwardingQuantities = [{ amount: bn(amount), assetId: BaseAssetId }];
46090
- const { requiredQuantities, maxFee, gasUsed } = await this.provider.getTransactionCost(
46091
- request,
46092
- forwardingQuantities
46093
- );
46094
- request.gasLimit = bn(params.gasLimit ?? gasUsed);
46095
- this.validateGas({
46096
- gasUsed,
46097
- gasPrice: request.gasPrice,
46098
- gasLimit: request.gasLimit,
46099
- minGasPrice
46100
- });
46101
- await this.fund(request, requiredQuantities, maxFee);
46579
+ const quantitiesToContract = [{ amount: bn(amount), assetId: BaseAssetId }];
46580
+ const txCost = await this.provider.getTransactionCost(request, { quantitiesToContract });
46581
+ if (txParams.gasLimit) {
46582
+ this.validateGas({
46583
+ gasUsed: txCost.gasUsed,
46584
+ gasLimit: request.gasLimit
46585
+ });
46586
+ }
46587
+ request.maxFee = txCost.maxFee;
46588
+ request.gasLimit = txCost.gasUsed;
46589
+ await this.fund(request, txCost);
46102
46590
  return this.sendTransaction(request);
46103
46591
  }
46104
46592
  async signMessage(message) {
@@ -46156,18 +46644,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
46156
46644
  }
46157
46645
  return this.provider.simulate(transactionRequest, { estimateTxDependencies: false });
46158
46646
  }
46159
- validateGas({
46160
- gasUsed,
46161
- gasPrice,
46162
- gasLimit,
46163
- minGasPrice
46164
- }) {
46165
- if (minGasPrice.gt(gasPrice)) {
46166
- throw new FuelError(
46167
- ErrorCode.GAS_PRICE_TOO_LOW,
46168
- `Gas price '${gasPrice}' is lower than the required: '${minGasPrice}'.`
46169
- );
46170
- }
46647
+ validateGas({ gasUsed, gasLimit }) {
46171
46648
  if (gasUsed.gt(gasLimit)) {
46172
46649
  throw new FuelError(
46173
46650
  ErrorCode.GAS_LIMIT_TOO_LOW,
@@ -47550,12 +48027,12 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
47550
48027
  };
47551
48028
 
47552
48029
  // ../../node_modules/.pnpm/uuid@9.0.0/node_modules/uuid/dist/esm-node/rng.js
47553
- var import_crypto16 = __toESM(__require("crypto"));
48030
+ var import_crypto17 = __toESM(__require("crypto"));
47554
48031
  var rnds8Pool = new Uint8Array(256);
47555
48032
  var poolPtr = rnds8Pool.length;
47556
48033
  function rng() {
47557
48034
  if (poolPtr > rnds8Pool.length - 16) {
47558
- import_crypto16.default.randomFillSync(rnds8Pool);
48035
+ import_crypto17.default.randomFillSync(rnds8Pool);
47559
48036
  poolPtr = 0;
47560
48037
  }
47561
48038
  return rnds8Pool.slice(poolPtr, poolPtr += 16);
@@ -47571,9 +48048,9 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
47571
48048
  }
47572
48049
 
47573
48050
  // ../../node_modules/.pnpm/uuid@9.0.0/node_modules/uuid/dist/esm-node/native.js
47574
- var import_crypto17 = __toESM(__require("crypto"));
48051
+ var import_crypto18 = __toESM(__require("crypto"));
47575
48052
  var native_default = {
47576
- randomUUID: import_crypto17.default.randomUUID
48053
+ randomUUID: import_crypto18.default.randomUUID
47577
48054
  };
47578
48055
 
47579
48056
  // ../../node_modules/.pnpm/uuid@9.0.0/node_modules/uuid/dist/esm-node/v4.js
@@ -47756,7 +48233,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
47756
48233
  * @param transactionRequestLike - The transaction request to send.
47757
48234
  * @returns A promise that resolves to the TransactionResponse object.
47758
48235
  */
47759
- async sendTransaction(transactionRequestLike, { estimateTxDependencies = true, awaitExecution } = {}) {
48236
+ async sendTransaction(transactionRequestLike, { estimateTxDependencies = false, awaitExecution } = {}) {
47760
48237
  const transactionRequest = transactionRequestify(transactionRequestLike);
47761
48238
  if (estimateTxDependencies) {
47762
48239
  await this.provider.estimateTxDependencies(transactionRequest);
@@ -50511,26 +50988,20 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
50511
50988
  __publicField(Wallet, "fromEncryptedJson", WalletUnlocked.fromEncryptedJson);
50512
50989
 
50513
50990
  // src/test-utils/seedTestWallet.ts
50514
- var seedTestWallet = async (wallet, quantities, utxosAmount = 1) => {
50515
- const toFundAccounts = Array.isArray(wallet) ? wallet : [wallet];
50991
+ var seedTestWallet = async (wallet, quantities) => {
50516
50992
  const genesisWallet = new WalletUnlocked(
50517
50993
  process.env.GENESIS_SECRET || randomBytes22(32),
50518
- toFundAccounts[0].provider
50994
+ wallet.provider
50519
50995
  );
50520
- const resources = await genesisWallet.getResourcesToSpend(quantities);
50521
- const { minGasPrice } = genesisWallet.provider.getGasConfig();
50522
- const request = new ScriptTransactionRequest({
50523
- gasLimit: 1e4,
50524
- gasPrice: minGasPrice
50996
+ const request = new ScriptTransactionRequest();
50997
+ quantities.forEach((quantity) => {
50998
+ const { amount, assetId } = coinQuantityfy(quantity);
50999
+ request.addCoinOutput(wallet.address, amount, assetId);
50525
51000
  });
50526
- request.addResources(resources);
50527
- quantities.map(coinQuantityfy).forEach(
50528
- ({ amount, assetId }) => toFundAccounts.forEach(({ address }) => {
50529
- for (let i = 0; i < utxosAmount; i++) {
50530
- request.addCoinOutput(address, amount.div(utxosAmount), assetId);
50531
- }
50532
- })
50533
- );
51001
+ const txCost = await genesisWallet.provider.getTransactionCost(request);
51002
+ request.gasLimit = txCost.gasUsed;
51003
+ request.maxFee = txCost.maxFee;
51004
+ await genesisWallet.fund(request, txCost);
50534
51005
  await genesisWallet.sendTransaction(request, { awaitExecution: true });
50535
51006
  };
50536
51007
 
@@ -50560,7 +51031,7 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
50560
51031
 
50561
51032
  // src/test-utils/launchNode.ts
50562
51033
  var import_child_process = __require("child_process");
50563
- var import_crypto21 = __require("crypto");
51034
+ var import_crypto22 = __require("crypto");
50564
51035
  var import_fs2 = __require("fs");
50565
51036
  var import_os = __toESM(__require("os"));
50566
51037
  var import_path8 = __toESM(__require("path"));
@@ -50609,12 +51080,12 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
50609
51080
  // eslint-disable-next-line no-async-promise-executor
50610
51081
  new Promise(async (resolve, reject) => {
50611
51082
  const remainingArgs = extractRemainingArgs(args, [
50612
- "--chain",
51083
+ "--snapshot",
50613
51084
  "--consensus-key",
50614
51085
  "--db-type",
50615
51086
  "--poa-instant"
50616
51087
  ]);
50617
- const chainConfigPath = getFlagValueFromArgs(args, "--chain");
51088
+ const chainConfigPath = getFlagValueFromArgs(args, "--snapshot");
50618
51089
  const consensusKey = getFlagValueFromArgs(args, "--consensus-key") || defaultConsensusKey;
50619
51090
  const dbTypeFlagValue = getFlagValueFromArgs(args, "--db-type");
50620
51091
  const useInMemoryDb = dbTypeFlagValue === "in-memory" || dbTypeFlagValue === void 0;
@@ -50632,37 +51103,55 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
50632
51103
  })).toString();
50633
51104
  let chainConfigPathToUse;
50634
51105
  const prefix = basePath || import_os.default.tmpdir();
50635
- const suffix = basePath ? "" : (0, import_crypto21.randomUUID)();
50636
- const tempDirPath = import_path8.default.join(prefix, ".fuels", suffix);
51106
+ const suffix = basePath ? "" : (0, import_crypto22.randomUUID)();
51107
+ const tempDirPath = import_path8.default.join(prefix, ".fuels", suffix, "chainConfigs");
50637
51108
  if (chainConfigPath) {
50638
51109
  chainConfigPathToUse = chainConfigPath;
50639
51110
  } else {
50640
51111
  if (!(0, import_fs2.existsSync)(tempDirPath)) {
50641
51112
  (0, import_fs2.mkdirSync)(tempDirPath, { recursive: true });
50642
51113
  }
50643
- const tempChainConfigFilePath = import_path8.default.join(tempDirPath, "chainConfig.json");
50644
- let chainConfig = defaultChainConfig;
51114
+ let { stateConfigJson } = defaultChainConfigs;
51115
+ const { chainConfigJson, metadataJson } = defaultChainConfigs;
51116
+ stateConfigJson = {
51117
+ ...stateConfigJson,
51118
+ coins: [
51119
+ ...stateConfigJson.coins.map((coin) => ({
51120
+ ...coin,
51121
+ amount: "18446744073709551615"
51122
+ }))
51123
+ ],
51124
+ messages: stateConfigJson.messages.map((message) => ({
51125
+ ...message,
51126
+ amount: "18446744073709551615"
51127
+ }))
51128
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
51129
+ };
50645
51130
  if (!process.env.GENESIS_SECRET) {
50646
51131
  const pk = Signer.generatePrivateKey();
50647
51132
  const signer = new Signer(pk);
50648
51133
  process.env.GENESIS_SECRET = hexlify(pk);
50649
- chainConfig = {
50650
- ...defaultChainConfig,
50651
- initial_state: {
50652
- ...defaultChainConfig.initial_state,
50653
- coins: [
50654
- ...defaultChainConfig.initial_state.coins,
50655
- {
50656
- owner: signer.address.toHexString(),
50657
- amount: toHex(1e9),
50658
- asset_id: BaseAssetId
50659
- }
50660
- ]
50661
- }
50662
- };
51134
+ stateConfigJson.coins.push({
51135
+ tx_id: hexlify(randomBytes3(34)),
51136
+ owner: signer.address.toHexString(),
51137
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
51138
+ amount: "18446744073709551615",
51139
+ asset_id: BaseAssetId,
51140
+ output_index: 0,
51141
+ tx_pointer_block_height: 0,
51142
+ tx_pointer_tx_idx: 0
51143
+ });
50663
51144
  }
50664
- (0, import_fs2.writeFileSync)(tempChainConfigFilePath, JSON.stringify(chainConfig), "utf8");
50665
- chainConfigPathToUse = tempChainConfigFilePath;
51145
+ let fixedStateConfigJSON = JSON.stringify(stateConfigJson);
51146
+ const regexMakeNumber = /("amount":)"(\d+)"/gm;
51147
+ fixedStateConfigJSON = fixedStateConfigJSON.replace(regexMakeNumber, "$1$2");
51148
+ const chainConfigWritePath = import_path8.default.join(tempDirPath, "chainConfig.json");
51149
+ const stateConfigWritePath = import_path8.default.join(tempDirPath, "stateConfig.json");
51150
+ const metadataWritePath = import_path8.default.join(tempDirPath, "metadata.json");
51151
+ (0, import_fs2.writeFileSync)(chainConfigWritePath, JSON.stringify(chainConfigJson), "utf8");
51152
+ (0, import_fs2.writeFileSync)(stateConfigWritePath, fixedStateConfigJSON, "utf8");
51153
+ (0, import_fs2.writeFileSync)(metadataWritePath, JSON.stringify(metadataJson), "utf8");
51154
+ chainConfigPathToUse = tempDirPath;
50666
51155
  }
50667
51156
  const child = (0, import_child_process.spawn)(
50668
51157
  command,
@@ -50671,10 +51160,10 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
50671
51160
  ["--ip", ipToUse],
50672
51161
  ["--port", portToUse],
50673
51162
  useInMemoryDb ? ["--db-type", "in-memory"] : ["--db-path", tempDirPath],
50674
- ["--min-gas-price", "0"],
51163
+ ["--min-gas-price", "1"],
50675
51164
  poaInstant ? ["--poa-instant", "true"] : [],
50676
51165
  ["--consensus-key", consensusKey],
50677
- ["--chain", chainConfigPathToUse],
51166
+ ["--snapshot", chainConfigPathToUse],
50678
51167
  "--vm-backtrace",
50679
51168
  "--utxo-validation",
50680
51169
  "--debug",
@@ -50733,40 +51222,13 @@ ${PANIC_DOC_URL}#variant.${status.reason}`;
50733
51222
  walletCount = 10
50734
51223
  } = {}) => {
50735
51224
  const { cleanup: closeNode, ip, port } = await launchNode(launchNodeOptions || {});
50736
- const provider = await Provider.create(`http://${ip}:${port}/graphql`);
51225
+ const provider = await Provider.create(`http://${ip}:${port}/v1/graphql`);
50737
51226
  const wallets = await generateWallets(walletCount, provider);
50738
51227
  const cleanup = () => {
50739
51228
  closeNode();
50740
51229
  };
50741
51230
  return { wallets, stop: cleanup, provider };
50742
51231
  };
50743
-
50744
- // src/test-utils/transactionRequest.ts
50745
- var generateFakeRequestInputCoin = (partial = {}) => ({
50746
- id: hexlify(randomBytes22(UTXO_ID_LEN)),
50747
- type: InputType.Coin,
50748
- owner: getRandomB256(),
50749
- amount: bn(100),
50750
- assetId: ZeroBytes32,
50751
- txPointer: "0x00000000000000000000000000000000",
50752
- witnessIndex: 0,
50753
- ...partial
50754
- });
50755
- var generateFakeRequestInputMessage = (partial = {}) => ({
50756
- nonce: getRandomB256(),
50757
- type: InputType.Message,
50758
- sender: getRandomB256(),
50759
- recipient: getRandomB256(),
50760
- amount: bn(100),
50761
- witnessIndex: 0,
50762
- ...partial
50763
- });
50764
- var generateFakeRequestInputContract = (partial = {}) => ({
50765
- contractId: getRandomB256(),
50766
- type: InputType.Contract,
50767
- txPointer: "0x00000000000000000000000000000000",
50768
- ...partial
50769
- });
50770
51232
  })();
50771
51233
  /*! Bundled license information:
50772
51234