EthereumRoutingState#
tradeexecutor.ethereum.routing_state.EthereumRoutingState Python class in Trading Strategy framework.
- class EthereumRoutingState[source]#
Bases:
RoutingState
Manage transaction building for multiple Uniswap trades.
Lifespan is one rebalance - remembers already made approvals
Web3 connection and hot wallet
Approval tx creation
Swap tx creation
Manage the state of already given approvals here, so that we do not do duplicates.
The approvals are not persistent in the executor state, but are specific for each cycle.
- __init__(pair_universe, tx_builder=None, swap_gas_limit=2000000, web3=None)[source]#
- Parameters:
pair_universe (PandasPairUniverse) – Pairs we trade
tx_builder (Optional[TransactionBuilder]) –
For creating trade transactions.
Can be set to None on DummyExecutionModel.
web3 (Optional[Web3]) –
Use for routing smart contract reads.
Given when tx_builder is not present.
swap_gas_limit – What is the max gas we are willing to pay for a swap.
Methods
__init__
(pair_universe[, tx_builder, ...])- param pair_universe:
check_has_enough_tokens
(erc_20, amount)Check we have enough buy side tokens to do a trade.
ensure_token_approved
(token_address, ...)Make sure we have ERC-20 approve() for the trade
get_signed_tx
(swap_func, gas_limit)Get a router for a trading pair.
is_approved_on_chain
(token_address, ...)is_route_approved
(router_address)mark_router_approved
(token_address, ...)trade_on_router_three_way
(uniswap, ...)Prepare the actual swap for three way trade.
trade_on_router_two_way
(uniswap, ...)Prepare the actual swap.
validate_exchange
(target_pair, intermediary_pair)Check routing happens on the same exchange
validate_pairs
(target_pair, intermediary_pair)Check we can chain two pairs
Attributes
- __init__(pair_universe, tx_builder=None, swap_gas_limit=2000000, web3=None)[source]#
- Parameters:
pair_universe (PandasPairUniverse) – Pairs we trade
tx_builder (Optional[TransactionBuilder]) –
For creating trade transactions.
Can be set to None on DummyExecutionModel.
web3 (Optional[Web3]) –
Use for routing smart contract reads.
Given when tx_builder is not present.
swap_gas_limit – What is the max gas we are willing to pay for a swap.
- abstract trade_on_router_two_way(uniswap, target_pair, reserve_asset, reserve_amount, max_slippage, check_balances)[source]#
Prepare the actual swap. Same for Uniswap V2 and V3.
- Parameters:
uniswap (eth_defi.uniswap_v2.deployment.UniswapV2Deployment | eth_defi.uniswap_v3.deployment.UniswapV3Deployment) –
target_pair (TradingPairIdentifier) –
reserve_asset (AssetIdentifier) –
reserve_amount (int) –
max_slippage (float) –
check_balances (False) –
- abstract trade_on_router_three_way(uniswap, target_pair, intermediary_pair, reserve_asset, reserve_amount, max_slippage, check_balances)[source]#
Prepare the actual swap for three way trade.
- Parameters:
uniswap (eth_defi.uniswap_v2.deployment.UniswapV2Deployment | eth_defi.uniswap_v3.deployment.UniswapV3Deployment) –
target_pair (TradingPairIdentifier) –
intermediary_pair (TradingPairIdentifier) –
reserve_asset (AssetIdentifier) –
reserve_amount (int) –
max_slippage (float) –
check_balances (False) –
- check_has_enough_tokens(erc_20, amount)[source]#
Check we have enough buy side tokens to do a trade.
This might not be the case if we are preparing transactions ahead of time and sell might have not happened yet.