/network-gas-price

Query accurate gas prices on every blockchain network ⛽️

Primary LanguageTypeScriptMIT LicenseMIT

network-gas-price

Tests npm version codecov npm bundle size

Query accurate gas prices on every blockchain network ⛽️

Highlights

  • Zero dependencies 🧹
  • Lightweight 📦
  • Simple to use ⚡️
  • Ethereum and Polygon networks 🚀

Why

Gas price is constantly changing on every blockchain network based on demand to run transactions. When sending a transaction to the network, it's important to set an accurate gas price in order to avoid stuck transactions or pay too much gas fees.

Getting started

  1. Install the package & its peer dependency
yarn add @enzoferey/network-gas-price isomorphic-unfetch
  1. Get network prices
import { getNetworkGasPrice } from "@enzoferey/network-gas-price";

const networkGasPrice = await getNetworkGasPrice("ethereum");

// networkGasPrice is an object with the following shape:
//
// {
//   low: {
//     maxPriorityFeePerGas: number;
//     maxFeePerGas: number;
//   },
//   average: {
//     maxPriorityFeePerGas: number;
//     maxFeePerGas: number;
//   },
//   high: {
//     maxPriorityFeePerGas: number;
//     maxFeePerGas: number;
//   },
//   asap: {
//     maxPriorityFeePerGas: number;
//     maxFeePerGas: number;
//   }
// }

// NOTE: All prices are returned in Gwei units

💡 The price level ("low", "average", "high", "asap") you should use depends on your type of application. Most use cases will do okay with "average" or "high". If your application has background transactions support and execution is not time critical, you could use "low". If your application has a strong need to execute transactions as soon as possible, we recommend using our custom "asap" option that protects against high gas prices spikes and makes the transaction attractive for miners.

🌐 The package currently supports the Ethereum ("ethereum"), Polygon ("polygon"), Goerli ("goerli"), Sepolia ("sepolia"), Rinkeby ("rinkeby"), and Mumbai ("mumbai") networks. If you would like to add support for a new network, please open an issue or pull request.

  1. Use gas prices (with Ethers.js as an example):
import { ethers, BigNumber } from "ethers";

function getGweiEthers(gweiAmount: number): BigNumber {
  return ethers.utils.parseUnits(Math.ceil(gweiAmount).toString(), "gwei");
}

try {
  const networkGasPrice = await getNetworkGasPrice("ethereum");
  const transaction = await someContract.someMethod(someArgument, {
    maxPriorityFeePerGas: getGweiEthers(
      networkGasPrice.high.maxPriorityFeePerGas
    ),
    maxFeePerGas: getGweiEthers(networkGasPrice.high.maxFeePerGas),
  });
  await transaction.wait();
} catch (error) {
  // Handle error
  // -> You could use my package https://github.com/enzoferey/ethers-error-parser for that 😉
}