Methods
estimateUserOperationGas
This method is used to estimate gas for the userOp. It returns estimates for preVerificationGas, verificationGasLimit, and callGasLimit for a given UserOperation. It requires passing a semi-valid/ dummy signature in userOp (e.g. a signature of the correct length and format).
Usageconst estimateUserOperationGasResponse: EstimateUserOperationGas = await gasEstimator.estimateUserOperationGas({
userOperation,
supportsEthCallStateOverride,
supportsEthCallByteCodeOverride,
stateOverrideSet
baseFeePerGas
});
- userOperation(
UserOperation
, required): userOperation to calculate gas estimates for. - stateOverrideSet(
StateOverrideSet
): optional state override set for estimating gas for a userOperation under different blockchain states. - supportsEthCallStateOverride (
boolean
): optional param, default set to true, set to false if eth_call does not support state overrides - supportsEthCallByteCodeOverride (
boolean
): optional param, default set to true, set to false if eth_call does not give the correct response to bytecode overrides - baseFeePerGas (
bigint
): optional param, but required for Optimism based networks
-
estimateUserOperationGasResponse(
Promise<EstimateUserOperationGas>
): It returns an object containing the following gas limits.type EstimateUserOperationGas = { callGasLimit: bigint; verificationGasLimit: bigint; preVerificationGas: bigint; validAfter: number; validUntil: number; };
estimateVerificationGasLimit
This method is used to estimate the verificationGasLimit for a given userOperation.
Usageconst verificationGasLimitResponse: EstimateVerificationGasLimit =
await gasEstimator.estimateVerificationGasLimit({
userOperation,
supportsEthCallStateOverride,
supportsEthCallByteCodeOverride,
stateOverrideSet,
});
- userOperation(
UserOperation
, required): userOperation to calculate gas estimates for. - stateOverrideSet(
StateOverrideSet
): optional state override set for estimating gas for a userOperation under different blockchain states. - supportsEthCallStateOverride (
boolean
): optional param, default set to true, set to false if eth_call does not support state overrides - supportsEthCallByteCodeOverride (
boolean
): optional param, default set to true, set to false if eth_call does not give the correct response to bytecode overrides
-
verificationGasLimitResponse(
Promise<EstimateVerificationGasLimit>
): It returns an object containing the verificationGasLimit, validUntil, and validAfter valuestype EstimateVerificationGasLimit = { verificationGasLimit: bigint; validAfter: number; validUntil: number; };
estimateCallGasLimit
This method is used to estimate the callGasLimit for a given userOperation.
Usageconst callGasLimitResponse = await gasEstimator.estimateCallGasLimit({
userOperation,
supportsEthCallStateOverride,
supportsEthCallByteCodeOverride,
stateOverrideSet,
});
- userOperation(
UserOperation
, required): userOperation to calculate gas estimates for. - stateOverrideSet(
StateOverrideSet
): optional state override set for estimating gas for a userOperation under different blockchain states. - supportsEthCallStateOverride (
boolean
): optional param, default set to true, set to false if eth_call does not support state overrides - supportsEthCallByteCodeOverride (
boolean
): optional param, default set to true, set to false if eth_call does not give the correct response to bytecode overrides
-
callGasLimitResponse(
Promise<EstimateCallGasLimit>
): It returns an object containing the callGasLimit valuetype EstimateCallGasLimit = { callGasLimit: bigint; };
calculatePreVerificationGas
This method is used to estimate the preVerificationGas for a given userOperation. The exact implementation of this method is network-dependent hence make sure to use network-specific gas estimator clients
Usageconst preVerficationGasResponse =
await gasEstimator.calculatePreVerificationGas({
userOperation,
baseFeePerGas,
});
- userOperation(
UserOperation
, required): userOperation to calculate gas estimates for. - baseFeePerGas (
bigint
): optional param, but required for Optimism based networks
-
preVerificationGasResponse(
Promise<CalculatePreVerificationGas>
) : It returns an object containing the preVerficationGas valuetype CalculatePreVerificationGas = { preVerificationGas: bigint; };
setEntryPointAddress
This method is used to set the entryPointAddress that is being used in the Gas Estimator instance
Usageawait gasEstimator.setEntryPointAddress("<ENTRY_POINT_ADDRESS>");
- entryPointAddress(
string
, required): entry point address that one might need to change to.
- void