This way we can define protocol and chain specific addresses in this file and use them in the Encoders --- don't change below this line --- ENG-4306 Took 1 hour 4 minutes
55 lines
1.8 KiB
Rust
55 lines
1.8 KiB
Rust
use std::collections::HashMap;
|
|
|
|
use crate::encoding::{
|
|
errors::EncodingError,
|
|
models::{Chain, 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
|
|
/// * `chain` - The chain on which the swap will be executed
|
|
/// * `config` - Additional configuration parameters for the encoder, like vault or registry
|
|
/// address
|
|
fn new(
|
|
executor_address: String,
|
|
chain: Chain,
|
|
config: Option<HashMap<String, String>>,
|
|
) -> Result<Self, EncodingError>
|
|
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()
|
|
}
|
|
}
|