Files
tycho-execution/src/encoding/swap_encoder.rs

46 lines
1.5 KiB
Rust

use crate::encoding::{
errors::EncodingError,
models::{EncodingContext, Swap},
};
/// A trait for protocol-specific swap encoding, where each implementation should handle the
/// encoding logic for swaps on a specific protocol.
pub trait SwapEncoder: Sync + Send {
/// Creates a new swap encoder for a specific protocol.
///
/// # Arguments
/// * `executor_address` - The address of the contract that will execute the swap
fn new(executor_address: String) -> Self
where
Self: Sized;
/// Encodes a swap for execution on the protocol.
///
/// # Arguments
/// * `swap` - The swap details including the protocol component, token in, token out, and split
/// * `encoding_context` - Additional context needed for encoding (receiver of the tokens,
/// router address, etc.)
///
/// # Returns
/// The encoded swap data as bytes, directly executable on the executor contract
fn encode_swap(
&self,
swap: Swap,
encoding_context: EncodingContext,
) -> Result<Vec<u8>, EncodingError>;
/// Returns the address of the protocol-specific executor contract.
fn executor_address(&self) -> &str;
/// Creates a cloned instance of the swap encoder.
///
/// This allows the encoder to be cloned when it is being used as a `Box<dyn SwapEncoder>`.
fn clone_box(&self) -> Box<dyn SwapEncoder>;
}
impl Clone for Box<dyn SwapEncoder> {
fn clone(&self) -> Box<dyn SwapEncoder> {
self.clone_box()
}
}