use alloy::primitives::{address, Address};
use alloy::sol_types::SolEvent;
use alloy::primitives::Log;
use alloy::sol;
use alloy::dyn_abi::DynSolType;
use crate::pools::PoolFetcher;
use crate::pools::PoolType;
use crate::Chain;
sol!(
#[derive(Debug)]
event PoolCreated(
address poolAddress,
uint8 protocolFeeRatio,
uint256 feeAIn,
uint256 feeBIn,
uint256 tickSpacing,
uint256 lookback,
int32 activeTick,
address tokenA,
address tokenB,
uint8 kinds,
address accessor
);
);
pub struct MaverickV2Fetcher;
impl PoolFetcher for MaverickV2Fetcher {
fn pool_type(&self) -> PoolType {
PoolType::MaverickV2
}
fn factory_address(&self, chain: Chain) -> Address {
match chain {
Chain::Ethereum => address!("0A7e848Aca42d879EF06507Fca0E7b33A0a63c1e"),
Chain::Base => address!("0A7e848Aca42d879EF06507Fca0E7b33A0a63c1e"),
}
}
fn pair_created_signature(&self) -> &str {
PoolCreated::SIGNATURE
}
fn log_to_address(&self, log: &Log) -> Address {
let decoded_log = PoolCreated::decode_log(log, false).unwrap();
decoded_log.data.poolAddress
}
fn get_pool_repr(&self) -> DynSolType {
DynSolType::Array(Box::new(DynSolType::Tuple(vec![
DynSolType::Address,
DynSolType::Address,
DynSolType::Address,
DynSolType::Uint(8),
DynSolType::Uint(8),
])))
}
}