From 6db8148820dd7aaf5455154299583aba2210d15f Mon Sep 17 00:00:00 2001 From: ethzoomer Date: Wed, 15 Jan 2025 08:51:57 -0600 Subject: [PATCH] feat: add velo superchain bribes, volume/fees --- dexs/velodrome-slipstream/index.ts | 52 +++++++++++++++++++++--- dexs/velodrome-v2/index.ts | 5 +++ fees/velodrome-v2/index.ts | 64 ++++++++++++++++++++++++------ 3 files changed, 104 insertions(+), 17 deletions(-) diff --git a/dexs/velodrome-slipstream/index.ts b/dexs/velodrome-slipstream/index.ts index c0af24d635..87b700aeda 100644 --- a/dexs/velodrome-slipstream/index.ts +++ b/dexs/velodrome-slipstream/index.ts @@ -2,13 +2,34 @@ import { FetchOptions, FetchResultV2, SimpleAdapter } from "../../adapters/types import { CHAIN } from "../../helpers/chains"; const sugarOld = '0x3e532BC1998584fe18e357B5187897ad0110ED3A'; // old Sugar version doesn't properly support pagination -const sugar = '0xdE2aE25FB984dd60C77dcF6489Be9ee6438eC195'; const abis: any = { "forSwaps": "function forSwaps(uint256 _limit, uint256 _offset) view returns ((address lp, int24 type, address token0, address token1, address factory, uint256 pool_fee)[])" } +const superchainConfig = { + [CHAIN.OPTIMISM]: { + sugar: '0xdE2aE25FB984dd60C77dcF6489Be9ee6438eC195', + }, + [CHAIN.MODE]: { + sugar: '0x8A5e97184E8850064805fAc2427ce7728689De5B', + }, + [CHAIN.LISK]: { + sugar: '0x0F5B7D59690F99f34081E24557f022d06d580BB6', + }, + [CHAIN.INK]: { + sugar: '0xD938B20f40505e33b7C131e6aDD6C6FF7380094A', + }, + [CHAIN.SONEIUM]: { + sugar: '0xB1d0DFFe6260982164B53EdAcD3ccd58B081889d', + }, + [CHAIN.FRAXTAL]: { + sugar: '0xB1d0DFFe6260982164B53EdAcD3ccd58B081889d', + } +} + interface IForSwap { lp: string; + type: number; token0: string; token1: string; pool_fee: string; @@ -29,10 +50,10 @@ const fetch = async (options: FetchOptions): Promise => { let currentOffset = 0; const allForSwaps: IForSwap[] = []; let unfinished = true; - let sugarContract = sugar; + let sugarContract = superchainConfig[options.chain]['sugar']; // before the new Sugar is deployed, we must use the old Sugar contract, and make one large Sugar call - if (options.startOfDay < 1715160600) { + if (options.chain === CHAIN.OPTIMISM && options.startOfDay < 1715160600) { chunkSize = 1800; sugarContract = sugarOld; } @@ -42,12 +63,13 @@ const fetch = async (options: FetchOptions): Promise => { target: sugarContract, params: [chunkSize, currentOffset], abi: abis.forSwaps, - chain: CHAIN.OPTIMISM, + chain: options.chain, })); const forSwaps: IForSwap[] = forSwapsUnfiltered.filter(t => Number(t.type) > 0).map((e: any) => { return { lp: e.lp, + type: e.type, token0: e.token0, token1: e.token1, pool_fee: e.pool_fee, @@ -99,7 +121,27 @@ const adapters: SimpleAdapter = { [CHAIN.OPTIMISM]: { fetch: fetch as any, start: '2024-03-06', - } + }, + [CHAIN.MODE]: { + fetch: fetch as any, + start: '2024-11-13', + }, + [CHAIN.LISK]: { + fetch: fetch as any, + start: '2024-11-13', + }, + [CHAIN.FRAXTAL]: { + fetch: fetch as any, + start: '2024-11-19', + }, + // [CHAIN.INK]: { + // fetch: fetch as any, + // start: '2025-01-14', + // }, + // [CHAIN.SONEIUM]: { + // fetch: fetch as any, + // start: '2025-01-14', + // }, } } export default adapters; diff --git a/dexs/velodrome-v2/index.ts b/dexs/velodrome-v2/index.ts index 53ec460e68..db518a348b 100644 --- a/dexs/velodrome-v2/index.ts +++ b/dexs/velodrome-v2/index.ts @@ -4,4 +4,9 @@ const swapEvent = 'event Swap(address indexed sender, address indexed to, uint25 export default uniV2Exports({ [CHAIN.OPTIMISM]: { factory: '0xF1046053aa5682b4F9a81b5481394DA16BE5FF5a', swapEvent, }, + [CHAIN.MODE]: { factory: '0x31832f2a97Fd20664D76Cc421207669b55CE4BC0', swapEvent, }, + [CHAIN.LISK]: { factory: '0x31832f2a97Fd20664D76Cc421207669b55CE4BC0', swapEvent, }, + [CHAIN.FRAXTAL]: { factory: '0x31832f2a97Fd20664D76Cc421207669b55CE4BC0', swapEvent, }, + //[CHAIN.INK]: { factory: '0x31832f2a97Fd20664D76Cc421207669b55CE4BC0', swapEvent, }, + //[CHAIN.SONEIUM]: { factory: '0x31832f2a97Fd20664D76Cc421207669b55CE4BC0', swapEvent, }, }) diff --git a/fees/velodrome-v2/index.ts b/fees/velodrome-v2/index.ts index 2f0536426f..a8a789d46c 100644 --- a/fees/velodrome-v2/index.ts +++ b/fees/velodrome-v2/index.ts @@ -6,6 +6,9 @@ const notifyRewardEvent = 'event NotifyReward(address indexed from,uint256 amoun const event_notify_reward_op = 'event NotifyReward(address indexed from,address indexed reward,uint256 indexed epoch,uint256 amount)'; const event_gauge_created = 'event GaugeCreated(address indexed poolFactory,address indexed votingRewardsFactory,address indexed gaugeFactory,address pool,address bribeVotingReward,address feeVotingReward,address gauge,address creator)' +const leaf_gauge_created = 'event GaugeCreated(address indexed poolFactory,address indexed votingRewardsFactory,address indexed gaugeFactory,address pool,address incentiveVotingReward,address feeVotingReward,address gauge)' +const leaf_voter = '0x97cDBCe21B6fd0585d29E539B1B99dAd328a1123' +const leaf_pool_factory = '0x31832f2a97Fd20664D76Cc421207669b55CE4BC0' const config = { [CHAIN.MODE]: { @@ -18,13 +21,32 @@ const config = { } } +const superchainConfig = { + [CHAIN.MODE]: { + start_block: 15405187, + }, + [CHAIN.LISK]: { + start_block: 8339180, + }, + [CHAIN.INK]: { + start_block: 3448692, + }, + [CHAIN.SONEIUM]: { + start_block: 1906595, + }, + [CHAIN.FRAXTAL]: { + start_block: 12603117, + } +} + const customLogic = async ({ dailyFees, fetchOptions, filteredPairs, }: any) => { const { createBalances, getLogs, chain, api, getToBlock, } = fetchOptions + const dailyBribes = createBalances() + // handle native OP Mainnet bribes if (chain === CHAIN.OPTIMISM) { let voter = '0x41C914ee0c7E1A5edCD0295623e6dC557B5aBf3C' - const dailyBribes = createBalances() const logs_gauge_created = (await getLogs({ target: voter, fromBlock: 105896852, @@ -41,30 +63,48 @@ const customLogic = async ({ dailyFees, fetchOptions, filteredPairs, }: any) => logs.map((e: any) => { dailyBribes.add(e.reward, e.amount) }) - - return { dailyBribesRevenue: dailyBribes } as any } - else { + // handle Superchain beta "staking rewards" bribes on Mode and Bob + if (chain in config) { const { stakingRewards, rewardToken, } = config[chain] const pairs = Object.keys(filteredPairs) const gauges = await api.multiCall({ target: stakingRewards, abi: 'function gauges(address) view returns (address)', calls: pairs }) - const dailyBribesRevenue = createBalances() let logs = await getLogs({ targets: gauges, eventAbi: notifyRewardEvent }) logs.forEach(log => { - dailyBribesRevenue.add(rewardToken, log.amount) + dailyBribes.add(rewardToken, log.amount) + }) + } + + // handle Superchain 1.0 L2 bribes + if (chain in superchainConfig) { + const leaf_gauge_logs = (await getLogs({ + target: leaf_voter, + fromBlock: superchainConfig[chain]['start_block'], + toBlock: await getToBlock(), + eventAbi: leaf_gauge_created, + cacheInCloud: true, + })) + const incentive_contracts: string[] = leaf_gauge_logs.map((e: any) => e.incentiveVotingReward.toLowerCase()); + + let logs = await getLogs({ + targets: incentive_contracts, + eventAbi: event_notify_reward_op, + }) + logs.map((e: any) => { + dailyBribes.add(e.reward, e.amount) }) - return { - dailyFees, - dailyRevenue: dailyFees, - dailyHoldersRevenue: dailyFees, - dailyBribesRevenue, - }; } + + return { dailyBribesRevenue: dailyBribes } as any } export default uniV2Exports({ [CHAIN.OPTIMISM]: { factory: '0xF1046053aa5682b4F9a81b5481394DA16BE5FF5a', swapEvent, voter: '0x41c914ee0c7e1a5edcd0295623e6dc557b5abf3c', maxPairSize: 500, customLogic, }, [CHAIN.MODE]: { factory: '0x31832f2a97Fd20664D76Cc421207669b55CE4BC0', customLogic }, [CHAIN.BOB]: { factory: '0x31832f2a97Fd20664D76Cc421207669b55CE4BC0', swapEvent, customLogic, }, + [CHAIN.LISK]: {factory: leaf_pool_factory, customLogic}, + [CHAIN.FRAXTAL]: {factory: leaf_pool_factory, customLogic}, + //[CHAIN.INK]: {factory: leaf_pool_factory, customLogic}, + //[CHAIN.SONEIUM]: {factory: leaf_pool_factory, customLogic}, })