@metamask-previews/gas-fee-controller 15.0.0-preview-f04be62f → 15.0.0-preview-fb52b9eb

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (85) hide show
  1. package/dist/GasFeeController.js +3 -9
  2. package/dist/GasFeeController.mjs +2 -8
  3. package/dist/{chunk-HCUEQ4NY.js → chunk-2AQW4RMC.js} +103 -83
  4. package/dist/chunk-2AQW4RMC.js.map +1 -0
  5. package/dist/{chunk-G2HAZY5F.mjs → chunk-GJSUFSHM.mjs} +95 -75
  6. package/dist/chunk-GJSUFSHM.mjs.map +1 -0
  7. package/dist/{chunk-QVES4OOM.mjs → chunk-KORLXV32.mjs} +28 -1
  8. package/dist/{chunk-QVES4OOM.mjs.map → chunk-KORLXV32.mjs.map} +1 -1
  9. package/dist/{chunk-NARPHUTR.js → chunk-Q2YPK5SL.js} +30 -3
  10. package/dist/chunk-Q2YPK5SL.js.map +1 -0
  11. package/dist/determineGasFeeCalculations.js +3 -9
  12. package/dist/determineGasFeeCalculations.mjs +2 -8
  13. package/dist/gas-util.js +2 -3
  14. package/dist/gas-util.mjs +1 -2
  15. package/dist/index.js +3 -9
  16. package/dist/index.mjs +2 -8
  17. package/dist/tsconfig.build.tsbuildinfo +1 -1
  18. package/dist/types/GasFeeController.d.ts +5 -1
  19. package/dist/types/GasFeeController.d.ts.map +1 -1
  20. package/dist/types/determineGasFeeCalculations.d.ts +17 -16
  21. package/dist/types/determineGasFeeCalculations.d.ts.map +1 -1
  22. package/package.json +2 -2
  23. package/dist/chunk-5INBFZXY.js +0 -127
  24. package/dist/chunk-5INBFZXY.js.map +0 -1
  25. package/dist/chunk-AQN4AQEF.mjs +0 -127
  26. package/dist/chunk-AQN4AQEF.mjs.map +0 -1
  27. package/dist/chunk-C4I7KKIU.mjs +0 -12
  28. package/dist/chunk-C4I7KKIU.mjs.map +0 -1
  29. package/dist/chunk-EXCWMMNV.mjs +0 -39
  30. package/dist/chunk-EXCWMMNV.mjs.map +0 -1
  31. package/dist/chunk-EZVGDV5H.js +0 -39
  32. package/dist/chunk-EZVGDV5H.js.map +0 -1
  33. package/dist/chunk-G2HAZY5F.mjs.map +0 -1
  34. package/dist/chunk-GE7RMDFV.js +0 -77
  35. package/dist/chunk-GE7RMDFV.js.map +0 -1
  36. package/dist/chunk-GUWY6WP6.mjs +0 -77
  37. package/dist/chunk-GUWY6WP6.mjs.map +0 -1
  38. package/dist/chunk-HCUEQ4NY.js.map +0 -1
  39. package/dist/chunk-LO7OP5FM.js +0 -19
  40. package/dist/chunk-LO7OP5FM.js.map +0 -1
  41. package/dist/chunk-NARPHUTR.js.map +0 -1
  42. package/dist/chunk-S2EH2EPS.js +0 -12
  43. package/dist/chunk-S2EH2EPS.js.map +0 -1
  44. package/dist/chunk-SINQOHIN.mjs +0 -19
  45. package/dist/chunk-SINQOHIN.mjs.map +0 -1
  46. package/dist/chunk-XUI43LEZ.mjs +0 -30
  47. package/dist/chunk-XUI43LEZ.mjs.map +0 -1
  48. package/dist/chunk-Z4BLTVTB.js +0 -30
  49. package/dist/chunk-Z4BLTVTB.js.map +0 -1
  50. package/dist/fetchBlockFeeHistory.js +0 -8
  51. package/dist/fetchBlockFeeHistory.js.map +0 -1
  52. package/dist/fetchBlockFeeHistory.mjs +0 -8
  53. package/dist/fetchBlockFeeHistory.mjs.map +0 -1
  54. package/dist/fetchGasEstimatesViaEthFeeHistory/calculateGasFeeEstimatesForPriorityLevels.js +0 -9
  55. package/dist/fetchGasEstimatesViaEthFeeHistory/calculateGasFeeEstimatesForPriorityLevels.js.map +0 -1
  56. package/dist/fetchGasEstimatesViaEthFeeHistory/calculateGasFeeEstimatesForPriorityLevels.mjs +0 -9
  57. package/dist/fetchGasEstimatesViaEthFeeHistory/calculateGasFeeEstimatesForPriorityLevels.mjs.map +0 -1
  58. package/dist/fetchGasEstimatesViaEthFeeHistory/fetchLatestBlock.js +0 -8
  59. package/dist/fetchGasEstimatesViaEthFeeHistory/fetchLatestBlock.js.map +0 -1
  60. package/dist/fetchGasEstimatesViaEthFeeHistory/fetchLatestBlock.mjs +0 -8
  61. package/dist/fetchGasEstimatesViaEthFeeHistory/fetchLatestBlock.mjs.map +0 -1
  62. package/dist/fetchGasEstimatesViaEthFeeHistory/medianOf.js +0 -8
  63. package/dist/fetchGasEstimatesViaEthFeeHistory/medianOf.js.map +0 -1
  64. package/dist/fetchGasEstimatesViaEthFeeHistory/medianOf.mjs +0 -8
  65. package/dist/fetchGasEstimatesViaEthFeeHistory/medianOf.mjs.map +0 -1
  66. package/dist/fetchGasEstimatesViaEthFeeHistory/types.js +0 -1
  67. package/dist/fetchGasEstimatesViaEthFeeHistory/types.js.map +0 -1
  68. package/dist/fetchGasEstimatesViaEthFeeHistory/types.mjs +0 -1
  69. package/dist/fetchGasEstimatesViaEthFeeHistory/types.mjs.map +0 -1
  70. package/dist/fetchGasEstimatesViaEthFeeHistory.js +0 -12
  71. package/dist/fetchGasEstimatesViaEthFeeHistory.js.map +0 -1
  72. package/dist/fetchGasEstimatesViaEthFeeHistory.mjs +0 -12
  73. package/dist/fetchGasEstimatesViaEthFeeHistory.mjs.map +0 -1
  74. package/dist/types/fetchBlockFeeHistory.d.ts +0 -115
  75. package/dist/types/fetchBlockFeeHistory.d.ts.map +0 -1
  76. package/dist/types/fetchGasEstimatesViaEthFeeHistory/calculateGasFeeEstimatesForPriorityLevels.d.ts +0 -17
  77. package/dist/types/fetchGasEstimatesViaEthFeeHistory/calculateGasFeeEstimatesForPriorityLevels.d.ts.map +0 -1
  78. package/dist/types/fetchGasEstimatesViaEthFeeHistory/fetchLatestBlock.d.ts +0 -12
  79. package/dist/types/fetchGasEstimatesViaEthFeeHistory/fetchLatestBlock.d.ts.map +0 -1
  80. package/dist/types/fetchGasEstimatesViaEthFeeHistory/medianOf.d.ts +0 -10
  81. package/dist/types/fetchGasEstimatesViaEthFeeHistory/medianOf.d.ts.map +0 -1
  82. package/dist/types/fetchGasEstimatesViaEthFeeHistory/types.d.ts +0 -7
  83. package/dist/types/fetchGasEstimatesViaEthFeeHistory/types.d.ts.map +0 -1
  84. package/dist/types/fetchGasEstimatesViaEthFeeHistory.d.ts +0 -22
  85. package/dist/types/fetchGasEstimatesViaEthFeeHistory.d.ts.map +0 -1
@@ -3,18 +3,12 @@
3
3
 
4
4
 
5
5
 
