ERC-4626 Tokenized Vault Standard
Last edit: @wackerow(opens in a new tab), December 24, 2024
Introduction
ERC-4626 is a standard to optimize and unify the technical parameters of yield-bearing vaults. It provides a standard API for tokenized yield-bearing vaults that represent shares of a single underlying ERC-20 token. ERC-4626 also outlines an optional extension for tokenized vaults utilizing ERC-20, offering basic functionality for depositing, withdrawing tokens and reading balances.
The role of ERC-4626 in yield-bearing vaults
Lending markets, aggregators, and intrinsically interest-bearing tokens help users find the best yield on their crypto tokens by executing different strategies. These strategies are done with slight variation, which might be error-prone or waste development resources.
ERC-4626 in yield-bearing vaults will lower the integration effort and unlock access to yield in various applications with little specialized effort from developers by creating more consistent and robust implementation patterns.
The ERC-4626 token is described fully in EIP-4626(opens in a new tab).
Asynchronous vault extension (ERC-7540)
ERC-4626 is optimized for atomic deposits and redemptions up to a limit. If the limit is reached, no new deposits or redemptions can be submitted. This limitation does not work well for any smart contract system with asynchronous actions or delays as a prerequisite for interfacing with the Vault (e.g. real-world asset protocols, undercollateralized lending protocols, cross-chain lending protocols, liquid staking tokens, or insurance safety modules).
ERC-7540 expands the utility of ERC-4626 Vaults for asynchronous use cases. The existing Vault interface (deposit
/withdraw
/mint
/redeem
) is fully utilized to claim asynchronous Requests.
The ERC-7540 extension is described fully in ERC-7540(opens in a new tab).
Multi-asset vault extension (ERC-7575)
One missing use case that is not supported by ERC-4626 is Vaults which have multiple assets or entry points such as liquidity provider (LP) Tokens. These are generally unwieldy or non-compliant due to the requirement of ERC-4626 to itself be an ERC-20.
ERC-7575 adds support for Vaults with multiple assets by externalizing the ERC-20 token implementation from the ERC-4626 implementation.
The ERC-7575 extension is described fully in ERC-7575(opens in a new tab).
Prerequisites
To better understand this page, we recommend you first read about token standards and ERC-20.
ERC-4626 Functions and Features:
Methods
asset
1function asset() public view returns (address assetTokenAddress)Copy
This function returns the address of the underlying token used for the vault for accounting, depositing, withdrawing.
totalAssets
1function totalAssets() public view returns (uint256)Copy
This function returns the total amount of underlying assets held by the vault.
convertToShares
1function convertToShares(uint256 assets) public view returns (uint256 shares)Copy
This function returns the amount of shares
that would be exchanged by the vault for the amount of assets
provided.
convertToAssets
1function convertToAssets(uint256 shares) public view returns (uint256 assets)Copy
This function returns the amount of assets
that would be exchanged by the vault for the amount of shares
provided.
maxDeposit
1function maxDeposit(address receiver) public view returns (uint256 maxAssets)Copy
This function returns the maximum amount of underlying assets that can be deposited in a single deposit
call by the receiver
.
previewDeposit
1function previewDeposit(uint256 assets) public view returns (uint256 shares)Copy
This function allows users to simulate the effects of their deposit at the current block.
deposit
1function deposit(uint256 assets, address receiver) public returns (uint256 shares)Copy
This function deposits assets
of underlying tokens into the vault and grants ownership of shares
to receiver
.
maxMint
1function maxMint(address receiver) public view returns (uint256 maxShares)Copy
This function returns the maximum amount of shares that can be minted in a single mint
call by the receiver
.
previewMint
1function previewMint(uint256 shares) public view returns (uint256 assets)Copy
This function allows users to simulate the effects of their mint at the current block.
mint
1function mint(uint256 shares, address receiver) public returns (uint256 assets)Copy
This function mints exactly shares
vault shares to receiver
by depositing assets
of underlying tokens.
maxWithdraw
1function maxWithdraw(address owner) public view returns (uint256 maxAssets)Copy
This function returns the maximum amount of underlying assets that can be withdrawn from the owner
balance with a single withdraw
call.
previewWithdraw
1function previewWithdraw(uint256 assets) public view returns (uint256 shares)Copy
This function allows users to simulate the effects of their withdrawal at the current block.
withdraw
1function withdraw(uint256 assets, address receiver, address owner) public returns (uint256 shares)Copy
This function burns shares
from owner
and send exactly assets
token from the vault to receiver
.
maxRedeem
1function maxRedeem(address owner) public view returns (uint256 maxShares)Copy
This function returns the maximum amount of shares that can be redeemed from the owner
balance through a redeem
call.
previewRedeem
1function previewRedeem(uint256 shares) public view returns (uint256 assets)Copy
This function allows users to simulate the effects of their redemption at the current block.
redeem
1function redeem(uint256 shares, address receiver, address owner) public returns (uint256 assets)Copy
This function redeems a specific number of shares
from owner
and sends assets
of underlying token from the vault to receiver
.
totalSupply
1function totalSupply() public view returns (uint256)Copy
Returns the total number of unredeemed vault shares in circulation.
balanceOf
1function balanceOf(address owner) public view returns (uint256)Copy
Returns the total amount of vault shares the owner
currently has.
Map of the interface
Events
Deposit Event
MUST be emitted when tokens are deposited into the vault via the mint
and deposit
methods.
1event Deposit(2 address indexed sender,3 address indexed owner,4 uint256 assets,5 uint256 shares6)Copy
Where sender
is the user who exchanged assets
for shares
, and transferred those shares
to owner
.
Withdraw Event
MUST be emitted when shares are withdrawn from the vault by a depositor in the redeem
or withdraw
methods.
1event Withdraw(2 address indexed sender,3 address indexed receiver,4 address indexed owner,5 uint256 assets,6 uint256 shares7)Copy
Where sender
is the user who triggered the withdrawal and exchanged shares
, owned by owner
, for assets
. receiver
is the user who received the withdrawn assets
.