AsyncSynthVault

EpochData

Git Source

This structure contains all the informations needed to let user claim their request after we processed those. To avoid rounding errors we store the totalSupply and totalAssets at the time of the deposit/redeem for the deposit and the redeem. We also store the amount of assets and shares given by the user.

struct EpochData {
    uint256 totalSupplySnapshotForRedeem;
    uint256 totalAssetsSnapshotForRedeem;
    uint256 totalSupplySnapshotForDeposit;
    uint256 totalAssetsSnapshotForDeposit;
    mapping(address => uint256) depositRequestBalance;
    mapping(address => uint256) redeemRequestBalance;
}

SettleValues

Git Source

Hold the required values to settle the vault deposit and redeem requests.

struct SettleValues {
    uint256 lastSavedBalance;
    uint256 fees;
    uint256 pendingRedeem;
    uint256 sharesToMint;
    uint256 pendingDeposit;
    uint256 assetsToWithdraw;
    uint256 totalAssetsSnapshotForDeposit;
    uint256 totalSupplySnapshotForDeposit;
    uint256 totalAssetsSnapshotForRedeem;
    uint256 totalSupplySnapshotForRedeem;
}

AsyncSynthVault

Git Source

Inherits: IERC7540, SyncSynthVault

State Variables

epochId

The epochId is used to keep track of the deposit and redeem requests. It is incremented every time the owner calls the settle function.

uint256 public epochId;

pendingSilo

The lastSavedBalance is used to keep track of the assets in the vault at the time of the last settle call.

Silo public pendingSilo;

claimableSilo

The claimableSilo is used to hold the assets/shares of the users that requested a deposit/redeem.

Silo public claimableSilo;

epochs

The epochs mapping is used to store the informations needed to let user claim their request after we processed those. To avoid rounding errors we store the totalSupply and totalAssets at the time of the deposit/redeem for the deposit and the redeem. We also store the amount of assets and shares given by the user.

mapping(uint256 epochId => EpochData epoch) public epochs;

lastDepositRequestId

The lastDepositRequestId is used to keep track of the last deposit request made by the user. It is used to let the user claim their request after we processed those.

mapping(address user => uint256 epochId) public lastDepositRequestId;

lastRedeemRequestId

The lastRedeemRequestId is used to keep track of the last redeem request made by the user. It is used to let the user claim their request after we processed those.

mapping(address user => uint256 epochId) public lastRedeemRequestId;

Functions

constructor

constructor() SyncSynthVault();

initialize

function initialize(
    uint16 fees,
    address owner,
    IERC20 underlying,
    string memory name,
    string memory symbol
)
    public
    virtual
    override
    initializer;

claimAndRequestDeposit

Since we only allow one claimable request at a time, users must claim their request before making a new one. This function let users claim and request a deposit in one transaction.

This function is used to claim the pending deposit and request a new one in one transaction.

function claimAndRequestDeposit(
    uint256 assets,
    address receiver,
    bytes memory data
)
    external;

Parameters

claimAndRequestRedeem

Since we only allow one claimable request at a time, users must claim their request before making a new one. This function let users claim and request a redeem in one transaction.

This function is used to claim the pending redeem and request a new one in one transaction.

function claimAndRequestRedeem(uint256 shares, bytes memory data) external;

Parameters

decreaseDepositRequest

This function is used to decrease the amount of assets requested to deposit by the user. It can only be called by the user who made the request.

function decreaseDepositRequest(uint256 assets)
    external
    whenClosed
    whenNotPaused;

Parameters

decreaseRedeemRequest

This function is used to decrease the amount of shares requested to redeem by the user. It can only be called by the user who made the request.

function decreaseRedeemRequest(uint256 shares)
    external
    whenClosed
    whenNotPaused;

Parameters

close

The close function is used to close the vault. It can only be called by the owner of the contract (onlyOwner modifier).

function close() external override onlyOwner;

open

The open function is used to end the lock period of the vault. It can only be called by the owner of the contract (onlyOwner modifier) and only when the vault is locked. If there are profits, the performance fees are taken and sent to the owner of the contract.

The open function is used to open the vault.

function open(uint256 assetReturned)
    external
    override
    onlyOwner
    whenNotPaused
    whenClosed;

Parameters

claimAndRequestDepositWithPermit

claimAndRequestDepositWithPermit is used to claim the pending deposit and request a new one in one transaction using permit signatures.

function claimAndRequestDepositWithPermit(
    uint256 assets,
    bytes memory data,
    PermitParams calldata permitParams
)
    external;

Parameters

settle

The settle function is used to settle the vault. It can only be called by the owner of the contract (onlyOwner modifier). If there are profits, the performance fees are taken and sent to the owner of the contract. Since amphor strategies can be time sensitive, we must be able to switch epoch without needing to put all the funds back. Using _settle we can virtually put back the funds, check how much we owe to users that want to redeem and maybe take the extra funds from the deposit requests.