6
- var _chunkHCUEQ4NYjs = require('./chunk-HCUEQ4NY.js');
7
- require('./chunk-EZVGDV5H.js');
8
- require('./chunk-5INBFZXY.js');
9
- require('./chunk-NARPHUTR.js');
10
- require('./chunk-GE7RMDFV.js');
11
- require('./chunk-S2EH2EPS.js');
12
- require('./chunk-LO7OP5FM.js');
13
- require('./chunk-Z4BLTVTB.js');
6
+ var _chunk2AQW4RMCjs = require('./chunk-2AQW4RMC.js');
7
+ require('./chunk-Q2YPK5SL.js');
14
8
 
15
9
 
16
10
 
17
11
 
18
12
 
19
- exports.GAS_API_BASE_URL = _chunkHCUEQ4NYjs.GAS_API_BASE_URL; exports.GAS_ESTIMATE_TYPES = _chunkHCUEQ4NYjs.GAS_ESTIMATE_TYPES; exports.GasFeeController = _chunkHCUEQ4NYjs.GasFeeController; exports.default = _chunkHCUEQ4NYjs.GasFeeController_default;
13
+ exports.GAS_API_BASE_URL = _chunk2AQW4RMCjs.GAS_API_BASE_URL; exports.GAS_ESTIMATE_TYPES = _chunk2AQW4RMCjs.GAS_ESTIMATE_TYPES; exports.GasFeeController = _chunk2AQW4RMCjs.GasFeeController; exports.default = _chunk2AQW4RMCjs.GasFeeController_default;
20
14
  //# sourceMappingURL=GasFeeController.js.map
@@ -3,14 +3,8 @@ import {
3
3
  GAS_ESTIMATE_TYPES,
4
4
  GasFeeController,
5
5
  GasFeeController_default
6
- } from "./chunk-G2HAZY5F.mjs";
7
- import "./chunk-EXCWMMNV.mjs";
8
- import "./chunk-AQN4AQEF.mjs";
9
- import "./chunk-QVES4OOM.mjs";
10
- import "./chunk-GUWY6WP6.mjs";
11
- import "./chunk-C4I7KKIU.mjs";
12
- import "./chunk-SINQOHIN.mjs";
13
- import "./chunk-XUI43LEZ.mjs";
6
+ } from "./chunk-GJSUFSHM.mjs";
7
+ import "./chunk-KORLXV32.mjs";
14
8
  export {
15
9
  GAS_API_BASE_URL,
16
10
  GAS_ESTIMATE_TYPES,
@@ -1,18 +1,13 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
2
2
 
3
- var _chunkEZVGDV5Hjs = require('./chunk-EZVGDV5H.js');
4
3
 
5
4
 
6
5
 
7
6
 
8
7
 
9
- var _chunkNARPHUTRjs = require('./chunk-NARPHUTR.js');
10
8
 
11
9
 
12
-
13
-
14
-
15
- var _chunkZ4BLTVTBjs = require('./chunk-Z4BLTVTB.js');
10
+ var _chunkQ2YPK5SLjs = require('./chunk-Q2YPK5SL.js');
16
11
 
17
12
  // src/GasFeeController.ts
18
13
 
@@ -44,7 +39,8 @@ var defaultState = {
44
39
  gasFeeEstimatesByChainId: {},
45
40
  gasFeeEstimates: {},
46
41
  estimatedGasFeeTimeBounds: {},
47
- gasEstimateType: GAS_ESTIMATE_TYPES.NONE
42
+ gasEstimateType: GAS_ESTIMATE_TYPES.NONE,
43
+ nonRPCGasFeeApisDisabled: false
48
44
  };
49
45
  var _getProvider, _onNetworkControllerDidChange, onNetworkControllerDidChange_fn;
50
46
  var GasFeeController = class extends _pollingcontroller.StaticIntervalPollingController {
@@ -88,24 +84,24 @@ var GasFeeController = class extends _pollingcontroller.StaticIntervalPollingCon
88
84
  messenger,
89
85
  state: { ...defaultState, ...state }
90
86
  });
91
- _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _onNetworkControllerDidChange);
92
- _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _getProvider, void 0);
87
+ _chunkQ2YPK5SLjs.__privateAdd.call(void 0, this, _onNetworkControllerDidChange);
88
+ _chunkQ2YPK5SLjs.__privateAdd.call(void 0, this, _getProvider, void 0);
93
89
  this.intervalDelay = interval;
94
90
  this.setIntervalLength(interval);
95
91
  this.pollTokens = /* @__PURE__ */ new Set();
96
92
  this.getCurrentNetworkEIP1559Compatibility = getCurrentNetworkEIP1559Compatibility;
97
93
  this.getCurrentNetworkLegacyGasAPICompatibility = getCurrentNetworkLegacyGasAPICompatibility;
98
94
  this.getCurrentAccountEIP1559Compatibility = getCurrentAccountEIP1559Compatibility;
99
- _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _getProvider, getProvider);
95
+ _chunkQ2YPK5SLjs.__privateSet.call(void 0, this, _getProvider, getProvider);
100
96
  this.EIP1559APIEndpoint = `${GAS_API_BASE_URL}/networks/<chain_id>/suggestedGasFees`;
101
97
  this.legacyAPIEndpoint = `${GAS_API_BASE_URL}/networks/<chain_id>/gasPrices`;
102
98
  this.clientId = clientId;
103
99
  this.infuraAPIKey = infuraAPIKey;
104
- this.ethQuery = new (0, _ethquery2.default)(_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _getProvider).call(this));
100
+ this.ethQuery = new (0, _ethquery2.default)(_chunkQ2YPK5SLjs.__privateGet.call(void 0, this, _getProvider).call(this));
105
101
  if (onNetworkDidChange && getChainId) {
106
102
  this.currentChainId = getChainId();
107
103
  onNetworkDidChange(async (networkControllerState) => {
108
- await _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _onNetworkControllerDidChange, onNetworkControllerDidChange_fn).call(this, networkControllerState);
104
+ await _chunkQ2YPK5SLjs.__privateMethod.call(void 0, this, _onNetworkControllerDidChange, onNetworkControllerDidChange_fn).call(this, networkControllerState);
109
105
  });
110
106
  } else {
111
107
  this.currentChainId = this.messagingSystem.call(
@@ -114,7 +110,7 @@ var GasFeeController = class extends _pollingcontroller.StaticIntervalPollingCon
114
110
  this.messagingSystem.subscribe(
115
111
  "NetworkController:networkDidChange",
116
112
  async (networkControllerState) => {
117
- await _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _onNetworkControllerDidChange, onNetworkControllerDidChange_fn).call(this, networkControllerState);
113
+ await _chunkQ2YPK5SLjs.__privateMethod.call(void 0, this, _onNetworkControllerDidChange, onNetworkControllerDidChange_fn).call(this, networkControllerState);
118
114
  }
119
115
  );
120
116
  }
@@ -182,22 +178,22 @@ var GasFeeController = class extends _pollingcontroller.StaticIntervalPollingCon
182
178
  const gasFeeCalculations = await determineGasFeeCalculations({
183
179
  isEIP1559Compatible,
184
180
  isLegacyGasAPICompatible,
185
- fetchGasEstimates: _chunkNARPHUTRjs.fetchGasEstimates,
181
+ fetchGasEstimates: _chunkQ2YPK5SLjs.fetchGasEstimates,
186
182
  fetchGasEstimatesUrl: this.EIP1559APIEndpoint.replace(
187
183
  "<chain_id>",
188
184
  `${decimalChainId}`
189
185
  ),
190
- fetchGasEstimatesViaEthFeeHistory: _chunkEZVGDV5Hjs.fetchGasEstimatesViaEthFeeHistory,
191
- fetchLegacyGasPriceEstimates: _chunkNARPHUTRjs.fetchLegacyGasPriceEstimates,
186
+ fetchLegacyGasPriceEstimates: _chunkQ2YPK5SLjs.fetchLegacyGasPriceEstimates,
192
187
  fetchLegacyGasPriceEstimatesUrl: this.legacyAPIEndpoint.replace(
193
188
  "<chain_id>",
194
189
  `${decimalChainId}`
195
190
  ),
196
- fetchEthGasPriceEstimate: _chunkNARPHUTRjs.fetchEthGasPriceEstimate,
197
- calculateTimeEstimate: _chunkNARPHUTRjs.calculateTimeEstimate,
191
+ fetchEthGasPriceEstimate: _chunkQ2YPK5SLjs.fetchEthGasPriceEstimate,
192
+ calculateTimeEstimate: _chunkQ2YPK5SLjs.calculateTimeEstimate,
198
193
  clientId: this.clientId,
199
194
  ethQuery,
200
- infuraAPIKey: this.infuraAPIKey
195
+ infuraAPIKey: this.infuraAPIKey,
196
+ nonRPCGasFeeApisDisabled: this.state.nonRPCGasFeeApisDisabled
201
197
  });
