Paymaster Methods
Imports needed for these methods:
import {
IHybridPaymaster,
PaymasterFeeQuote,
PaymasterMode,
SponsorUserOperationDto,
createPaymaster,
} from "@biconomy/account";
const biconomyPaymaster =
smartAccount.paymaster as IHybridPaymaster<SponsorUserOperationDto>;
// Or...
const biconomyPaymaster = await createPaymaster({ paymasterUrl }); // Found at https://dashboard.biconomy.io
After setting up your smart account as mentioned above you can start using the Paymaster.
getPaymasterFeeQuotesOrData()
This method is particularly useful for ERC20
mode and is used to get the fee quotes information for the ERC20 tokens.
Usage
const feeQuotesResponse = await biconomyPaymaster.getPaymasterFeeQuotesOrData(
userOp,
{
mode: PaymasterMode.ERC20,
tokenList: ["0xdA5289FCAAF71d52A80A254dA614A192B693e975"],
preferredToken: "0xdA5289FCAAF71d52A80A254dA614A192B693e975",
}
);
As per the code
- We set the mode to ERC20
- In the token list we can specify a list of addresses of the ERC20 tokens we want to have our users pay in.
- We can also decide to choose a preferred token for the response to include.
Parameters
-
userOp(
Partial<UserOperation>
, required): A UserOperation object representing the user's request that needs to be processed. -
paymasterServiceData(
FeeQuotesOrDataDto
, required): The paymaster service data containing token information and sponsorship details. You can send just the preferred token or an array of token addresses.type FeeQuotesOrDataDto = { mode?: PaymasterMode; // enum values ERC20 and SPONSORED expiryDuration?: number; // Specifies the duration, in seconds, for which the user intends the paymasterAndData to remain valid, minimum duration is 300 secs. calculateGasLimits?: boolean; tokenList?: string[]; // If you pass tokenList as an empty array. and it // would return fee quotes for all tokens supported by the Biconomy paymaster preferredToken?: string; // If you want to pass only one token webhookData?: Record<string, any>; smartAccountInfo?: SmartAccountData; // use this to calulate the gas for smart account v1, otherwise by default it will return for latest smart account version };
Returns
-
response(
Promise<FeeQuotesOrDataResponse>
): It returns a promise that resolves to the following object containing a feeQuotes Array. A paymaster Fee quote will have additional information about the fee being paid in the specified ERC20 token, how long this fee is valid, what type of premium is going to be paid, as well as general token information and the amount in USD. Here is the full typing for a single fee quote:type FeeQuotesOrDataResponse = { feeQuotes?: PaymasterFeeQuote[]; tokenPaymasterAddress?: string; paymasterAndData?: string; preVerificationGas?: BigNumberish; verificationGasLimit?: BigNumberish; callGasLimit?: BigNumberish; }; type PaymasterFeeQuote = { symbol: string; // ERC20 token symbol tokenAddress: string; // ERC20 token address decimal: number; // number of decimal places used to represent the token logoUrl?: string; // logo url of the ERC20 token maxGasFee: number; maxGasFeeUSD?: number; usdPayment?: number; // the fee converted into the USD premiumPercentage: number; // premium in percentage that biconomy charges for the txn, generally ranges between 7-12 validUntil?: number; // number (epoch time in milliseconds, till these fee quotes are valid) };
getPaymasterAndData()
The getPaymasterAndData
method is used to get the information on how the transaction fees will be covered for the transactions. The returned PaymasterAndDataResponse
includes a signed string (paymasterAndData) that signifies the paymaster's commitment to covering the transaction fee.
Parameters
-
userOperation (
UserOperation
, required): A UserOperation object representing the user's request that needs to be processed. -
paymasterServiceData (
SponsorUserOperationDto
, Optional): An optional parameter that allows you to provide additional data specific to the paymaster service.type SponsorUserOperationDto = { mode: PaymasterMode; calculateGasLimits?: boolean; expiryDuration?: number; webhookData?: { [key: string]: any; }; smartAccountInfo?: SmartAccountData; feeTokenAddress?: string; };
Returns
- paymasterAndDataResponse(
Promise<PaymasterAndDataResponse>
): It returns a promise that resolves to a Paymaster and Data Response object. The data in this response can be used to update the userOp to include sponsorship data or data for paying gas in ERC20 tokens.type PaymasterAndDataResponse = { paymasterAndData: string; preVerificationGas?: BigNumberish; verificationGasLimit?: BigNumberish; callGasLimit?: BigNumberish; };
Usage Mode: SPONSORED
There are two modes for using this function: SPONSORED
and ERC20
.
Here it is meant to act as Sponsorship/Verifying paymaster hence we send mode: PaymasterMode.SPONSORED which is required
let paymasterServiceData: SponsorUserOperationDto = {
mode: PaymasterMode.SPONSORED,
// optional params...
calculateGasLimits: true,
};
const paymasterAndDataResponse = await biconomyPaymaster.getPaymasterAndData(
userOp,
paymasterServiceData
);
userOp.paymasterAndData = paymasterAndDataResponse.paymasterAndData;
As per the code we get the Paymaster Data Response and update the userOp, to specify that this will be a sponsored transaction by the Biconomy Paymaster.
Usage Mode: ERC20
ERC20 mode enables you to pay the gas fees of your users in exchange for ERC-20 tokens. When switching mode to ERC20 there are additional steps that need to be considered.
1. Get paymaster fee quote: We need to get the swap quotes of the ERC20 tokens that the user is paying for the native token of the network we are on.
const feeQuotesResponse = await biconomyPaymaster.getPaymasterFeeQuotesOrData(
userOp,
{
mode: PaymasterMode.ERC20,
tokenList: [],
preferredToken: "",
}
);
2. Update userOp: After getting this information we need to build our updated userOp with the preferred feeQuote
from the feeQuotes
array. Here spender is the ERC20 paymaster contract address.
finalUserOp = await smartAccount.buildTokenPaymasterUserOp(userOp, {
feeQuote: selectedFeeQuote,
spender: spender,
maxApproval: false,
});
3. Create paymaster data: Now we create our paymasterServiceData
again and call the getPaymasterAndData
method
let paymasterServiceData = {
mode: PaymasterMode.ERC20,
feeTokenAddress: selectedFeeQuote.tokenAddress,
calculateGasLimits: true, // Always recommended and especially when using token paymaster
};
const paymasterAndDataWithLimits = await biconomyPaymaster.getPaymasterAndData(
finalUserOp,
paymasterServiceData
);
finalUserOp.paymasterAndData = paymasterAndDataWithLimits.paymasterAndData;