Gas abstraction
How to best handle transactions sponsoring
Gas abstraction is crucial to provide users a seamless interaction with your application. Ideally, end-users should not have to care about paying gas or having gas tokens in their wallet.
Abstracting account deployment
By default, Argent will automatically deploy and pay for the deployment of accounts generated through the Invisible SDK.
However, you should have a fallback in case the Argent service is down and unable to pay for accounts deployment.
Calling the requestConnection
method will return ConnectResponse
If
deploymentPayload
isundefined
, that means that the wallet account is deployedIf not, you'll need to deploy it using
deployAndExecuteWithPaymaster
As a second fallback, you can notify the user in the UI that the account needs to be funded
Abstracting ERC-20 approvals
The Invisible SDK lets you bundle ERC-20 approvals together with the approval of a session. These particular approvals are also sponsored by Argent. In some cases, you might need users to sign additional ERC-20 approvals later in their journey (not part of the session approval). These ERC-20 approvals are not sponsored by Argent.
Again, make sure to have a fallback in case our relayer service is unavailable.
Abstracting other types of transactions
We recommend that you totally abstract gas for users and hence sponsor all other types of transactions (onchain recordings, swaps, transfers etc...) using the AVNU paymaster.
You can also airdrop/sell your own token to users and let them pay gas fees with it.
Last updated
Was this helpful?