Request for Quote Protocols
To add support for a new RFQ provider in Tycho, you’ll need to implement a client, a state, and the logic to encode and execute trades.
The state, encoding, and execution logic for RFQs follow the same structure as on-chain protocol integrations. See our simulation and execution guides for details.
We recommend using the existing Bebop integration as a reference.
RFQClient
Each RFQ protocol must implement the RFQClient trait:
#[async_trait]
pub trait RFQClient: Send + Sync {
    fn stream(
        &self,
    ) -> BoxStream<'static, Result<(String, StateSyncMessage<TimestampHeader>), RFQError>>;
    async fn request_binding_quote(
        &self,
        params: &GetAmountOutParams,
    ) -> Result<SignedQuote, RFQError>;
}Responsibilities:
- stream: Connects to the RFQ provider and emits real-time indicative price updates. 
- request_binding_quote: Sends an HTTP request to fetch a binding quote for a specific swap. 
You’ll also need to provide a builder to configure and construct your client, similar to BebopClientBuilder.
State
Each provider must define a state object that represents a full snapshot of their indicative prices.
This state must implement:
- ProtocolSimfor simulation
- TryFromWithBlockto decode incoming messages into a usable state
Details on how to implement these can be found here.
Encoder + Executor
To support execution, implement:
- Encoder: Encodes the calldata to execute a swap on the RFQ via the Tycho Router. Be sure to request the binding quote here. 
- Executor: Executes the swap 
For more see here.
This allows the RFQ to be used in hybrid routes and benefit from Tycho’s execution optimizations.
Last updated