The settle function is used to settle the vault.

function settle(uint256 newSavedBalance) external;

Parameters

pendingRedeemRequest

pendingRedeemRequest is used to know how many shares are currently waiting to be redeemed for the user.

function pendingRedeemRequest(address owner) external view returns (uint256);

Parameters

claimableRedeemRequest

How many shares are virtually waiting for the user to be redeemed via the claimRedeem function.

function claimableRedeemRequest(address owner)
    external
    view
    returns (uint256);

Parameters

pendingDepositRequest

How many assets are currently waiting to be deposited for the user.

function pendingDepositRequest(address owner)
    external
    view
    returns (uint256 assets);

Parameters

claimableDepositRequest

How many assets are virtually waiting for the user to be deposit via the claimDeposit function.

function claimableDepositRequest(address owner)
    external
    view
    returns (uint256 assets);

Parameters

totalPendingDeposits

How many assets are currently waiting to be deposited for all users.

function totalPendingDeposits() external view returns (uint256);

Returns

totalPendingRedeems

How many shares are waiting to be redeemed for all users.

function totalPendingRedeems() external view returns (uint256);

Returns

totalClaimableShares

How many shares are virtually waiting for the user to be redeemed via the claimRedeem function.

function totalClaimableShares() external view returns (uint256);

Returns

totalClaimableAssets

How many assets are virtually waiting for the user to be deposit via the claimDeposit function.

function totalClaimableAssets() external view returns (uint256);

Returns

requestDeposit

when the vault is closed, users can only request to deposit. By doing this funds will be sent and wait in the pendingSilo. When the owner will call the open or settle function, the funds will be deposited and the minted shares will be sent to the claimableSilo. Waiting for the users to claim them.

function requestDeposit(
    uint256 assets,
    address receiver,
    address owner,
    bytes memory data
)
    public
    whenNotPaused
    whenClosed;

Parameters

requestRedeem

when the vault is closed, users can only request to redeem. By doing this shares will be sent and wait in the pendingSilo. When the owner will call the open or settle function, the shares will be redeemed and the assets will be sent to the claimableSilo. Waiting for the users to claim them.

function requestRedeem(
    uint256 shares,
    address receiver,
    address owner,
    bytes memory data
)
    public
    whenNotPaused
    whenClosed;

Parameters

claimDeposit

This function let users claim the shares we owe them after we processed their deposit request, in the _settle function.

function claimDeposit(address receiver)
    public
    whenNotPaused
    returns (uint256 shares);

Parameters

claimRedeem

This function let users claim the assets we owe them after we processed their redeem request, in the _settle function.

function claimRedeem(address receiver)
    public
    whenNotPaused
    returns (uint256 assets);

Parameters

requestDepositWithPermit

This funciton let user request a deposit using permit signatures.

function requestDepositWithPermit(
    uint256 assets,
    address receiver,
    bytes memory data,
    PermitParams calldata permitParams
)
    public;

Parameters

maxDepositRequest

users can request deposit only when the vault is closed and not paused.

function maxDepositRequest(address) public view returns (uint256);

Returns

maxRedeemRequest

users can request redeem only when the vault is closed and not paused.

function maxRedeemRequest(address owner) public view returns (uint256);

Parameters

Returns

previewClaimDeposit

This function let users preview how many shares they will get if they claim their deposit request.

This function let users preview how many shares they will get if they claim their deposit request.

function previewClaimDeposit(address owner) public view returns (uint256);

Parameters

Returns

previewClaimRedeem

This function let users preview how many assets they will get if they claim their redeem request.

This function let users preview how many assets they will get if they claim their redeem request.

function previewClaimRedeem(address owner) public view returns (uint256);

Parameters

Returns

convertToShares

This function convertToShares is used to convert the assets into shares.

function convertToShares(
    uint256 assets,
    uint256 _epochId
)
    public
    view
    returns (uint256);

Parameters

Returns

convertToAssets

This function convertToAssets is used to convert the shares into assets.

function convertToAssets(
    uint256 shares,
    uint256 _epochId
)
    public
    view
    returns (uint256);

Parameters

Returns

claimableDepositBalanceInAsset

Utils function to convert the shares claimable into assets. It can be used in the front end to save an rpc call.

Using this the owner can know if he will have to send money to the claimableSilo (for users who want to leave the vault) or if he will receive money from it.

This function claimableDepositBalanceInAsset is used to know if the owner will have to send money to the claimableSilo (for users who want to leave the vault) or if he will receive money from it.

function claimableDepositBalanceInAsset(address owner)
    public
    view
    returns (uint256);

Parameters

Returns

previewSettle

Using this the owner can know if he will have to send money to the claimableSilo (for users who want to leave the vault) or if he will receive money from it.

