vault.deposit_redeem
Documentation for eth_defi.vault.deposit_redeem Python module.
Abstraction over different deposit/redeem flows of vaults.
Classes
Analyse a vault deposit/redeem event. |
|
DepositRedeemEventFailure(tx_hash: hexbytes.main.HexBytes, revert_reason: str | None) |
|
Wrap the different deposit functions async vaults implement. |
|
In-progress deposit request. |
|
Wrap the different redeem functions async vaults implement. |
|
In-progress redemption request. |
|
Abstraction over different deposit/redeem flows of vaults. |
Exceptions
We did no know how our redemption transaction went. |
|
One of vault deposit/redeem transactions reverted |
- exception VaultTransactionFailed
Bases:
ExceptionOne of vault deposit/redeem transactions reverted
- __init__(*args, **kwargs)
- __new__(**kwargs)
- add_note()
Exception.add_note(note) – add a note to the exception
- with_traceback()
Exception.with_traceback(tb) – set self.__traceback__ to tb and return self.
- class DepositRedeemEventFailure
Bases:
objectDepositRedeemEventFailure(tx_hash: hexbytes.main.HexBytes, revert_reason: str | None)
- class DepositRedeemEventAnalysis
Bases:
objectAnalyse a vault deposit/redeem event.
Done for the transaction where we get our assets into our wallet, so we can determine the actualy executed price of shares we received/sold
- __init__(from_, to, denomination_amount, share_count, tx_hash, block_number, block_timestamp)
- Parameters
from_ (eth_typing.evm.HexAddress) –
to (eth_typing.evm.HexAddress) –
denomination_amount (decimal.Decimal) –
share_count (decimal.Decimal) –
tx_hash (hexbytes.main.HexBytes) –
block_number (eth_typing.evm.BlockNumber) –
block_timestamp (datetime.datetime) –
- Return type
None
- class DepositTicket
Bases:
objectIn-progress deposit request.
- tx_hash: hexbytes.main.HexBytes
Last of transaction hashes
- block_timestamp: datetime.datetime
Last tx block timestamp
- __init__(vault_address, owner, to, raw_amount, tx_hash, gas_used, block_number, block_timestamp)
- Parameters
vault_address (eth_typing.evm.HexAddress) –
owner (eth_typing.evm.HexAddress) –
to (eth_typing.evm.HexAddress) –
raw_amount (int) –
tx_hash (hexbytes.main.HexBytes) –
gas_used (int) –
block_number (int) –
block_timestamp (datetime.datetime) –
- Return type
None
- class RedemptionTicket
Bases:
objectIn-progress redemption request.
Needs to wait until the epoch time is over or owner has settled
Serialisable class
- abstract get_request_id()
Get the redemption request id.
If vault uses some sort of request ids to track the withdrawals
Needed for settlement
- Return type
- __init__(vault_address, owner, to, raw_shares, tx_hash)
- Parameters
vault_address (eth_typing.evm.HexAddress) –
owner (eth_typing.evm.HexAddress) –
to (eth_typing.evm.HexAddress) –
raw_shares (int) –
tx_hash (hexbytes.main.HexBytes) –
- Return type
None
- exception CannotParseRedemptionTransaction
Bases:
ExceptionWe did no know how our redemption transaction went.
- __init__(*args, **kwargs)
- __new__(**kwargs)
- add_note()
Exception.add_note(note) – add a note to the exception
- with_traceback()
Exception.with_traceback(tb) – set self.__traceback__ to tb and return self.
- class RedemptionRequest
Bases:
objectWrap the different redeem functions async vaults implement.
- owner: eth_typing.evm.HexAddress
Owner of the shares
- to: eth_typing.evm.HexAddress
Receiver of underlying asset
Human-readable shares
Raw amount of shares
- funcs: list[web3.contract.contract.ContractFunction]
Transactions we need to perform in order to open a redemption
It’s a list because for Gains we need 2 tx
- parse_redeem_transaction(tx_hashes)
Parse the transaction receipt to get the actual shares redeemed.
Assumes only one redemption request per vault per transaction
- Raises
CannotParseRedemptionTransaction – If we did not know how to parse the transaction
- Parameters
tx_hashes (list[hexbytes.main.HexBytes]) –
- Return type
- broadcast(from_=None, gas=1000000)
Broadcast all the transactions in this request.
- Parameters
from – Address to send the transactions from
gas (int) – Gas limit to use for each transaction
from_ (eth_typing.evm.HexAddress) –
- Returns
List of transaction hashes
- Return type
list[hexbytes.main.HexBytes]
- __init__(vault, owner, to, shares, raw_shares, funcs)
- Parameters
vault (VaultBase) –
owner (eth_typing.evm.HexAddress) –
to (eth_typing.evm.HexAddress) –
shares (decimal.Decimal) –
raw_shares (int) –
funcs (list[web3.contract.contract.ContractFunction]) –
- Return type
None
- class DepositRequest
Bases:
objectWrap the different deposit functions async vaults implement.
- owner: eth_typing.evm.HexAddress
Owner of the shares
- to: eth_typing.evm.HexAddress
Receiver of underlying asset
- amount: decimal.Decimal
Human-readable shares
- funcs: list[web3.contract.contract.ContractFunction]
Transactions we need to perform in order to open a redemption
It’s a list because for Gains we need 2 tx
- value: decimal.Decimal | None
Attached ETH value to the tx
- parse_deposit_transaction(tx_hashes)
Parse the transaction receipt to get the actual shares redeemed.
Assumes only one redemption request per vault per transaction
Most throw an
- Raises
CannotParseRedemptionTransaction – If we did not know how to parse the transaction
VaultTransactionFailed – One of transactions reverted
- Parameters
tx_hashes (list[hexbytes.main.HexBytes]) –
- Return type
- broadcast(from_=None, gas=None, check_value=True)
Broadcast all the transactions in this request.
- Parameters
from – Address to send the transactions from
gas (int | None) – Gas limit to use for each transaction
from_ (eth_typing.evm.HexAddress) –
- Returns
List of transaction hashes
- Raises
TransactionAssertionError – If any of the transactions revert
- Return type
- __init__(vault, owner, to, amount, raw_amount, funcs, gas=None, value=None)
- Parameters
vault (VaultBase) –
owner (eth_typing.evm.HexAddress) –
to (eth_typing.evm.HexAddress) –
amount (decimal.Decimal) –
raw_amount (int) –
funcs (list[web3.contract.contract.ContractFunction]) –
gas (int | None) –
value (decimal.Decimal | None) –
- Return type
None
- class VaultDepositManager
Bases:
abc.ABCAbstraction over different deposit/redeem flows of vaults.
- __init__(vault)
- Parameters
vault (eth_defi.vault.base.VaultBase) –
- abstract has_synchronous_deposit()
Does this vault support synchronous deposits?
E.g. ERC-4626 vaults
- Return type
- abstract has_synchronous_redemption()
Does this vault support synchronous deposits?
E.g. ERC-4626 vaults
- Return type
- abstract estimate_deposit(owner, amount, block_identifier='latest')
How many shares we get for a deposit.
- Parameters
owner (Optional[eth_typing.evm.HexAddress]) –
amount (decimal.Decimal) –
block_identifier (Union[Literal['latest', 'earliest', 'pending', 'safe', 'finalized'], eth_typing.evm.BlockNumber, eth_typing.evm.Hash32, eth_typing.encoding.HexStr, int]) –
- Return type
- abstract estimate_redeem(owner, shares, block_identifier='latest')
How many denomination tokens we get for a redeem.
- Parameters
owner (Optional[eth_typing.evm.HexAddress]) –
shares (decimal.Decimal) –
block_identifier (Union[Literal['latest', 'earliest', 'pending', 'safe', 'finalized'], eth_typing.evm.BlockNumber, eth_typing.evm.Hash32, eth_typing.encoding.HexStr, int]) –
- Return type
- abstract create_redemption_request(owner, to, shares=None, raw_shares=None, check_max_deposit=True, check_enough_token=True)
Create a redemption request.
Abstracts IPOR, Lagoon, Gains, other vault redemption flow.
See
eth_defi.gains.vault.GainsVaultfor an example usage.Flow
create_redemption_request
sign and broadcast the transaction
parse success and redemption request id from the transaction
wait until the redemption delay is over
settle the redemption request
- Parameters
owner (eth_typing.evm.HexAddress) – Deposit owner.
shares (decimal.Decimal) –
Share amount in decimal.
Will be converted to raw_shares using share_token decimals.
raw_shares (int) – Raw amount in share token
to (eth_typing.evm.HexAddress) –
- Returns
Redemption request wrapper.
- Return type
- abstract is_redemption_in_progress(owner)
Check if the owner has an active redemption request.
- Parameters
owner (eth_typing.evm.HexAddress) – Owner of the shares
- Returns
True if there is an active redemption request
- Return type
- abstract is_deposit_in_progress(owner)
Check if the owner has an active deposit request.
- Parameters
owner (eth_typing.evm.HexAddress) – Owner of the shares
- Returns
True if there is an active redemption request
- Return type
- can_create_deposit_request(owner)
Can we start depositing now.
Vault can be full?
- Parameters
owner (eth_typing.evm.HexAddress) –
- Return type
- get_max_deposit(owner)
How much we can deposit
- Parameters
owner (eth_typing.evm.HexAddress) –
- Return type
decimal.Decimal | None
- abstract can_create_redemption_request(owner)
Gains allows request redepetion only two first days of three days epoch.
- Returns
True if can create a redemption request now
- Parameters
owner (eth_typing.evm.HexAddress) –
- Return type
- abstract can_finish_redeem(redemption_ticket)
Check if the redemption request can be redeemed now.
Phase 2 of redemption, after settlement
- Parameters
redemption_ticket (eth_defi.vault.deposit_redeem.RedemptionTicket) – Redemption redemption_ticket ticket from create_redemption_request()
- Returns
True if can be redeemed now
- Return type
- abstract can_finish_deposit(deposit_ticket)
Can we finish the deposit process in async reposits
- Parameters
deposit_ticket (eth_defi.vault.deposit_redeem.DepositTicket) –
- Return type
- abstract finish_deposit(deposit_ticket)
Can we finish the deposit process in async vault.
We can claim our shares from the vault now
- Parameters
deposit_ticket (eth_defi.vault.deposit_redeem.DepositTicket) –
- Return type
web3.contract.contract.ContractFunction
- abstract estimate_redemption_delay()
Get the redemption delay for this vault.
What is overall redemption delay: not related to the current moment
How long it takes before a redemption request is allowed
This is not specific for any address, but the general vault rule
E.g. you get 0xa592703b is an IPOR Fusion error code AccountIsLocked, if you try to instantly redeem from IPOR vaults
- Returns
Redemption delay as a
datetime.timedelta- Raises
NotImplementedError – If not implemented for this vault protocoll.
- Return type
- abstract get_redemption_delay_over(address)
Get the redemption timer left for an address.
How long it takes before a redemption request is allowed
This is not specific for any address, but the general vault rule
E.g. you get 0xa592703b is an IPOR Fusion error code AccountIsLocked, if you try to instantly redeem from IPOR vaults
- Returns
UTC timestamp when the account can redeem.
Naive datetime.
- Raises
NotImplementedError – If not implemented for this vault protocoll.
- Parameters
address (Union[eth_typing.evm.HexAddress, str]) –
- Return type
- abstract analyse_deposit(claim_tx_hash, deposit_ticket)
Analyse the transaction where we claim shares
Return information of the actual executed price for which we got the shares for
- Parameters
claim_tx_hash (hexbytes.main.HexBytes | str) –
deposit_ticket (eth_defi.vault.deposit_redeem.DepositTicket | None) –
- Return type
eth_defi.vault.deposit_redeem.DepositRedeemEventAnalysis | eth_defi.vault.deposit_redeem.DepositRedeemEventFailure
- abstract analyse_redemption(claim_tx_hash, redemption_ticket)
Analyse the transaction where we claim our capital back.
Return information of the actual executed price for which we got the shares for
- Parameters
claim_tx_hash (hexbytes.main.HexBytes | str) –
redemption_ticket (eth_defi.vault.deposit_redeem.RedemptionTicket | None) –
- Return type
eth_defi.vault.deposit_redeem.DepositRedeemEventAnalysis | eth_defi.vault.deposit_redeem.DepositRedeemEventFailure