pool-sync 3.0.0

A library for synchronizing and managing various types of liquidity pools across different blockchains
Documentation
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),
        ])))
    }


}