SponsorPaymaster

Deployment Address

Mainnet: 0x1842a4EFf3eFd24c50B63c3CF89cECEe245Fc2bd

Interface: ISponsorPaymaster.sol


Basics

  • An ETH-based paymaster contract for handling ETH deposits.

  • Ensures that the user pays for transactions with their ETH deposited at the entry point.

  • Features deposit management functions like adding, locking, unlocking, and withdrawing deposits.

  • Implements global, per-app, and per-user rate and cost-limiting features to control gas usage and prevent abuse.

  • Includes view functions to provide information about user limits and deposit statuses.

  • Integrates with KintoID for KYC verification and KintoAppRegistry for app-specific limits.


State functions

function addDepositFor(address account) external payable override

function unlockTokenDeposit() public override

function lockTokenDeposit() public override

function withdrawTokensTo(address target, uint256 amount) external override nonReentrant

function setAppRegistry(address _newRegistry) external override onlyOwner

function setUserOpMaxCost(uint256 _newUserOpMaxCost) external onlyOwner
  1. addDepositFor

Deposits ETH for a specific account, allowing it to be used to pay for gas.

function addDepositFor(address account) external payable override;
  1. unlockTokenDeposit

Unlocks the deposit, enabling it to be withdrawn.

function unlockTokenDeposit() public override;

No parameters.

  1. lockTokenDeposit

Locks the ETH deposited for an account so they can be used to pay for gas.

function lockTokenDeposit() public override;

No parameters.

  1. withdrawTokensTo

Withdraws ETH to a specified target address.

function withdrawTokensTo(address target, uint256 amount) external override nonReentrant;
  1. setAppRegistry

Sets the app registry address. Can only be called by the owner.

function setAppRegistry(address _newRegistry) external override onlyOwner;
  1. setUserOpMaxCost

Sets the maximum cost allowed for a user operation. Can only be called by the owner.

function setUserOpMaxCost(uint256 _newUserOpMaxCost) external onlyOwner;

View functions

function depositInfo(address account) external view returns (uint256 amount, uint256 _unlockBlock)

function appUserLimit(address wallet, address app) external view override returns (uint256, uint256, uint256, uint256)

function walletFactory() external view override returns (IKintoWalletFactory)

function appRegistry() external view override returns (IKintoAppRegistry)
  1. depositInfo

Returns deposit information for a specific account.

function depositInfo(address account) external view returns (uint256 amount, uint256 _unlockBlock);
  1. appUserLimit

Returns current user limits for an app.

function appUserLimit(address wallet, address app) external view override returns (uint256, uint256, uint256, uint256);
  1. walletFactory

Returns the address of the KintoWalletFactory contract.

function walletFactory() external view override returns (IKintoWalletFactory);

No parameters.

  1. appRegistry

Returns the address of the KintoAppRegistry contract.

function appRegistry() external view override returns (IKintoAppRegistry);

No parameters.


Constants

  • COST_OF_POST: 200,000

  • MAX_COST_OF_VERIFICATION: 530,000

  • MAX_COST_OF_PREVERIFICATION: 2,500,000

  • RATE_LIMIT_PERIOD: 1 minute

  • RATE_LIMIT_THRESHOLD_TOTAL: 50

These constants are used for various limits and calculations within the contract.

Last updated