feat: Remove router_address from TychoEncoder
Make the router address mandatory for the Solution attribute instead --- don't change below this line --- ENG-4088 Took 30 minutes
This commit is contained in:
18
README.md
18
README.md
@@ -11,6 +11,7 @@ designed to be safe, straightforward, and quick to set up, so anyone can start t
|
||||
### Installation
|
||||
|
||||
First, build and install the binary:
|
||||
|
||||
```bash
|
||||
# Build the project
|
||||
cargo build --release
|
||||
@@ -19,12 +20,11 @@ cargo build --release
|
||||
cargo install --path .
|
||||
```
|
||||
|
||||
After installation, the `tycho-encode` command will be available to use from any directory in your terminal. The command accepts the following options:
|
||||
After installation, the `tycho-encode` command will be available to use from any directory in your terminal. The command
|
||||
accepts the following options:
|
||||
|
||||
- `-c`: Path to the executor addresses configuration file (defaults to `src/encoding/config/executor_addresses.json`)
|
||||
- `-p`: Private key for signing approvals (required when direct_execution is false)
|
||||
- `ROUTER_ADDRESS`: Router contract address (defaults to `0xaa820C29648D5EA543d712cC928377Bd7206a0E7`)
|
||||
|
||||
|
||||
### Encoding Transactions
|
||||
|
||||
@@ -36,9 +36,6 @@ echo '<solution_payload>' | tycho-encode
|
||||
|
||||
# Using custom config path
|
||||
echo '<solution_payload>' | tycho-encode -c /path/to/your/config.json
|
||||
|
||||
# Using custom router address and config path
|
||||
echo '<solution_payload>' | tycho-encode -c /path/to/your/config.json 0x1234...5678
|
||||
```
|
||||
|
||||
#### Example
|
||||
@@ -49,7 +46,6 @@ Here's a complete example that encodes a swap from WETH to DAI using Uniswap V2:
|
||||
echo '{"sender":"0x1234567890123456789012345678901234567890","receiver":"0x1234567890123456789012345678901234567890","given_token":"0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2","given_amount":"1000000000000000000","checked_token":"0x6B175474E89094C44Da98b954EedeAC495271d0F","exact_out":false,"slippage":0.01,"expected_amount":"1000000000000000000","check_amount":"990000000000000000","router_address":"0xaa820C29648D5EA543d712cC928377Bd7206a0E7","swaps":[{"component":{"id":"0x88e6A0c2dDD26FEEb64F039a2c41296FcB3f5640","protocol_system":"uniswap_v2","protocol_type_name":"UniswapV2Pool","chain":"ethereum","tokens":["0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2"],"contract_ids":["0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D"],"static_attributes":{"factory":"0x5c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f"},"change":"Update","creation_tx":"0x0000000000000000000000000000000000000000000000000000000000000000","created_at":"2024-02-28T12:00:00"},"token_in":"0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2","token_out":"0x6B175474E89094C44Da98b954EedeAC495271d0F","split":1.0}],"direct_execution":true}' | tycho-encode
|
||||
```
|
||||
|
||||
|
||||
#### JSON Payload Structure: Solution struct
|
||||
|
||||
The `Solution` struct is composed of the following fields:
|
||||
@@ -64,10 +60,10 @@ The `Solution` struct is composed of the following fields:
|
||||
- `expected_amount`: The expected output amount
|
||||
- `check_amount`: The minimum acceptable output amount (accounting for slippage)
|
||||
- `swaps`: Array of swap steps, each containing:
|
||||
- `component`: Details about the DEX/protocol being used
|
||||
- `token_in`: Input token address for this step
|
||||
- `token_out`: Output token address for this step
|
||||
- `split`: Proportion of tokens to route through this step (1.0 = 100%)
|
||||
- `component`: Details about the DEX/protocol being used
|
||||
- `token_in`: Input token address for this step
|
||||
- `token_out`: Output token address for this step
|
||||
- `split`: Proportion of tokens to route through this step (1.0 = 100%)
|
||||
- `router_address`: The address of the protocol's router contract
|
||||
- `direct_execution`: Boolean indicating if the transaction should be executed directly
|
||||
|
||||
|
||||
Reference in New Issue
Block a user