跳转至主要内容
Change page

ERC-4626 代币化资金库标准

介绍

ERC-4626 是优化和统一收益资金库技术参数的标准。 它为表示单个底层 ERC-20 代币的份额的代币化收益资金库提供标准应用程序接口。 ERC-4626 还概述了使用 ERC-20 的代币化资金库的可选扩展,提供存款、提取代币和读取余额的基本功能。

ERC-4626 在收益资金库中的作用

借贷市场、聚合器和本质上计息的代币可以帮助用户通过执行不同的策略来找到他们的加密代币的最佳收益。 这些策略的完成方式略有不同,这可能容易出错或浪费开发资源。

收益资金库的 ERC-4626 标准通过创建更加一致和健壮的实现模式,无需开发者提供专门的工作,就能减少集成工作量并解锁在各种应用程序中获取收益的途径。

EIP-4626(opens in a new tab) 中对 ERC-4626 代币进行了全面的描述。

异步资金库扩展 (ERC-7540)

ERC-4626 针对原子存款和赎回上限进行了优化。 如果达到上限,则无法提交新的存款或赎回。 该上限不适用于任何以异步操作或延迟作为与资金库交互的先决条件的智能合约(例如现实世界资产协议、非足额抵押贷款协议、跨链贷款协议、流动性质押代币或保险安全模块)。

ERC-7540 拓展了 ERC-4626 资金库在异步用例中的实用性。 充分利用现有的资金库接口 (deposit/withdraw/mint/redeem) 来声明异步请求。

ERC-7540(opens in a new tab) 中完整描述了 ERC-7540 扩展。

多资产资金库扩展 (ERC-7575)

ERC-4626 不支持的一个缺失用例是具有多种资产或入口点的资金库,例如流动性提供商 (LP) 代币。 由于 ERC-4626 要求其本身是 ERC-20,这些用例通常难以操作或不兼容。

ERC-7575 通过从 ERC-4626 实现外部化 ERC-20 代币实现,增加了对多资产资金库的支持。

ERC-7575(opens in a new tab) 中完整描述了 ERC-7575 扩展。

前提条件

为了更好地理解这个页面,我们建议你首先阅读代币标准ERC-20

ERC-4626 的函数和功能:

方法

asset

1function asset() public view returns (address assetTokenAddress)
复制

此函数返回用于资金库记帐、存款和取款的标的代币的地址。

totalAssets

1function totalAssets() public view returns (uint256)
复制

此函数返回资金库持有的标的资产总量。

convertToShares

1function convertToShares(uint256 assets) public view returns (uint256 shares)
复制

此函数返回 shares 的数量,该数量将由资金库兑换为提供的 assets 数量。

convertToAssets

1function convertToAssets(uint256 shares) public view returns (uint256 assets)
复制

此函数返回 assets 的数量,该数量将由资金库兑换为提供的 shares 数量。

maxDeposit

1function maxDeposit(address receiver) public view returns (uint256 maxAssets)
复制

此函数返回 receiver 的一次 deposit 调用中可以存入的最大标的资产数量。

previewDeposit

1function previewDeposit(uint256 assets) public view returns (uint256 shares)
复制

此函数允许用户模拟他们在当前区块的存款效果。

deposit

1function deposit(uint256 assets, address receiver) public returns (uint256 shares)
复制

此函数将标的代币的 assets 存入资金库,并将 shares 的所有权授予 receiver

maxMint

1function maxMint(address receiver) public view returns (uint256 maxShares)
复制

此函数返回 receiver 在单次 mint 调用中可以铸造的最大份额。

previewMint

1function maxMint(address receiver) public view returns (uint256 maxShares)
复制

此函数允许用户在当前区块模拟他们的铸币效果。

mint

1function mint(uint256 shares, address receiver) public returns (uint256 assets)
复制

此函数通过存入标的代币的 assets,将 shares 资金库份额准确铸造到 receiver

maxWithdraw

1function maxWithdraw(address owner) public view returns (uint256 maxAssets)
复制

此函数返回可以通过单次 withdraw 调用从 owner 余额中提取的最大标的资产数量。

previewWithdraw

1function previewWithdraw(uint256 assets) public view returns (uint256 shares)
复制

此函数允许用户模拟他们在当前区块取款的效果。

withdraw

1function withdraw(uint256 assets, address receiver, address owner) public returns (uint256 shares)
复制

此函数从 owner 烧录 shares,并将 assets 代币从资金库准确发送到 receiver

maxRedeem

1function maxRedeem(address owner) public view returns (uint256 maxShares)
复制

此函数返回可以通过 redeem 调用从 owner 余额中赎回的最大份额。

previewRedeem

1function previewRedeem(uint256 shares) public view returns (uint256 assets)
复制

此函数允许用户在当前区块模拟他们的赎回效果。

redeem

1function redeem(uint256 shares, address receiver, address owner) public returns (uint256 assets)
复制

此函数从 owner 赎回特定数量的 shares 并将底层代币的 assets 从资金库发送到 receiver

totalSupply

1function totalSupply() public view returns (uint256)
复制

返回流通中未赎回的资金库份额总数。

balanceOf

1function balanceOf(address owner) public view returns (uint256)
复制

返回 owner 当前拥有的资金库份额总量。

接口图

ERC-4626 接口图

事件

Deposit 事件

必须在通过 mintdeposit 方法将代币存入资金库之前发出。

1event Deposit(
2 address indexed sender,
3 address indexed owner,
4 uint256 assets,
5 uint256 shares
6)
复制

其中 sender 是用 assets 兑换 shares,并将这些 shares 转移给 owner 的用户。

提款事件

必须在存款人用 redeemwithdraw 方法从资金库中取出份额时发出。

1event Withdraw(
2 address indexed sender,
3 address indexed receiver,
4 address indexed owner,
5 uint256 assets,
6 uint256 shares
7)
复制

其中 sender 是触发取款并将 owner 拥有的 shares 兑换为 assets 的用户。 receiver 是收到提取的 assets 的用户。

延伸阅读

本文对你有帮助吗?