This function claimableRedeemBalanceInShares is used to know if the owner will have to send money to the claimableSilo (for users who want to leave the vault) or if he will receive money from it.

function previewSettle(uint256 newSavedBalance)
    public
    view
    returns (
        uint256 assetsToOwner,
        uint256 assetsToVault,
        SettleValues memory settleValues
    );

Parameters

Returns

supportsInterface

see EIP

function supportsInterface(bytes4 interfaceId) public pure returns (bool);

Parameters

Returns

_createDepositRequest

This function is used to update the balance of the user.

This function is used to update the balance of the user.

function _createDepositRequest(
    uint256 assets,
    address receiver,
    address owner,
    bytes memory data
)
    internal;

Parameters

_createRedeemRequest

This function is used to update the balance of the user.

_createRedeemRequest is used to update the balance of the user in order to create the redeem request.

function _createRedeemRequest(
    uint256 shares,
    address receiver,
    address owner,
    bytes memory data
)
    internal;

Parameters

_claimDeposit

_claimDeposit is used to claim the pending deposit and request a new one in one transaction.

function _claimDeposit(
    address owner,
    address receiver
)
    internal
    returns (uint256 shares);

Parameters

Returns

_claimRedeem

_claimRedeem is used to claim the pending redeem and request a new one in one transaction.

function _claimRedeem(
    address owner,
    address receiver
)
    internal
    whenNotPaused
    returns (uint256 assets);

Parameters

Returns

_settle

_settle is used to settle the vault.

function _settle(uint256 newSavedBalance)
    internal
    onlyOwner
    whenNotPaused
    whenClosed
    returns (uint256, uint256);

Parameters

Returns

isCurrentEpoch

isCurrentEpoch is used to check if the request is the current epoch.

function isCurrentEpoch(uint256 requestId) internal view returns (bool);

Parameters

_convertToShares

_convertToShares is used to convert the assets into shares for a specific epoch/request.

function _convertToShares(
    uint256 assets,
    uint256 requestId,
    Math.Rounding rounding
)
    internal
    view
    returns (uint256);

Parameters

_convertToAssets

_convertToAssets is used to convert the shares into assets for a specific epoch/request.

function _convertToAssets(
    uint256 shares,
    uint256 requestId,
    Math.Rounding rounding
)
    internal
    view
    returns (uint256);

Parameters

_checkMaxDrawdown

_checkMaxDrawdown is used to check if the max drawdown is reached.

function _checkMaxDrawdown(
    uint256 _lastSavedBalance,
    uint256 newSavedBalance
)
    internal
    view;

Parameters

_computeFees

function _computeFees(
    uint256 _lastSavedBalance,
    uint256 newSavedBalance
)
    internal
    view
    returns (uint256 fees);

Events

DecreaseDepositRequest

This event is emitted when a user request a deposit.

event DecreaseDepositRequest(
    uint256 indexed requestId,
    address indexed owner,
    uint256 indexed previousRequestedAssets,
    uint256 newRequestedAssets
);

Parameters

DecreaseRedeemRequest

This event is emitted when a user request a redeem.

event DecreaseRedeemRequest(
    uint256 indexed requestId,
    address indexed owner,
    uint256 indexed previousRequestedShares,
    uint256 newRequestedShares
);

Parameters

ClaimDeposit

This event is emitted when a user request a redeem.

event ClaimDeposit(
    uint256 indexed requestId,
    address indexed owner,
    address indexed receiver,
    uint256 assets,
    uint256 shares
);

Parameters

ClaimRedeem

This event is emitted when a user request a redeem.

event ClaimRedeem(
    uint256 indexed requestId,
    address indexed owner,
    address indexed receiver,
    uint256 assets,
    uint256 shares
);

Parameters

Errors

ExceededMaxRedeemRequest

This error is emitted when the user request more shares than the maximum allowed.

error ExceededMaxRedeemRequest(
    address receiver, uint256 shares, uint256 maxShares
);

Parameters

ExceededMaxDepositRequest

This error is emitted when the user request more assets than the maximum allowed.

error ExceededMaxDepositRequest(
    address receiver, uint256 assets, uint256 maxDeposit
);

Parameters

MustClaimFirst

This error is emitted when the user try to make a new request without claiming the previous one.

error MustClaimFirst(address owner);

Parameters

ReceiverFailed

This error is emitted when the user try to make a new request without claiming the previous one.

error ReceiverFailed();

NotOwner

This error is emitted when the user try to make a new request without claiming the previous one.

error NotOwner();

NullRequest

This error is emitted when the user try to make a new request without claiming the previous one.

error NullRequest();

ERC7540CantRequestDepositOnBehalfOf

This error is emitted when the user try to make a new request without claiming the previous one.

error ERC7540CantRequestDepositOnBehalfOf();

Last updated