202
198
  if (shouldUpdateState) {
203
199
  this.update((state) => {
@@ -273,19 +269,29 @@ var GasFeeController = class extends _pollingcontroller.StaticIntervalPollingCon
273
269
  if (!this.state.gasFeeEstimates || this.state.gasEstimateType !== GAS_ESTIMATE_TYPES.FEE_MARKET) {
274
270
  return {};
275
271
  }
276
- return _chunkNARPHUTRjs.calculateTimeEstimate.call(void 0,
272
+ return _chunkQ2YPK5SLjs.calculateTimeEstimate.call(void 0,
277
273
  maxPriorityFeePerGas,
278
274
  maxFeePerGas,
279
275
  this.state.gasFeeEstimates
280
276
  );
281
277
  }
278
+ enableNonRPCGasFeeApis() {
279
+ this.update((state) => {
280
+ state.nonRPCGasFeeApisDisabled = false;
281
+ });
282
+ }
283
+ disableNonRPCGasFeeApis() {
284
+ this.update((state) => {
285
+ state.nonRPCGasFeeApisDisabled = true;
286
+ });
287
+ }
282
288
  };
283
289
  _getProvider = new WeakMap();
284
290
  _onNetworkControllerDidChange = new WeakSet();
285
291
  onNetworkControllerDidChange_fn = async function(networkControllerState) {
286
292
  const newChainId = networkControllerState.providerConfig.chainId;
287
293
  if (newChainId !== this.currentChainId) {
288
- this.ethQuery = new (0, _ethquery2.default)(_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _getProvider).call(this));
294
+ this.ethQuery = new (0, _ethquery2.default)(_chunkQ2YPK5SLjs.__privateGet.call(void 0, this, _getProvider).call(this));
289
295
  await this.resetPolling();
290
296
  this.currentChainId = newChainId;
291
297
  }
@@ -293,74 +299,88 @@ onNetworkControllerDidChange_fn = async function(networkControllerState) {
293
299
  var GasFeeController_default = GasFeeController;
294
300
 
295
301
  // src/determineGasFeeCalculations.ts
296
- async function determineGasFeeCalculations({
297
- isEIP1559Compatible,
298
- isLegacyGasAPICompatible,
299
- fetchGasEstimates: fetchGasEstimates2,
300
- fetchGasEstimatesUrl,
301
- fetchGasEstimatesViaEthFeeHistory: fetchGasEstimatesViaEthFeeHistory2,
302
- fetchLegacyGasPriceEstimates: fetchLegacyGasPriceEstimates2,
303
- fetchLegacyGasPriceEstimatesUrl,
304
- fetchEthGasPriceEstimate: fetchEthGasPriceEstimate2,
305
- calculateTimeEstimate: calculateTimeEstimate2,
306
- clientId,
307
- ethQuery,
308
- infuraAPIKey
309
- }) {
302
+ async function determineGasFeeCalculations(args) {
310
303
  try {
311
- if (isEIP1559Compatible) {
312
- let estimates;
313
- try {
314
- estimates = await fetchGasEstimates2(
315
- fetchGasEstimatesUrl,
316
- infuraAPIKey,
317
- clientId
318
- );
319
- } catch {
320
- estimates = await fetchGasEstimatesViaEthFeeHistory2(ethQuery);
321
- }
322
- const { suggestedMaxPriorityFeePerGas, suggestedMaxFeePerGas } = estimates.medium;
323
- const estimatedGasFeeTimeBounds = calculateTimeEstimate2(
324
- suggestedMaxPriorityFeePerGas,
325
- suggestedMaxFeePerGas,
326
- estimates
327
- );
328
- return {
329
- gasFeeEstimates: estimates,
330
- estimatedGasFeeTimeBounds,
331
- gasEstimateType: GAS_ESTIMATE_TYPES.FEE_MARKET
332
- };
333
- } else if (isLegacyGasAPICompatible) {
334
- const estimates = await fetchLegacyGasPriceEstimates2(
335
- fetchLegacyGasPriceEstimatesUrl,
336
- infuraAPIKey,
337
- clientId
304
+ return await getEstimatesUsingFallbacks(args);
305
+ } catch (error) {
306
+ if (error instanceof Error) {
307
+ throw new Error(
308
+ `Gas fee/price estimation failed. Message: ${error.message}`
338
309
  );
339
- return {
340
- gasFeeEstimates: estimates,
341
- estimatedGasFeeTimeBounds: {},
342
- gasEstimateType: GAS_ESTIMATE_TYPES.LEGACY
343
- };
310
+ }
311
+ throw error;
312
+ }
313
+ }
314
+ async function getEstimatesUsingFallbacks(request) {
315
+ const {
316
+ isEIP1559Compatible,
317
+ isLegacyGasAPICompatible,
318
+ nonRPCGasFeeApisDisabled
319
+ } = request;
320
+ try {
321
+ if (isEIP1559Compatible && !nonRPCGasFeeApisDisabled) {
322
+ return await getEstimatesUsingFeeMarketEndpoint(request);
323
+ }
324
+ if (isLegacyGasAPICompatible && !nonRPCGasFeeApisDisabled) {
325
+ return await getEstimatesUsingLegacyEndpoint(request);
344
326
  }
345
327
  throw new Error("Main gas fee/price estimation failed. Use fallback");
346
328
  } catch {
347
- try {
348
- const estimates = await fetchEthGasPriceEstimate2(ethQuery);
349
- return {
350
- gasFeeEstimates: estimates,
351
- estimatedGasFeeTimeBounds: {},
352
- gasEstimateType: GAS_ESTIMATE_TYPES.ETH_GASPRICE
353
- };
354
- } catch (error) {
355
- if (error instanceof Error) {
356
- throw new Error(
357
- `Gas fee/price estimation failed. Message: ${error.message}`
358
- );
359
- }
360
- throw error;
361
- }
329
+ return await getEstimatesUsingProvider(request);
362
330
  }
363
331
  }
332
+ async function getEstimatesUsingFeeMarketEndpoint(request) {
333
+ const {
334
+ fetchGasEstimates: fetchGasEstimates2,
335
+ fetchGasEstimatesUrl,
336
+ infuraAPIKey,
337
+ clientId,
338
+ calculateTimeEstimate: calculateTimeEstimate2
339
+ } = request;
340
+ const estimates = await fetchGasEstimates2(
341
+ fetchGasEstimatesUrl,
342
+ infuraAPIKey,
343
+ clientId
344
+ );
345
+ const { suggestedMaxPriorityFeePerGas, suggestedMaxFeePerGas } = estimates.medium;
346
+ const estimatedGasFeeTimeBounds = calculateTimeEstimate2(
347
+ suggestedMaxPriorityFeePerGas,
348
+ suggestedMaxFeePerGas,
349
+ estimates
350
+ );
351
+ return {
352
+ gasFeeEstimates: estimates,
353
+ estimatedGasFeeTimeBounds,
354
+ gasEstimateType: GAS_ESTIMATE_TYPES.FEE_MARKET
355
+ };
356
+ }
357
+ async function getEstimatesUsingLegacyEndpoint(request) {
358
+ const {
359
+ fetchLegacyGasPriceEstimates: fetchLegacyGasPriceEstimates2,
360
+ fetchLegacyGasPriceEstimatesUrl,
361
+ infuraAPIKey,
362
+ clientId
363
+ } = request;
364
+ const estimates = await fetchLegacyGasPriceEstimates2(
365
+ fetchLegacyGasPriceEstimatesUrl,
366
+ infuraAPIKey,
367
+ clientId
368
+ );
369
+ return {
370
+ gasFeeEstimates: estimates,
371
+ estimatedGasFeeTimeBounds: {},
372
+ gasEstimateType: GAS_ESTIMATE_TYPES.LEGACY
373
+ };
374
+ }
375
+ async function getEstimatesUsingProvider(request) {
376
+ const { ethQuery, fetchEthGasPriceEstimate: fetchEthGasPriceEstimate2 } = request;
377
+ const estimates = await fetchEthGasPriceEstimate2(ethQuery);
378
+ return {
379
+ gasFeeEstimates: estimates,
380
+ estimatedGasFeeTimeBounds: {},
381
+ gasEstimateType: GAS_ESTIMATE_TYPES.ETH_GASPRICE
382
+ };
383
+ }
364
384
 
365
385
 
366
386
 
@@ -369,4 +389,4 @@ async function determineGasFeeCalculations({
369
389
 
370
390
 
371
391
  exports.determineGasFeeCalculations = determineGasFeeCalculations; exports.GAS_API_BASE_URL = GAS_API_BASE_URL; exports.GAS_ESTIMATE_TYPES = GAS_ESTIMATE_TYPES; exports.GasFeeController = GasFeeController; exports.GasFeeController_default = GasFeeController_default;
372
- //# sourceMappingURL=chunk-HCUEQ4NY.js.map
392
+ //# sourceMappingURL=chunk-2AQW4RMC.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/GasFeeController.ts","../src/determineGasFeeCalculations.ts"],"names":["fetchGasEstimates","calculateTimeEstimate","fetchLegacyGasPriceEstimates","fetchEthGasPriceEstimate"],"mappings":"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","sourcesContent":["import type {\n ControllerGetStateAction,\n ControllerStateChangeEvent,\n RestrictedControllerMessenger,\n} from '@metamask/base-controller';\nimport {\n convertHexToDecimal,\n safelyExecute,\n toHex,\n} from '@metamask/controller-utils';\nimport EthQuery from '@metamask/eth-query';\nimport type {\n NetworkClientId,\n NetworkControllerGetEIP1559CompatibilityAction,\n NetworkControllerGetNetworkClientByIdAction,\n NetworkControllerGetStateAction,\n NetworkControllerNetworkDidChangeEvent,\n NetworkState,\n ProviderProxy,\n} from '@metamask/network-controller';\nimport { StaticIntervalPollingController } from '@metamask/polling-controller';\nimport type { Hex } from '@metamask/utils';\nimport { v1 as random } from 'uuid';\n\nimport determineGasFeeCalculations from './determineGasFeeCalculations';\nimport {\n calculateTimeEstimate,\n fetchGasEstimates,\n fetchLegacyGasPriceEstimates,\n fetchEthGasPriceEstimate,\n} from './gas-util';\n\nexport const GAS_API_BASE_URL = 'https://gas.api.infura.io';\n\nexport type unknownString = 'unknown';\n\n// Fee Market describes the way gas is set after the london hardfork, and was\n// defined by EIP-1559.\nexport type FeeMarketEstimateType = 'fee-market';\n// Legacy describes gasPrice estimates from before london hardfork, when the\n// user is connected to mainnet and are presented with fast/average/slow\n// estimate levels to choose from.\nexport type LegacyEstimateType = 'legacy';\n// EthGasPrice describes a gasPrice estimate received from eth_gasPrice. Post\n// london this value should only be used for legacy type transactions when on\n// networks that support EIP-1559. This type of estimate is the most accurate\n// to display on custom networks that don't support EIP-1559.\nexport type EthGasPriceEstimateType = 'eth_gasPrice';\n// NoEstimate describes the state of the controller before receiving its first\n// estimate.\nexport type NoEstimateType = 'none';\n\n/**\n * Indicates which type of gasEstimate the controller is currently returning.\n * This is useful as a way of asserting that the shape of gasEstimates matches\n * expectations. NONE is a special case indicating that no previous gasEstimate\n * has been fetched.\n */\nexport const GAS_ESTIMATE_TYPES = {\n FEE_MARKET: 'fee-market' as FeeMarketEstimateType,\n LEGACY: 'legacy' as LegacyEstimateType,\n ETH_GASPRICE: 'eth_gasPrice' as EthGasPriceEstimateType,\n NONE: 'none' as NoEstimateType,\n};\n\nexport type GasEstimateType =\n | FeeMarketEstimateType\n | EthGasPriceEstimateType\n | LegacyEstimateType\n | NoEstimateType;\n\nexport type EstimatedGasFeeTimeBounds = {\n lowerTimeBound: number | null;\n upperTimeBound: number | unknownString;\n};\n\n/**\n * @type EthGasPriceEstimate\n *\n * A single gas price estimate for networks and accounts that don't support EIP-1559\n * This estimate comes from eth_gasPrice but is converted to dec gwei to match other\n * return values\n * @property gasPrice - A GWEI dec string\n */\n\nexport type EthGasPriceEstimate = {\n gasPrice: string;\n};\n\n/**\n * @type LegacyGasPriceEstimate\n *\n * A set of gas price estimates for networks and accounts that don't support EIP-1559\n * These estimates include low, medium and high all as strings representing gwei in\n * decimal format.\n * @property high - gasPrice, in decimal gwei string format, suggested for fast inclusion\n * @property medium - gasPrice, in decimal gwei string format, suggested for avg inclusion\n * @property low - gasPrice, in decimal gwei string format, suggested for slow inclusion\n */\nexport type LegacyGasPriceEstimate = {\n high: string;\n medium: string;\n low: string;\n};\n\n/**\n * @type Eip1559GasFee\n *\n * Data necessary to provide an estimate of a gas fee with a specific tip\n * @property minWaitTimeEstimate - The fastest the transaction will take, in milliseconds\n * @property maxWaitTimeEstimate - The slowest the transaction will take, in milliseconds\n * @property suggestedMaxPriorityFeePerGas - A suggested \"tip\", a GWEI hex number\n * @property suggestedMaxFeePerGas - A suggested max fee, the most a user will pay. a GWEI hex number\n */\nexport type Eip1559GasFee = {\n minWaitTimeEstimate: number; // a time duration in milliseconds\n maxWaitTimeEstimate: number; // a time duration in milliseconds\n suggestedMaxPriorityFeePerGas: string; // a GWEI decimal number\n suggestedMaxFeePerGas: string; // a GWEI decimal number\n};\n\n/**\n * @type GasFeeEstimates\n *\n * Data necessary to provide multiple GasFee estimates, and supporting information, to the user\n * @property low - A GasFee for a minimum necessary combination of tip and maxFee\n * @property medium - A GasFee for a recommended combination of tip and maxFee\n * @property high - A GasFee for a high combination of tip and maxFee\n * @property estimatedBaseFee - An estimate of what the base fee will be for the pending/next block. A GWEI dec number\n * @property networkCongestion - A normalized number that can be used to gauge the congestion\n * level of the network, with 0 meaning not congested and 1 meaning extremely congested\n */\nexport type GasFeeEstimates = SourcedGasFeeEstimates | FallbackGasFeeEstimates;\n\ntype SourcedGasFeeEstimates = {\n low: Eip1559GasFee;\n medium: Eip1559GasFee;\n high: Eip1559GasFee;\n estimatedBaseFee: string;\n historicalBaseFeeRange: [string, string];\n baseFeeTrend: 'up' | 'down' | 'level';\n latestPriorityFeeRange: [string, string];\n historicalPriorityFeeRange: [string, string];\n priorityFeeTrend: 'up' | 'down' | 'level';\n networkCongestion: number;\n};\n\ntype FallbackGasFeeEstimates = {\n low: Eip1559GasFee;\n medium: Eip1559GasFee;\n high: Eip1559GasFee;\n estimatedBaseFee: string;\n historicalBaseFeeRange: null;\n baseFeeTrend: null;\n latestPriorityFeeRange: null;\n historicalPriorityFeeRange: null;\n priorityFeeTrend: null;\n networkCongestion: null;\n};\n\nconst metadata = {\n gasFeeEstimatesByChainId: {\n persist: true,\n anonymous: false,\n },\n gasFeeEstimates: { persist: true, anonymous: false },\n estimatedGasFeeTimeBounds: { persist: true, anonymous: false },\n gasEstimateType: { persist: true, anonymous: false },\n};\n\nexport type GasFeeStateEthGasPrice = {\n gasFeeEstimates: EthGasPriceEstimate;\n estimatedGasFeeTimeBounds: Record<string, never>;\n gasEstimateType: EthGasPriceEstimateType;\n};\n\nexport type GasFeeStateFeeMarket = {\n gasFeeEstimates: GasFeeEstimates;\n estimatedGasFeeTimeBounds: EstimatedGasFeeTimeBounds | Record<string, never>;\n gasEstimateType: FeeMarketEstimateType;\n};\n\nexport type GasFeeStateLegacy = {\n gasFeeEstimates: LegacyGasPriceEstimate;\n estimatedGasFeeTimeBounds: Record<string, never>;\n gasEstimateType: LegacyEstimateType;\n};\n\nexport type GasFeeStateNoEstimates = {\n gasFeeEstimates: Record<string, never>;\n estimatedGasFeeTimeBounds: Record<string, never>;\n gasEstimateType: NoEstimateType;\n};\n\nexport type FetchGasFeeEstimateOptions = {\n shouldUpdateState?: boolean;\n networkClientId?: NetworkClientId;\n};\n\n/**\n * @type GasFeeState\n *\n * Gas Fee controller state\n * @property gasFeeEstimates - Gas fee estimate data based on new EIP-1559 properties\n * @property estimatedGasFeeTimeBounds - Estimates representing the minimum and maximum\n */\nexport type SingleChainGasFeeState =\n | GasFeeStateEthGasPrice\n | GasFeeStateFeeMarket\n | GasFeeStateLegacy\n | GasFeeStateNoEstimates;\n\nexport type GasFeeEstimatesByChainId = {\n gasFeeEstimatesByChainId?: Record<string, SingleChainGasFeeState>;\n};\n\nexport type GasFeeState = GasFeeEstimatesByChainId &\n SingleChainGasFeeState & {\n nonRPCGasFeeApisDisabled?: boolean;\n };\n\nconst name = 'GasFeeController';\n\nexport type GasFeeStateChange = ControllerStateChangeEvent<\n typeof name,\n GasFeeState\n>;\n\nexport type GetGasFeeState = ControllerGetStateAction<typeof name, GasFeeState>;\n\nexport type GasFeeControllerActions = GetGasFeeState;\n\nexport type GasFeeControllerEvents = GasFeeStateChange;\n\ntype AllowedActions =\n | NetworkControllerGetStateAction\n | NetworkControllerGetNetworkClientByIdAction\n | NetworkControllerGetEIP1559CompatibilityAction;\n\ntype GasFeeMessenger = RestrictedControllerMessenger<\n typeof name,\n GasFeeControllerActions | AllowedActions,\n GasFeeControllerEvents | NetworkControllerNetworkDidChangeEvent,\n AllowedActions['type'],\n NetworkControllerNetworkDidChangeEvent['type']\n>;\n\nconst defaultState: GasFeeState = {\n gasFeeEstimatesByChainId: {},\n gasFeeEstimates: {},\n estimatedGasFeeTimeBounds: {},\n gasEstimateType: GAS_ESTIMATE_TYPES.NONE,\n nonRPCGasFeeApisDisabled: false,\n};\n\n/**\n * Controller that retrieves gas fee estimate data and polls for updated data on a set interval\n */\nexport class GasFeeController extends StaticIntervalPollingController<\n typeof name,\n GasFeeState,\n GasFeeMessenger\n> {\n private intervalId?: ReturnType<typeof setTimeout>;\n\n private readonly intervalDelay;\n\n private readonly pollTokens: Set<string>;\n\n private readonly legacyAPIEndpoint: string;\n\n private readonly EIP1559APIEndpoint: string;\n\n private readonly getCurrentNetworkEIP1559Compatibility;\n\n private readonly getCurrentNetworkLegacyGasAPICompatibility;\n\n private readonly getCurrentAccountEIP1559Compatibility;\n\n private readonly infuraAPIKey: string;\n\n private currentChainId;\n\n private ethQuery?: EthQuery;\n\n private readonly clientId?: string;\n\n #getProvider: () => ProviderProxy;\n\n /**\n * Creates a GasFeeController instance.\n *\n * @param options - The controller options.\n * @param options.interval - The time in milliseconds to wait between polls.\n * @param options.messenger - The controller messenger.\n * @param options.state - The initial state.\n * @param options.getCurrentNetworkEIP1559Compatibility - Determines whether or not the current\n * network is EIP-1559 compatible.\n * @param options.getCurrentNetworkLegacyGasAPICompatibility - Determines whether or not the\n * current network is compatible with the legacy gas price API.\n * @param options.getCurrentAccountEIP1559Compatibility - Determines whether or not the current\n * account is EIP-1559 compatible.\n * @param options.getChainId - Returns the current chain ID.\n * @param options.getProvider - Returns a network provider for the current network.\n * @param options.onNetworkDidChange - A function for registering an event handler for the\n * network state change event.\n * @param options.clientId - The client ID used to identify to the gas estimation API who is\n * asking for estimates.\n * @param options.infuraAPIKey - The Infura API key used for infura API requests.\n */\n constructor({\n interval = 15000,\n messenger,\n state,\n getCurrentNetworkEIP1559Compatibility,\n getCurrentAccountEIP1559Compatibility,\n getChainId,\n getCurrentNetworkLegacyGasAPICompatibility,\n getProvider,\n onNetworkDidChange,\n clientId,\n infuraAPIKey,\n }: {\n interval?: number;\n messenger: GasFeeMessenger;\n state?: GasFeeState;\n getCurrentNetworkEIP1559Compatibility: () => Promise<boolean>;\n getCurrentNetworkLegacyGasAPICompatibility: () => boolean;\n getCurrentAccountEIP1559Compatibility?: () => boolean;\n getChainId?: () => Hex;\n getProvider: () => ProviderProxy;\n onNetworkDidChange?: (listener: (state: NetworkState) => void) => void;\n clientId?: string;\n infuraAPIKey: string;\n }) {\n super({\n name,\n metadata,\n messenger,\n state: { ...defaultState, ...state },\n });\n this.intervalDelay = interval;\n this.setIntervalLength(interval);\n this.pollTokens = new Set();\n this.getCurrentNetworkEIP1559Compatibility =\n getCurrentNetworkEIP1559Compatibility;\n this.getCurrentNetworkLegacyGasAPICompatibility =\n getCurrentNetworkLegacyGasAPICompatibility;\n this.getCurrentAccountEIP1559Compatibility =\n getCurrentAccountEIP1559Compatibility;\n this.#getProvider = getProvider;\n this.EIP1559APIEndpoint = `${GAS_API_BASE_URL}/networks/<chain_id>/suggestedGasFees`;\n this.legacyAPIEndpoint = `${GAS_API_BASE_URL}/networks/<chain_id>/gasPrices`;\n this.clientId = clientId;\n this.infuraAPIKey = infuraAPIKey;\n\n this.ethQuery = new EthQuery(this.#getProvider());\n\n if (onNetworkDidChange && getChainId) {\n this.currentChainId = getChainId();\n onNetworkDidChange(async (networkControllerState) => {\n await this.#onNetworkControllerDidChange(networkControllerState);\n });\n } else {\n this.currentChainId = this.messagingSystem.call(\n 'NetworkController:getState',\n ).providerConfig.chainId;\n this.messagingSystem.subscribe(\n 'NetworkController:networkDidChange',\n async (networkControllerState) => {\n await this.#onNetworkControllerDidChange(networkControllerState);\n },\n );\n }\n }\n\n async resetPolling() {\n if (this.pollTokens.size !== 0) {\n const tokens = Array.from(this.pollTokens);\n this.stopPolling();\n await this.getGasFeeEstimatesAndStartPolling(tokens[0]);\n tokens.slice(1).forEach((token) => {\n this.pollTokens.add(token);\n });\n }\n }\n\n async fetchGasFeeEstimates(options?: FetchGasFeeEstimateOptions) {\n return await this._fetchGasFeeEstimateData(options);\n }\n\n async getGasFeeEstimatesAndStartPolling(\n pollToken: string | undefined,\n ): Promise<string> {\n const _pollToken = pollToken || random();\n\n this.pollTokens.add(_pollToken);\n\n if (this.pollTokens.size === 1) {\n await this._fetchGasFeeEstimateData();\n this._poll();\n }\n\n return _pollToken;\n }\n\n /**\n * Gets and sets gasFeeEstimates in state.\n *\n * @param options - The gas fee estimate options.\n * @param options.shouldUpdateState - Determines whether the state should be updated with the\n * updated gas estimates.\n * @returns The gas fee estimates.\n */\n async _fetchGasFeeEstimateData(\n options: FetchGasFeeEstimateOptions = {},\n ): Promise<GasFeeState> {\n const { shouldUpdateState = true, networkClientId } = options;\n\n let ethQuery,\n isEIP1559Compatible,\n isLegacyGasAPICompatible,\n decimalChainId: number;\n\n if (networkClientId !== undefined) {\n const networkClient = this.messagingSystem.call(\n 'NetworkController:getNetworkClientById',\n networkClientId,\n );\n isLegacyGasAPICompatible = networkClient.configuration.chainId === '0x38';\n\n decimalChainId = convertHexToDecimal(networkClient.configuration.chainId);\n\n try {\n const result = await this.messagingSystem.call(\n 'NetworkController:getEIP1559Compatibility',\n networkClientId,\n );\n isEIP1559Compatible = result || false;\n } catch {\n isEIP1559Compatible = false;\n }\n ethQuery = new EthQuery(networkClient.provider);\n }\n\n ethQuery ??= this.ethQuery;\n\n isLegacyGasAPICompatible ??=\n this.getCurrentNetworkLegacyGasAPICompatibility();\n\n decimalChainId ??= convertHexToDecimal(this.currentChainId);\n\n try {\n isEIP1559Compatible ??= await this.getEIP1559Compatibility();\n } catch (e) {\n console.error(e);\n isEIP1559Compatible ??= false;\n }\n\n const gasFeeCalculations = await determineGasFeeCalculations({\n isEIP1559Compatible,\n isLegacyGasAPICompatible,\n fetchGasEstimates,\n fetchGasEstimatesUrl: this.EIP1559APIEndpoint.replace(\n '<chain_id>',\n `${decimalChainId}`,\n ),\n fetchLegacyGasPriceEstimates,\n fetchLegacyGasPriceEstimatesUrl: this.legacyAPIEndpoint.replace(\n '<chain_id>',\n `${decimalChainId}`,\n ),\n fetchEthGasPriceEstimate,\n calculateTimeEstimate,\n clientId: this.clientId,\n ethQuery,\n infuraAPIKey: this.infuraAPIKey,\n nonRPCGasFeeApisDisabled: this.state.nonRPCGasFeeApisDisabled,\n });\n\n if (shouldUpdateState) {\n this.update((state) => {\n state.gasFeeEstimates = gasFeeCalculations.gasFeeEstimates;\n state.estimatedGasFeeTimeBounds =\n gasFeeCalculations.estimatedGasFeeTimeBounds;\n state.gasEstimateType = gasFeeCalculations.gasEstimateType;\n state.gasFeeEstimatesByChainId ??= {};\n state.gasFeeEstimatesByChainId[toHex(decimalChainId)] = {\n gasFeeEstimates: gasFeeCalculations.gasFeeEstimates,\n estimatedGasFeeTimeBounds:\n gasFeeCalculations.estimatedGasFeeTimeBounds,\n gasEstimateType: gasFeeCalculations.gasEstimateType,\n } as SingleChainGasFeeState;\n });\n }\n\n return gasFeeCalculations;\n }\n\n /**\n * Remove the poll token, and stop polling if the set of poll tokens is empty.\n *\n * @param pollToken - The poll token to disconnect.\n */\n disconnectPoller(pollToken: string) {\n this.pollTokens.delete(pollToken);\n if (this.pollTokens.size === 0) {\n this.stopPolling();\n }\n }\n\n stopPolling() {\n if (this.intervalId) {\n clearInterval(this.intervalId);\n }\n this.pollTokens.clear();\n this.resetState();\n }\n\n /**\n * Prepare to discard this controller.\n *\n * This stops any active polling.\n */\n override destroy() {\n super.destroy();\n this.stopPolling();\n }\n\n private _poll() {\n if (this.intervalId) {\n clearInterval(this.intervalId);\n }\n\n this.intervalId = setInterval(async () => {\n await safelyExecute(() => this._fetchGasFeeEstimateData());\n }, this.intervalDelay);\n }\n\n /**\n * Fetching token list from the Token Service API.\n *\n * @private\n * @param networkClientId - The ID of the network client triggering the fetch.\n * @returns A promise that resolves when this operation completes.\n */\n async _executePoll(networkClientId: string): Promise<void> {\n await this._fetchGasFeeEstimateData({ networkClientId });\n }\n\n private resetState() {\n this.update(() => {\n return defaultState;\n });\n }\n\n private async getEIP1559Compatibility() {\n const currentNetworkIsEIP1559Compatible =\n await this.getCurrentNetworkEIP1559Compatibility();\n const currentAccountIsEIP1559Compatible =\n this.getCurrentAccountEIP1559Compatibility?.() ?? true;\n\n return (\n currentNetworkIsEIP1559Compatible && currentAccountIsEIP1559Compatible\n );\n }\n\n getTimeEstimate(\n maxPriorityFeePerGas: string,\n maxFeePerGas: string,\n ): EstimatedGasFeeTimeBounds | Record<string, never> {\n if (\n !this.state.gasFeeEstimates ||\n this.state.gasEstimateType !== GAS_ESTIMATE_TYPES.FEE_MARKET\n ) {\n return {};\n }\n return calculateTimeEstimate(\n maxPriorityFeePerGas,\n maxFeePerGas,\n this.state.gasFeeEstimates,\n );\n }\n\n async #onNetworkControllerDidChange(networkControllerState: NetworkState) {\n const newChainId = networkControllerState.providerConfig.chainId;\n\n if (newChainId !== this.currentChainId) {\n this.ethQuery = new EthQuery(this.#getProvider());\n await this.resetPolling();\n\n this.currentChainId = newChainId;\n }\n }\n\n enableNonRPCGasFeeApis() {\n this.update((state) => {\n state.nonRPCGasFeeApisDisabled = false;\n });\n }\n\n disableNonRPCGasFeeApis() {\n this.update((state) => {\n state.nonRPCGasFeeApisDisabled = true;\n });\n }\n}\n\nexport default GasFeeController;\n","import type {\n EstimatedGasFeeTimeBounds,\n EthGasPriceEstimate,\n GasFeeEstimates,\n GasFeeState as GasFeeCalculations,\n LegacyGasPriceEstimate,\n} from './GasFeeController';\nimport { GAS_ESTIMATE_TYPES } from './GasFeeController';\n\ntype DetermineGasFeeCalculationsRequest = {\n isEIP1559Compatible: boolean;\n isLegacyGasAPICompatible: boolean;\n fetchGasEstimates: (\n url: string,\n infuraAPIKey: string,\n clientId?: string,\n ) => Promise<GasFeeEstimates>;\n fetchGasEstimatesUrl: string;\n fetchLegacyGasPriceEstimates: (\n url: string,\n infuraAPIKey: string,\n clientId?: string,\n ) => Promise<LegacyGasPriceEstimate>;\n fetchLegacyGasPriceEstimatesUrl: string;\n // TODO: Replace `any` with type\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n fetchEthGasPriceEstimate: (ethQuery: any) => Promise<EthGasPriceEstimate>;\n calculateTimeEstimate: (\n maxPriorityFeePerGas: string,\n maxFeePerGas: string,\n gasFeeEstimates: GasFeeEstimates,\n ) => EstimatedGasFeeTimeBounds;\n clientId: string | undefined;\n // TODO: Replace `any` with type\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ethQuery: any;\n infuraAPIKey: string;\n nonRPCGasFeeApisDisabled?: boolean;\n};\n\n/**\n * Obtains a set of max base and priority fee estimates along with time estimates so that we\n * can present them to users when they are sending transactions or making swaps.\n *\n * @param args - The arguments.\n * @param args.isEIP1559Compatible - Governs whether or not we can use an EIP-1559-only method to\n * produce estimates.\n * @param args.isLegacyGasAPICompatible - Governs whether or not we can use a non-EIP-1559 method to\n * produce estimates (for instance, testnets do not support estimates altogether).\n * @param args.fetchGasEstimates - A function that fetches gas estimates using an EIP-1559-specific\n * API.\n * @param args.fetchGasEstimatesUrl - The URL for the API we can use to obtain EIP-1559-specific\n * estimates.\n * @param args.fetchLegacyGasPriceEstimates - A function that fetches gas estimates using an\n * non-EIP-1559-specific API.\n * @param args.fetchLegacyGasPriceEstimatesUrl - The URL for the API we can use to obtain\n * non-EIP-1559-specific estimates.\n * @param args.fetchEthGasPriceEstimate - A function that fetches gas estimates using\n * `eth_gasPrice`.\n * @param args.calculateTimeEstimate - A function that determine time estimate bounds.\n * @param args.clientId - An identifier that an API can use to know who is asking for estimates.\n * @param args.ethQuery - An EthQuery instance we can use to talk to Ethereum directly.\n * @param args.infuraAPIKey - Infura API key to use for requests to Infura.\n * @param args.nonRPCGasFeeApisDisabled - Whether to disable requests to the legacyAPIEndpoint and the EIP1559APIEndpoint\n * @returns The gas fee calculations.\n */\nexport default async function determineGasFeeCalculations(\n args: DetermineGasFeeCalculationsRequest,\n): Promise<GasFeeCalculations> {\n try {\n return await getEstimatesUsingFallbacks(args);\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\n `Gas fee/price estimation failed. Message: ${error.message}`,\n );\n }\n\n throw error;\n }\n}\n\n/**\n * Retrieve the gas fee estimates using a series of fallback mechanisms.\n * @param request - The request object.\n * @returns The gas fee estimates.\n */\nasync function getEstimatesUsingFallbacks(\n request: DetermineGasFeeCalculationsRequest,\n): Promise<GasFeeCalculations> {\n const {\n isEIP1559Compatible,\n isLegacyGasAPICompatible,\n nonRPCGasFeeApisDisabled,\n } = request;\n\n try {\n if (isEIP1559Compatible && !nonRPCGasFeeApisDisabled) {\n return await getEstimatesUsingFeeMarketEndpoint(request);\n }\n\n if (isLegacyGasAPICompatible && !nonRPCGasFeeApisDisabled) {\n return await getEstimatesUsingLegacyEndpoint(request);\n }\n\n throw new Error('Main gas fee/price estimation failed. Use fallback');\n } catch {\n return await getEstimatesUsingProvider(request);\n }\n}\n\n/**\n * Retrieve gas fee estimates using the EIP-1559 endpoint of the gas API.\n * @param request - The request object.\n * @returns The gas fee estimates.\n */\nasync function getEstimatesUsingFeeMarketEndpoint(\n request: DetermineGasFeeCalculationsRequest,\n): Promise<GasFeeCalculations> {\n const {\n fetchGasEstimates,\n fetchGasEstimatesUrl,\n infuraAPIKey,\n clientId,\n calculateTimeEstimate,\n } = request;\n\n const estimates = await fetchGasEstimates(\n fetchGasEstimatesUrl,\n infuraAPIKey,\n clientId,\n );\n\n const { suggestedMaxPriorityFeePerGas, suggestedMaxFeePerGas } =\n estimates.medium;\n\n const estimatedGasFeeTimeBounds = calculateTimeEstimate(\n suggestedMaxPriorityFeePerGas,\n suggestedMaxFeePerGas,\n estimates,\n );\n\n return {\n gasFeeEstimates: estimates,\n estimatedGasFeeTimeBounds,\n gasEstimateType: GAS_ESTIMATE_TYPES.FEE_MARKET,\n };\n}\n\n/**\n * Retrieve gas fee estimates using the legacy endpoint of the gas API.\n * @param request - The request object.\n * @returns The gas fee estimates.\n */\nasync function getEstimatesUsingLegacyEndpoint(\n request: DetermineGasFeeCalculationsRequest,\n): Promise<GasFeeCalculations> {\n const {\n fetchLegacyGasPriceEstimates,\n fetchLegacyGasPriceEstimatesUrl,\n infuraAPIKey,\n clientId,\n } = request;\n\n const estimates = await fetchLegacyGasPriceEstimates(\n fetchLegacyGasPriceEstimatesUrl,\n infuraAPIKey,\n clientId,\n );\n\n return {\n gasFeeEstimates: estimates,\n estimatedGasFeeTimeBounds: {},\n gasEstimateType: GAS_ESTIMATE_TYPES.LEGACY,\n };\n}\n\n/**\n * Retrieve gas fee estimates using an `eth_gasPrice` call to the RPC provider.\n * @param request - The request object.\n * @returns The gas fee estimates.\n */\nasync function getEstimatesUsingProvider(\n request: DetermineGasFeeCalculationsRequest,\n): Promise<GasFeeCalculations> {\n const { ethQuery, fetchEthGasPriceEstimate } = request;\n\n const estimates = await fetchEthGasPriceEstimate(ethQuery);\n\n return {\n gasFeeEstimates: estimates,\n estimatedGasFeeTimeBounds: {},\n gasEstimateType: GAS_ESTIMATE_TYPES.ETH_GASPRICE,\n };\n}\n"]}
@@ -1,18 +1,13 @@
1
1
  import {
2
- fetchGasEstimatesViaEthFeeHistory
3
- } from "./chunk-EXCWMMNV.mjs";
4
- import {
2
+ __privateAdd,
3
+ __privateGet,
4
+ __privateMethod,
5
+ __privateSet,
5
6
  calculateTimeEstimate,
6
7
  fetchEthGasPriceEstimate,
7
8
  fetchGasEstimates,
8
9
  fetchLegacyGasPriceEstimates
9
- } from "./chunk-QVES4OOM.mjs";
10
- import {
11
- __privateAdd,
12
- __privateGet,
13
- __privateMethod,
14
- __privateSet
15
- } from "./chunk-XUI43LEZ.mjs";
10
+ } from "./chunk-KORLXV32.mjs";
16
11
 
17
12
  // src/GasFeeController.ts
18
13
  import {
@@ -44,7 +39,8 @@ var defaultState = {
44
39
  gasFeeEstimatesByChainId: {},
45
40
  gasFeeEstimates: {},
46
41
  estimatedGasFeeTimeBounds: {},
47
- gasEstimateType: GAS_ESTIMATE_TYPES.NONE
42
+ gasEstimateType: GAS_ESTIMATE_TYPES.NONE,
43
+ nonRPCGasFeeApisDisabled: false
48
44
  };
49
45
  var _getProvider, _onNetworkControllerDidChange, onNetworkControllerDidChange_fn;
50
46
  var GasFeeController = class extends StaticIntervalPollingController {
@@ -187,7 +183,6 @@ var GasFeeController = class extends StaticIntervalPollingController {
187
183
  "<chain_id>",
188
184
  `${decimalChainId}`
189
185
  ),
190
- fetchGasEstimatesViaEthFeeHistory,
191
186
  fetchLegacyGasPriceEstimates,
192
187
  fetchLegacyGasPriceEstimatesUrl: this.legacyAPIEndpoint.replace(
193
188
  "<chain_id>",
@@ -197,7 +192,8 @@ var GasFeeController = class extends StaticIntervalPollingController {
197
192
  calculateTimeEstimate,
198
193
  clientId: this.clientId,
199
194
  ethQuery,
200
- infuraAPIKey: this.infuraAPIKey
195
+ infuraAPIKey: this.infuraAPIKey,
196
+ nonRPCGasFeeApisDisabled: this.state.nonRPCGasFeeApisDisabled
201
197
  });
202
198
  if (shouldUpdateState) {
203
199
  this.update((state) => {
@@ -279,6 +275,16 @@ var GasFeeController = class extends StaticIntervalPollingController {
279
275
  this.state.gasFeeEstimates
280
276
  );
281
277
  }
278
+ enableNonRPCGasFeeApis() {
279
+ this.update((state) => {
280
+ state.nonRPCGasFeeApisDisabled = false;
281
+ });
282
+ }
283
+ disableNonRPCGasFeeApis() {
284
+ this.update((state) => {
285
+ state.nonRPCGasFeeApisDisabled = true;
286
+ });
287
+ }
282
288
  };
283
289
  _getProvider = new WeakMap();
284
290
  _onNetworkControllerDidChange = new WeakSet();
@@ -293,74 +299,88 @@ onNetworkControllerDidChange_fn = async function(networkControllerState) {
293
299
  var GasFeeController_default = GasFeeController;
294
300
 
295
301
  // src/determineGasFeeCalculations.ts
296
- async function determineGasFeeCalculations({
297
- isEIP1559Compatible,
298
- isLegacyGasAPICompatible,
299
- fetchGasEstimates: fetchGasEstimates2,
300
- fetchGasEstimatesUrl,
301
- fetchGasEstimatesViaEthFeeHistory: fetchGasEstimatesViaEthFeeHistory2,
302
- fetchLegacyGasPriceEstimates: fetchLegacyGasPriceEstimates2,
303
- fetchLegacyGasPriceEstimatesUrl,
304
- fetchEthGasPriceEstimate: fetchEthGasPriceEstimate2,
305
- calculateTimeEstimate: calculateTimeEstimate2,
306
- clientId,
307
- ethQuery,
308
- infuraAPIKey
309
- }) {
302
+ async function determineGasFeeCalculations(args) {
310
303
  try {
311
- if (isEIP1559Compatible) {
312
- let estimates;
313
- try {
314
- estimates = await fetchGasEstimates2(
315
- fetchGasEstimatesUrl,
316
- infuraAPIKey,
317
- clientId
318
- );
319
- } catch {
320
- estimates = await fetchGasEstimatesViaEthFeeHistory2(ethQuery);
321
- }
322
- const { suggestedMaxPriorityFeePerGas, suggestedMaxFeePerGas } = estimates.medium;
323
- const estimatedGasFeeTimeBounds = calculateTimeEstimate2(
324
- suggestedMaxPriorityFeePerGas,
325
- suggestedMaxFeePerGas,
326
- estimates
327
- );
328
- return {
329
- gasFeeEstimates: estimates,
330
- estimatedGasFeeTimeBounds,
331
- gasEstimateType: GAS_ESTIMATE_TYPES.FEE_MARKET
332
- };
333
- } else if (isLegacyGasAPICompatible) {
334
- const estimates = await fetchLegacyGasPriceEstimates2(
335
- fetchLegacyGasPriceEstimatesUrl,
336
- infuraAPIKey,
337
- clientId
304
+ return await getEstimatesUsingFallbacks(args);
305
+ } catch (error) {
306
+ if (error instanceof Error) {
307
+ throw new Error(
308
+ `Gas fee/price estimation failed. Message: ${error.message}`
338
309
  );
339
- return {
340
- gasFeeEstimates: estimates,
341
- estimatedGasFeeTimeBounds: {},
342
- gasEstimateType: GAS_ESTIMATE_TYPES.LEGACY
343
- };
310
+ }
311
+ throw error;
312
+ }
313
+ }
314
+ async function getEstimatesUsingFallbacks(request) {
315
+ const {
316
+ isEIP1559Compatible,
317
+ isLegacyGasAPICompatible,
318
+ nonRPCGasFeeApisDisabled
319
+ } = request;
320
+ try {
321
+ if (isEIP1559Compatible && !nonRPCGasFeeApisDisabled) {
322
+ return await getEstimatesUsingFeeMarketEndpoint(request);
323
+ }
324
+ if (isLegacyGasAPICompatible && !nonRPCGasFeeApisDisabled) {
325
+ return await getEstimatesUsingLegacyEndpoint(request);
344
326
  }
345
327
  throw new Error("Main gas fee/price estimation failed. Use fallback");
346
328
  } catch {
347
- try {
348
- const estimates = await fetchEthGasPriceEstimate2(ethQuery);
349
- return {
350
- gasFeeEstimates: estimates,
351
- estimatedGasFeeTimeBounds: {},
352
- gasEstimateType: GAS_ESTIMATE_TYPES.ETH_GASPRICE
353
- };
354
- } catch (error) {
355
- if (error instanceof Error) {
356
- throw new Error(
357
- `Gas fee/price estimation failed. Message: ${error.message}`
358
- );
359
- }
360
- throw error;
361
- }
329
+ return await getEstimatesUsingProvider(request);
362
330
  }
363
331
  }
332
+ async function getEstimatesUsingFeeMarketEndpoint(request) {
333
+ const {
334
+ fetchGasEstimates: fetchGasEstimates2,
335
+ fetchGasEstimatesUrl,
336
+ infuraAPIKey,
337
+ clientId,
338
+ calculateTimeEstimate: calculateTimeEstimate2
339
+ } = request;
340
+ const estimates = await fetchGasEstimates2(
341
+ fetchGasEstimatesUrl,
342
+ infuraAPIKey,
343
+ clientId
344
+ );
345
+ const { suggestedMaxPriorityFeePerGas, suggestedMaxFeePerGas } = estimates.medium;
346
+ const estimatedGasFeeTimeBounds = calculateTimeEstimate2(
347
+ suggestedMaxPriorityFeePerGas,
348
+ suggestedMaxFeePerGas,
349
+ estimates
350
+ );
351
+ return {
352
+ gasFeeEstimates: estimates,
353
+ estimatedGasFeeTimeBounds,
354
+ gasEstimateType: GAS_ESTIMATE_TYPES.FEE_MARKET
355
+ };
356
+ }
357
+ async function getEstimatesUsingLegacyEndpoint(request) {
358
+ const {
359
+ fetchLegacyGasPriceEstimates: fetchLegacyGasPriceEstimates2,
360
+ fetchLegacyGasPriceEstimatesUrl,
361
+ infuraAPIKey,
362
+ clientId
363
+ } = request;
364
+ const estimates = await fetchLegacyGasPriceEstimates2(
365
+ fetchLegacyGasPriceEstimatesUrl,
366
+ infuraAPIKey,
367
+ clientId
368
+ );
369
+ return {
370
+ gasFeeEstimates: estimates,
371
+ estimatedGasFeeTimeBounds: {},
372
+ gasEstimateType: GAS_ESTIMATE_TYPES.LEGACY
373
+ };
374
+ }
375
+ async function getEstimatesUsingProvider(request) {
376
+ const { ethQuery, fetchEthGasPriceEstimate: fetchEthGasPriceEstimate2 } = request;
377
+ const estimates = await fetchEthGasPriceEstimate2(ethQuery);
378
+ return {
379
+ gasFeeEstimates: estimates,
380
+ estimatedGasFeeTimeBounds: {},
381
+ gasEstimateType: GAS_ESTIMATE_TYPES.ETH_GASPRICE
382
+ };
383
+ }
364
384
 
365
385
  export {
366
386
  determineGasFeeCalculations,
@@ -369,4 +389,4 @@ export {
369
389
  GasFeeController,
370
390
  GasFeeController_default
371
391
  };
372
- //# sourceMappingURL=chunk-G2HAZY5F.mjs.map
392
+ //# sourceMappingURL=chunk-GJSUFSHM.mjs.map