@dopex-io/web3-multicall
v0.1.10
Published
A library to do multiple calls via a single eth_call using web3.js
Downloads
1,222
Readme
web3-multicall
A library to do multiple calls via a single eth_call
using web3.
Installation
- via yarn
yarn add @dopex-io/web3-multicall
- via npm
npm i @dopex-io/web3-multicall
Usage
Constructing
With
chainId
import Multicall from '@dopex-io/web3-multicall'; import erc20Abi from './abi/erc20.json'; async function main() { const web3 = new Web3(provider /* Your Web3 provider here */); const multicall = new Multicall({ chainId: 1, provider: 'Your Web3 provider here', defaultBlock: 1000 /* Optional */ }); ... } main()
With custom Multicall address
import Multicall from '@dopex-io/web3-multicall'; import erc20Abi from './abi/erc20.json'; async function main() { const web3 = new Web3(provider /* Your Web3 provider here */); const multicall = new Multicall({ multicallAddress: "The address of the deployed multicall contract", provider: 'Your Web3 provider here', defaultBlock: 1000 /* Optional */ }); ... } main();
Aggregating
const dpxContract = new web3.eth.Contract(dpxAddress, erc20Abi);
const balances = await multicall.aggregate([
dpxContract.methods.balanceOf('Address 1'),
dpxContract.methods.balanceOf('Address 2'),
multicall.getEthBalance('Address 3'),
]);
console.log('DPX balance of Address 1', balances[0]);
console.log('DPX balance of Address 2', balances[1]);
console.log('ETH balance of Address 3', balances[2]);
Helper Functions
getEthBalance
Gets the ETH balance of an addressconst ethBalance = multicall.getEthBalance('address');
getBlockHash
Gets the block hashconst blockHash = multicall.getBlockHash(blockNumber);
getLastBlockHash
Gets the last blocks hashconst lastBlockHash = multicall.getLastBlockHash();
getCurrentBlockTimestamp
Gets the current block timestampconst currentBlockTimestamp = multicall.getCurrentBlockTimestamp();
getCurrentBlockDifficulty
Gets the current block difficultyconst currentBlockDifficulty = multicall.getCurrentBlockDifficulty();
getCurrentBlockGasLimit
Gets the current block gas limitconst currentBlockGasLimit = multicall.getCurrentBlockGasLimit();
getCurrentBlockCoinbase
Gets the current block coinbaseconst currentBlockCoinbase = multicall.getCurrentBlockCoinbase();
License
This project is licensed under the MIT License - Copyright (c) 2023 Dopex