@steerprotocol/sdk 1.30.8-test-algebra-plugins.2 → 1.31.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/base/PoolClient.js +137 -0
- package/dist/cjs/base/PoolClient.js.map +1 -1
- package/dist/cjs/base/VaultClient.js +111 -2
- package/dist/cjs/base/VaultClient.js.map +1 -1
- package/dist/cjs/const/feeManagerContracts.js +25 -0
- package/dist/cjs/const/feeManagerContracts.js.map +1 -0
- package/dist/cjs/const/network.js +7 -0
- package/dist/cjs/const/network.js.map +1 -1
- package/dist/cjs/const/protocol.js +68 -92
- package/dist/cjs/const/protocol.js.map +1 -1
- package/dist/cjs/scripts/processDeployments.js +1 -0
- package/dist/cjs/scripts/processDeployments.js.map +1 -1
- package/dist/esm/base/PoolClient.js +137 -0
- package/dist/esm/base/PoolClient.js.map +1 -1
- package/dist/esm/base/VaultClient.js +111 -2
- package/dist/esm/base/VaultClient.js.map +1 -1
- package/dist/esm/const/feeManagerContracts.js +25 -0
- package/dist/esm/const/feeManagerContracts.js.map +1 -0
- package/dist/esm/const/network.js +7 -0
- package/dist/esm/const/network.js.map +1 -1
- package/dist/esm/const/protocol.js +68 -92
- package/dist/esm/const/protocol.js.map +1 -1
- package/dist/esm/scripts/processDeployments.js +1 -0
- package/dist/esm/scripts/processDeployments.js.map +1 -1
- package/dist/types/base/PoolClient.d.ts +22 -0
- package/dist/types/base/PoolClient.d.ts.map +1 -1
- package/dist/types/base/VaultClient.d.ts +20 -0
- package/dist/types/base/VaultClient.d.ts.map +1 -1
- package/dist/types/const/feeManagerContracts.d.ts +6 -0
- package/dist/types/const/feeManagerContracts.d.ts.map +1 -0
- package/dist/types/const/network.d.ts +1 -0
- package/dist/types/const/network.d.ts.map +1 -1
- package/dist/types/const/protocol.d.ts +4 -19
- package/dist/types/const/protocol.d.ts.map +1 -1
- package/package.json +3 -2
- package/src/__tests__/base/PoolClient.test.ts +355 -104
- package/src/__tests__/base/StakingClient.test.ts +72 -72
- package/src/__tests__/base/VaultClient.protocol-filter.test.ts +64 -137
- package/src/__tests__/base/VaultClient.test.ts +460 -60
- package/src/__tests__/base/vault/single-asset/calculateLimitPrice.test.ts +32 -14
- package/src/__tests__/base/vault/single-asset/calculateSwapAmount.test.ts +7 -4
- package/src/__tests__/base/vault/single-asset/estimateLpTokens.test.ts +105 -570
- package/src/__tests__/base/vault/single-asset/simulateSwap.test.ts +45 -66
- package/src/__tests__/base/vault/single-asset/singleAssetDepositClient.test.ts +178 -381
- package/src/__tests__/const/network.feeManager.test.ts +47 -0
- package/src/__tests__/fixtures/live/single-asset.fixture.json +116 -0
- package/src/__tests__/fixtures/live/staking-pools.fixture.json +353 -0
- package/src/__tests__/fixtures/live/vaults.fixture.json +5392 -0
- package/src/base/PoolClient.ts +200 -1
- package/src/base/VaultClient.ts +169 -2
- package/src/const/feeManagerContracts.ts +28 -0
- package/src/const/network.ts +10 -1
- package/src/const/protocol.ts +18 -39
- package/src/scripts/processDeployments.ts +1 -0
|
@@ -76,6 +76,64 @@ class PoolClient extends SubgraphClient_js_1.SubgraphClient {
|
|
|
76
76
|
apiCallCount: this.apiCallCount,
|
|
77
77
|
};
|
|
78
78
|
}
|
|
79
|
+
normalizeAddress(value) {
|
|
80
|
+
return value?.toLowerCase() || '';
|
|
81
|
+
}
|
|
82
|
+
normalizeSymbol(value) {
|
|
83
|
+
return value?.trim().toLowerCase() || '';
|
|
84
|
+
}
|
|
85
|
+
dedupePools(pools) {
|
|
86
|
+
const seen = new Set();
|
|
87
|
+
const deduped = [];
|
|
88
|
+
pools.forEach((pool) => {
|
|
89
|
+
const key = this.normalizeAddress(pool.id);
|
|
90
|
+
if (!key || seen.has(key)) {
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
seen.add(key);
|
|
94
|
+
deduped.push(pool);
|
|
95
|
+
});
|
|
96
|
+
return deduped;
|
|
97
|
+
}
|
|
98
|
+
filterPoolsBySymbols(pools, symbols) {
|
|
99
|
+
if (symbols.length === 0) {
|
|
100
|
+
return pools;
|
|
101
|
+
}
|
|
102
|
+
const normalizedSymbols = new Set(symbols.map((symbol) => this.normalizeSymbol(symbol)).filter(Boolean));
|
|
103
|
+
return pools.filter((pool) => {
|
|
104
|
+
const token0Symbol = this.normalizeSymbol(pool.token0?.symbol);
|
|
105
|
+
const token1Symbol = this.normalizeSymbol(pool.token1?.symbol);
|
|
106
|
+
return normalizedSymbols.has(token0Symbol) || normalizedSymbols.has(token1Symbol);
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
applyPoolSearchResultFilters(pools, filter) {
|
|
110
|
+
let filteredPools = this.dedupePools(pools);
|
|
111
|
+
if (typeof filter.minVolumeUSD === 'number') {
|
|
112
|
+
filteredPools = filteredPools.filter((pool) => {
|
|
113
|
+
const volumeUSD = parseFloat(pool.volumeUSD || pool.volumeUsd || '0');
|
|
114
|
+
return !Number.isNaN(volumeUSD) && volumeUSD >= filter.minVolumeUSD;
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
if (typeof filter.limit === 'number' && filter.limit >= 0) {
|
|
118
|
+
filteredPools = filteredPools.slice(0, filter.limit);
|
|
119
|
+
}
|
|
120
|
+
return filteredPools;
|
|
121
|
+
}
|
|
122
|
+
async searchPoolsBySymbols(filter, symbols) {
|
|
123
|
+
// Symbol relation filtering is not portable across all supported AMM subgraphs.
|
|
124
|
+
// Use bounded top-pools fetch plus local symbol filtering as the baseline path.
|
|
125
|
+
const boundedLimit = Math.min(Math.max(filter.limit ?? 200, 1), 500);
|
|
126
|
+
const topPools = await this.getTopPools(boundedLimit, filter.protocol, filter.chainId);
|
|
127
|
+
if (!topPools.success || !topPools.data) {
|
|
128
|
+
return topPools;
|
|
129
|
+
}
|
|
130
|
+
const symbolMatches = this.filterPoolsBySymbols(topPools.data, symbols);
|
|
131
|
+
return {
|
|
132
|
+
data: this.applyPoolSearchResultFilters(symbolMatches, filter),
|
|
133
|
+
status: 200,
|
|
134
|
+
success: true,
|
|
135
|
+
};
|
|
136
|
+
}
|
|
79
137
|
/**
|
|
80
138
|
* Fetches data from GraphQL endpoint with retry logic for rate limits
|
|
81
139
|
*
|
|
@@ -450,6 +508,85 @@ class PoolClient extends SubgraphClient_js_1.SubgraphClient {
|
|
|
450
508
|
return true;
|
|
451
509
|
});
|
|
452
510
|
}
|
|
511
|
+
/**
|
|
512
|
+
* Searches pools using exact-address lookups where supported and local symbol
|
|
513
|
+
* filtering as a portable fallback.
|
|
514
|
+
*
|
|
515
|
+
* Symbol-based matching is best-effort because not every downstream AMM
|
|
516
|
+
* subgraph exposes portable nested token-symbol filters.
|
|
517
|
+
*/
|
|
518
|
+
async searchPools(filter) {
|
|
519
|
+
const { chainId, protocol } = filter;
|
|
520
|
+
if (!chainId || !protocol) {
|
|
521
|
+
return {
|
|
522
|
+
data: null,
|
|
523
|
+
status: 400,
|
|
524
|
+
success: false,
|
|
525
|
+
error: 'searchPools requires both chainId and protocol',
|
|
526
|
+
};
|
|
527
|
+
}
|
|
528
|
+
const normalizedPoolAddress = this.normalizeAddress(filter.poolAddress);
|
|
529
|
+
const normalizedTokenAddress = this.normalizeAddress(filter.tokenAddress);
|
|
530
|
+
const normalizedTokenAddresses = (filter.tokenAddresses || [])
|
|
531
|
+
.map((address) => this.normalizeAddress(address))
|
|
532
|
+
.filter(Boolean);
|
|
533
|
+
const tokenSymbols = [
|
|
534
|
+
...(filter.tokenSymbol ? [filter.tokenSymbol] : []),
|
|
535
|
+
...(filter.tokenSymbols || []),
|
|
536
|
+
].filter(Boolean);
|
|
537
|
+
if (!normalizedPoolAddress &&
|
|
538
|
+
!normalizedTokenAddress &&
|
|
539
|
+
normalizedTokenAddresses.length === 0 &&
|
|
540
|
+
tokenSymbols.length === 0) {
|
|
541
|
+
return {
|
|
542
|
+
data: null,
|
|
543
|
+
status: 400,
|
|
544
|
+
success: false,
|
|
545
|
+
error: 'searchPools requires at least one of poolAddress, tokenAddress, tokenAddresses, tokenSymbol, or tokenSymbols',
|
|
546
|
+
};
|
|
547
|
+
}
|
|
548
|
+
const collectedPools = [];
|
|
549
|
+
if (normalizedPoolAddress) {
|
|
550
|
+
const exactPool = await this.getPoolById(normalizedPoolAddress, protocol, chainId);
|
|
551
|
+
if (!exactPool.success) {
|
|
552
|
+
return {
|
|
553
|
+
data: null,
|
|
554
|
+
status: exactPool.status,
|
|
555
|
+
success: false,
|
|
556
|
+
error: exactPool.error,
|
|
557
|
+
};
|
|
558
|
+
}
|
|
559
|
+
if (exactPool.data) {
|
|
560
|
+
collectedPools.push(exactPool.data);
|
|
561
|
+
}
|
|
562
|
+
}
|
|
563
|
+
if (normalizedTokenAddress) {
|
|
564
|
+
const tokenPools = await this.fetchPoolsForToken(normalizedTokenAddress, protocol, chainId);
|
|
565
|
+
if (!tokenPools.success) {
|
|
566
|
+
return tokenPools;
|
|
567
|
+
}
|
|
568
|
+
collectedPools.push(...(tokenPools.data || []));
|
|
569
|
+
}
|
|
570
|
+
if (normalizedTokenAddresses.length > 0) {
|
|
571
|
+
const batchPools = await this.fetchPoolsForTokensBatch(normalizedTokenAddresses, protocol, chainId);
|
|
572
|
+
if (!batchPools.success) {
|
|
573
|
+
return batchPools;
|
|
574
|
+
}
|
|
575
|
+
collectedPools.push(...(batchPools.data || []));
|
|
576
|
+
}
|
|
577
|
+
if (tokenSymbols.length > 0) {
|
|
578
|
+
const symbolPools = await this.searchPoolsBySymbols({ ...filter, chainId, protocol }, tokenSymbols);
|
|
579
|
+
if (!symbolPools.success) {
|
|
580
|
+
return symbolPools;
|
|
581
|
+
}
|
|
582
|
+
collectedPools.push(...(symbolPools.data || []));
|
|
583
|
+
}
|
|
584
|
+
return {
|
|
585
|
+
data: this.applyPoolSearchResultFilters(collectedPools, filter),
|
|
586
|
+
status: 200,
|
|
587
|
+
success: true,
|
|
588
|
+
};
|
|
589
|
+
}
|
|
453
590
|
}
|
|
454
591
|
exports.PoolClient = PoolClient;
|
|
455
592
|
//# sourceMappingURL=PoolClient.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PoolClient.js","sourceRoot":"","sources":["../../../src/base/PoolClient.ts"],"names":[],"mappings":"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","sourcesContent":["import type { PublicClient, WalletClient } from 'viem';\nimport { PoolData, SteerResponse } from '../types.js';\nimport { SubgraphClient } from './SubgraphClient.js';\nimport { \n Protocol, \n Chain\n} from '../const/chain.js';\nimport { \n chainIdToName, \n getProtocolSubgraphURL\n} from '../const/index.js';\nimport { isAlgebraProtocol } from '../const/protocol.js';\nimport { getTopPoolsQuery, getTokenPoolsQueryByAddress, getPoolDetailsQuery } from '../utils/PoolQueryAdapter.js';\n\n/**\n * GraphQL token data interface representing token information from subgraph responses\n * @interface GraphQLTokenData\n */\nexport interface GraphQLTokenData {\n /** Token symbol (e.g., \"ETH\", \"USDC\") */\n symbol: string;\n /** Token contract address */\n id: string;\n /** Number of decimal places for the token */\n decimals: string;\n /** Human-readable token name */\n name: string;\n}\n\n/**\n * GraphQL pool data interface representing pool information from subgraph responses\n * @interface GraphQLPoolData\n */\nexport interface GraphQLPoolData {\n /** Pool contract address */\n id: string;\n /** First token in the pool */\n token0: GraphQLTokenData;\n /** Second token in the pool */\n token1: GraphQLTokenData;\n /** 24-hour trading volume in USD */\n volumeUSD: string;\n /** Current tick of the pool */\n tick: string;\n /** Total liquidity in the pool */\n liquidity: string;\n /** Fee tier for the pool (optional) */\n feeTier?: string;\n /** 24-hour volume of token0 (optional) */\n volumeToken0?: string;\n /** 24-hour volume of token1 (optional) */\n volumeToken1?: string;\n /** Total value locked in ETH (optional) */\n totalValueLockedETH?: string;\n /** Alternative field name for volume USD (optional) */\n volumeUsd?: string;\n /** Alternative field name for TVL in ETH (optional) */\n totalValueLockedEth?: string;\n}\n\n/**\n * Filter criteria for querying pools\n * @interface PoolFilter\n */\nexport interface PoolFilter {\n /** Chain ID to filter pools by */\n chainId?: number;\n /** Protocol to filter pools by */\n protocol?: Protocol;\n /** Minimum volume in USD to filter pools */\n minVolumeUSD?: number;\n /** Token address to find pools containing this token */\n tokenAddress?: string;\n /** Maximum number of pools to return */\n limit?: number;\n}\n\n// GraphQL response interfaces (currently unused but kept for future use)\n// interface GraphQLResponse<T> {\n// data: T;\n// errors?: Array<{ message: string }>;\n// }\n\n/**\n * Response interface for top pools query\n * @interface TopPoolsResponse\n * @internal\n */\ninterface TopPoolsResponse {\n /** Standard pools array */\n pools: GraphQLPoolData[];\n /** Limit pools array (used by some protocols) */\n limitPools?: GraphQLPoolData[];\n /** CL pools array (used by some protocols) */\n clPools?: GraphQLPoolData[];\n}\n\n/**\n * Response interface for pool details query\n * @interface PoolDetailsResponse\n * @internal\n */\ninterface PoolDetailsResponse {\n /** Single pool data */\n pool: GraphQLPoolData;\n /** Single limit pool data (used by some protocols) */\n limitPool?: GraphQLPoolData;\n /** Single CL pool data (used by some protocols) */\n clPool?: GraphQLPoolData;\n}\n\n/**\n * Response interface for pools by token query\n * @interface PoolsByTokenResponse\n * @internal\n */\ninterface PoolsByTokenResponse {\n /** Standard pools array */\n pools?: GraphQLPoolData[];\n /** Limit pools array (used by some protocols) */\n limitPools?: GraphQLPoolData[];\n /** Token pools array (used by some protocols) */\n tokenPools?: GraphQLPoolData[];\n /** CL pools array (used by some protocols) */\n clPools?: GraphQLPoolData[];\n}\n\n/**\n * Client for fetching pool data from various DEX protocol subgraphs\n * \n * @example\n * ```typescript\n * import { createPublicClient, createWalletClient, http } from 'viem';\n * import { mainnet } from 'viem/chains';\n * import { PoolClient } from '@steerprotocol/sdk';\n * \n * const client = createPublicClient({\n * chain: mainnet,\n * transport: http()\n * }) as PublicClient & WalletClient;\n * \n * const poolClient = new PoolClient(client, 'your-subgraph-studio-key');\n * \n * // Fetch top pools\n * const topPools = await poolClient.getTopPools(100, Protocol.UniswapV3, 1);\n * ```\n * \n * @extends SubgraphClient\n * @group Pool\n */\nexport class PoolClient extends SubgraphClient {\n /** Public client for blockchain interactions */\n protected readonly publicClient: PublicClient;\n /** Default timeout for GraphQL queries in milliseconds */\n private readonly defaultTimeout: number = 60000;\n /** Counter for tracking API call metrics */\n private apiCallCount: number = 0;\n /** Subgraph Studio API key for rate limiting */\n private readonly subgraphStudioKey: string;\n\n /**\n * Creates a new PoolClient instance\n * \n * @param client - Combined public and wallet client for blockchain interactions\n * @param subgraphStudioKey - Optional Subgraph Studio API key for higher rate limits\n * \n * @example\n * ```typescript\n * const poolClient = new PoolClient(client, 'your-api-key');\n * ```\n */\n constructor(\n client: PublicClient & WalletClient,\n subgraphStudioKey: string = ''\n ) {\n super(client);\n this.publicClient = client;\n this.subgraphStudioKey = subgraphStudioKey;\n }\n\n /**\n * Resets the API call counter for metrics tracking\n * \n * @example\n * ```typescript\n * poolClient.resetMetrics();\n * ```\n */\n public resetMetrics(): void {\n this.apiCallCount = 0;\n }\n\n /**\n * Gets current metrics for monitoring API usage\n * \n * @returns Object containing current metrics\n * \n * @example\n * ```typescript\n * const metrics = poolClient.getMetrics();\n * console.log(`API calls made: ${metrics.apiCallCount}`);\n * ```\n */\n public getMetrics(): { apiCallCount: number } {\n return {\n apiCallCount: this.apiCallCount,\n };\n }\n\n /**\n * Fetches data from GraphQL endpoint with retry logic for rate limits\n * \n * @param query - GraphQL query string\n * @param variables - Variables for the GraphQL query\n * @param protocol - Protocol to query\n * @param chainId - Chain ID to query\n * @returns Promise containing the response data\n * \n * @throws {Error} When subgraph endpoint is not available\n * @throws {Error} When rate limit is exceeded after max retries\n * @throws {Error} When GraphQL query times out\n * \n * @internal\n */\n private async fetchFromGraph<T>(\n query: string,\n variables: Record<string, unknown>,\n protocol: Protocol,\n chainId: number\n ): Promise<SteerResponse<T>> {\n try {\n const chainName = chainIdToName(chainId);\n const endpoint = getProtocolSubgraphURL(protocol, chainName as Chain, this.subgraphStudioKey);\n\n if (!endpoint) {\n throw new Error(`No subgraph endpoint available for protocol ${protocol} on chain ${chainName}`);\n }\n\n const MAX_RETRIES = 3;\n const RETRY_DELAY_MS = 11000;\n\n const fetchWithRetry = async (retries = 0): Promise<T> => {\n const response = await fetch(endpoint, {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\",\n },\n body: JSON.stringify({ query, variables }),\n });\n\n const data = await response.json() as { data: T; error?: string; errors?: Array<{ message: string }> };\n\n if (data.error && typeof data.error === \"string\" && data.error.includes(\"surpassed your query allowance\")) {\n if (retries < MAX_RETRIES) {\n console.warn(`Rate limit hit for ${endpoint}, retrying in ${RETRY_DELAY_MS / 1000}s (attempt ${retries + 1})`);\n await new Promise(res => setTimeout(res, RETRY_DELAY_MS));\n return fetchWithRetry(retries + 1);\n } else {\n throw new Error(`Rate limit exceeded after ${MAX_RETRIES} retries: ${data.error}`);\n }\n }\n\n if (data.error) {\n throw new Error(`GraphQL endpoint error: ${data.error}`);\n }\n\n if (data.errors) {\n throw new Error(`GraphQL errors: ${JSON.stringify(data.errors)}`);\n }\n\n return data.data;\n };\n\n this.apiCallCount++;\n console.log(\"Total API calls:\", this.apiCallCount);\n\n const timeoutPromise = new Promise<never>((_, reject) => {\n setTimeout(\n () => reject(new Error(\"GraphQL query timeout\")),\n this.defaultTimeout\n );\n });\n\n const data = await Promise.race([fetchWithRetry(), timeoutPromise]);\n\n return {\n data: data as T,\n status: 200,\n success: true,\n };\n } catch (error) {\n return {\n data: null,\n status: 500,\n success: false,\n error: error instanceof Error ? error.message : 'Unknown error occurred',\n };\n }\n }\n\n /**\n * Fetches the top pools for a specific protocol by trading volume\n * \n * @param count - Number of pools to fetch (default: 500)\n * @param protocol - Protocol to fetch pools from\n * @param chainId - Chain ID to fetch pools from\n * @returns Promise containing an array of top pools\n * \n * @example\n * ```typescript\n * // Get top 100 Uniswap V3 pools on Ethereum\n * const topPools = await poolClient.getTopPools(100, Protocol.UniswapV3, 1);\n * if (topPools.success) {\n * console.log(`Found ${topPools.data.length} pools`);\n * }\n * ```\n * \n * @throws {Error} When failed to fetch pools from subgraph\n */\n public async getTopPools(\n count: number = 500,\n protocol: Protocol,\n chainId: number\n ): Promise<SteerResponse<GraphQLPoolData[]>> {\n try {\n const isAlgebraPool = isAlgebraProtocol(protocol);\n const query = getTopPoolsQuery(protocol, isAlgebraPool);\n\n console.log(`[Chain ${chainId}] [Protocol ${protocol}] 📊 Fetching top ${count} pools from the subgraph...`);\n\n const response = await this.fetchFromGraph<TopPoolsResponse>(\n query,\n { limit: count },\n protocol,\n chainId\n );\n\n if (!response.success || !response.data) {\n throw new Error(response.error || 'Failed to fetch pools');\n }\n\n const pools = response.data.pools || response.data.limitPools || response.data.clPools || [];\n \n console.log(`[Chain ${chainId}] [Protocol ${protocol}] ✅ Received ${pools.length} pools from the subgraph`);\n\n // Filter out pools with invalid volumeUSD\n const validPools = pools.filter(pool => {\n const volumeUSD = parseFloat(pool.volumeUSD || pool.volumeUsd || \"0\");\n return !isNaN(volumeUSD) && volumeUSD > 0;\n });\n\n console.log(`[Chain ${chainId}] [Protocol ${protocol}] ✅ Found ${validPools.length} valid pools with positive volumeUSD`);\n\n return {\n data: validPools,\n status: 200,\n success: true,\n };\n } catch (error) {\n console.error(`[Chain ${chainId}] [Protocol ${protocol}] Error in getTopPools:`, error);\n return {\n data: null,\n status: 500,\n success: false,\n error: error instanceof Error ? error.message : 'Unknown error occurred',\n };\n }\n }\n\n /**\n * Fetches detailed information for a specific pool by its ID\n * \n * @param poolId - Pool contract address to fetch\n * @param protocol - Protocol the pool belongs to\n * @param chainId - Chain ID where the pool exists\n * @returns Promise containing pool details or null if not found\n * \n * @example\n * ```typescript\n * // Get specific pool details\n * const poolDetails = await poolClient.getPoolById(\n * '0x88e6a0c2ddd26feeb64f039a2c41296fcb3f5640',\n * Protocol.UniswapV3,\n * 1\n * );\n * if (poolDetails.success && poolDetails.data) {\n * console.log(`Pool: ${poolDetails.data.token0.symbol}/${poolDetails.data.token1.symbol}`);\n * }\n * ```\n * \n * @throws {Error} When failed to fetch pool from subgraph\n */\n public async getPoolById(\n poolId: string,\n protocol: Protocol,\n chainId: number\n ): Promise<SteerResponse<GraphQLPoolData | null>> {\n try {\n\n const isAlgebraPool = isAlgebraProtocol(protocol);\n const query = getPoolDetailsQuery(isAlgebraPool, protocol);\n\n \n const response = await this.fetchFromGraph<PoolDetailsResponse>(\n query,\n { pool: poolId },\n protocol,\n chainId\n );\n\n if (!response.success || !response.data) {\n throw new Error(response.error || 'Failed to fetch pool');\n }\n\n const pool = response.data.pool || response.data.clPool || response.data.limitPool || null;\n\n\n return {\n data: pool,\n status: 200,\n success: true,\n };\n } catch (error) {\n console.error(`Error fetching pool ${poolId}:`, error);\n return {\n data: null,\n status: 500,\n success: false,\n error: error instanceof Error ? error.message : 'Unknown error occurred',\n };\n }\n }\n\n /**\n * Fetches pools containing multiple tokens in batches for better performance\n * \n * @param tokenAddresses - Array of token contract addresses\n * @param protocol - Protocol to fetch pools from\n * @param chainId - Chain ID to fetch pools from\n * @param batchSize - Number of tokens to process in each batch (default: 10)\n * @returns Promise containing all pools found for the tokens\n * \n * @example\n * ```typescript\n * // Get pools for multiple tokens\n * const tokenAddresses = [\n * '0xa0b86a33e6f8b07b71c3a39ef77a6b6e8f1b7b7e', // USDC\n * '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2' // WETH\n * ];\n * const pools = await poolClient.fetchPoolsForTokensBatch(\n * tokenAddresses,\n * Protocol.UniswapV3,\n * 1,\n * 5\n * );\n * ```\n * \n * @throws {Error} When batch processing fails\n */\n public async fetchPoolsForTokensBatch(\n tokenAddresses: string[],\n protocol: Protocol,\n chainId: number,\n batchSize: number = 10\n ): Promise<SteerResponse<GraphQLPoolData[]>> {\n try {\n if (tokenAddresses.length === 0) {\n return {\n data: [],\n status: 200,\n success: true,\n };\n }\n\n console.log(`\\n🔍 Batch Pool Fetch Summary:`);\n console.log(`📥 Total tokens to process: ${tokenAddresses.length}`);\n\n const isAlgebraPool = isAlgebraProtocol(protocol);\n const normalizedAddresses = tokenAddresses.map(addr => addr.toLowerCase());\n\n // Split into chunks\n const chunkSize = batchSize;\n const addressChunks = [];\n for (let i = 0; i < normalizedAddresses.length; i += chunkSize) {\n addressChunks.push(normalizedAddresses.slice(i, i + chunkSize));\n }\n\n console.log(`📦 Processing ${addressChunks.length} chunks of max ${chunkSize} tokens each`);\n\n const allPools: GraphQLPoolData[] = [];\n\n // Process chunks in parallel\n const results = await Promise.all(\n addressChunks.map(async (chunk, chunkIndex) => {\n console.log(`\\n🔄 Processing chunk ${chunkIndex + 1}/${addressChunks.length} with ${chunk.length} tokens`);\n\n const chunkResults = await Promise.all(\n chunk.map(async (token) => {\n try {\n const query = getTokenPoolsQueryByAddress(isAlgebraPool, protocol);\n const queryStartTime = performance.now();\n \n const response = await this.fetchFromGraph<PoolsByTokenResponse>(\n query,\n { token },\n protocol,\n chainId\n );\n\n const queryTime = performance.now() - queryStartTime;\n console.log(`⏱️ GraphQL query for token ${token.slice(0, 6)}... completed in ${queryTime.toFixed(2)}ms`);\n\n if (!response.success || !response.data) {\n console.error(`❌ No pools found for token: ${token} on chainId: ${chainId}`);\n return [];\n }\n\n // Extract pools from different possible response structures\n let pools: GraphQLPoolData[] = [];\n if (response.data.pools) {\n pools = response.data.pools;\n } else if (response.data.clPools) {\n pools = response.data.clPools;\n } else if (response.data.limitPools) {\n pools = response.data.limitPools;\n } else if (response.data.tokenPools) {\n pools = response.data.tokenPools;\n }\n\n if (pools.length === 0) {\n console.error(`❌ No pools found for token: ${token} on chainId: ${chainId}`);\n return [];\n }\n\n return pools;\n } catch (error) {\n console.error(`❌ Error fetching pools for token: ${token} on chainId: ${chainId}`, error);\n return [];\n }\n })\n );\n\n return chunkResults.flat();\n })\n );\n\n // Flatten all results\n allPools.push(...results.flat());\n\n return {\n data: allPools,\n status: 200,\n success: true,\n };\n } catch (error) {\n console.error(\"Error in fetchPoolsForTokensBatch:\", error);\n return {\n data: null,\n status: 500,\n success: false,\n error: error instanceof Error ? error.message : 'Unknown error occurred',\n };\n }\n }\n\n /**\n * Fetches all pools containing a specific token\n * \n * @param tokenAddress - Token contract address\n * @param protocol - Protocol to fetch pools from\n * @param chainId - Chain ID to fetch pools from\n * @returns Promise containing pools that include the specified token\n * \n * @example\n * ```typescript\n * // Get all USDC pools on Uniswap V3\n * const usdcPools = await poolClient.fetchPoolsForToken(\n * '0xa0b86a33e6f8b07b71c3a39ef77a6b6e8f1b7b7e',\n * Protocol.UniswapV3,\n * 1\n * );\n * if (usdcPools.success) {\n * console.log(`Found ${usdcPools.data.length} USDC pools`);\n * }\n * ```\n * \n * @throws {Error} When failed to fetch pools for token\n */\n public async fetchPoolsForToken(\n tokenAddress: string,\n protocol: Protocol,\n chainId: number\n ): Promise<SteerResponse<GraphQLPoolData[]>> {\n try {\n const isAlgebraPool = isAlgebraProtocol(protocol);\n const query = getTokenPoolsQueryByAddress(isAlgebraPool, protocol);\n\n const response = await this.fetchFromGraph<PoolsByTokenResponse>(\n query,\n { token: tokenAddress.toLowerCase() },\n protocol,\n chainId\n );\n\n if (!response.success || !response.data) {\n throw new Error(response.error || 'Failed to fetch pools for token');\n }\n\n // Extract pools from different possible response structures\n let pools: GraphQLPoolData[] = [];\n if (response.data.pools) {\n pools = response.data.pools;\n } else if (response.data.limitPools) {\n pools = response.data.limitPools;\n } else if (response.data.tokenPools) {\n pools = response.data.tokenPools;\n } else if (response.data.clPools) {\n pools = response.data.clPools;\n }\n\n return {\n data: pools,\n status: 200,\n success: true,\n };\n } catch (error) {\n console.error(`Error fetching pools for token ${tokenAddress}:`, error);\n return {\n data: null,\n status: 500,\n success: false,\n error: error instanceof Error ? error.message : 'Unknown error occurred',\n };\n }\n }\n\n /**\n * Filters pools based on validity criteria such as tick range and liquidity\n * \n * @param pools - Array of pools to filter\n * @returns Array of valid pools that meet the criteria\n * \n * @example\n * ```typescript\n * const validPools = poolClient.filterValidPools(allPools);\n * console.log(`Filtered down to ${validPools.length} valid pools`);\n * ```\n */\n public filterValidPools(pools: PoolData[]): PoolData[] {\n return pools.filter(pool => {\n // Check for required fields\n if (!pool.id || !pool.tick || !pool.liquidity) {\n return false;\n }\n\n // Parse values\n const tick = parseInt(pool.tick);\n const liquidity = parseFloat(pool.liquidity);\n\n // Check for valid tick range and liquidity\n const TICK_MIN = -887272;\n const TICK_MAX = 887272;\n const TICK_EDGE_THRESHOLD = 1;\n\n if (\n isNaN(tick) ||\n isNaN(liquidity) ||\n liquidity <= 0 ||\n tick <= TICK_MIN + TICK_EDGE_THRESHOLD ||\n tick >= TICK_MAX - TICK_EDGE_THRESHOLD\n ) {\n return false;\n }\n\n return true;\n });\n }\n} "]}
|
|
1
|
+
{"version":3,"file":"PoolClient.js","sourceRoot":"","sources":["../../../src/base/PoolClient.ts"],"names":[],"mappings":"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","sourcesContent":["import type { PublicClient, WalletClient } from 'viem';\nimport { PoolData, SteerResponse } from '../types.js';\nimport { SubgraphClient } from './SubgraphClient.js';\nimport { \n Protocol, \n Chain\n} from '../const/chain.js';\nimport { \n chainIdToName, \n getProtocolSubgraphURL\n} from '../const/index.js';\nimport { isAlgebraProtocol } from '../const/protocol.js';\nimport { getTopPoolsQuery, getTokenPoolsQueryByAddress, getPoolDetailsQuery } from '../utils/PoolQueryAdapter.js';\n\n/**\n * GraphQL token data interface representing token information from subgraph responses\n * @interface GraphQLTokenData\n */\nexport interface GraphQLTokenData {\n /** Token symbol (e.g., \"ETH\", \"USDC\") */\n symbol: string;\n /** Token contract address */\n id: string;\n /** Number of decimal places for the token */\n decimals: string;\n /** Human-readable token name */\n name: string;\n}\n\n/**\n * GraphQL pool data interface representing pool information from subgraph responses\n * @interface GraphQLPoolData\n */\nexport interface GraphQLPoolData {\n /** Pool contract address */\n id: string;\n /** First token in the pool */\n token0: GraphQLTokenData;\n /** Second token in the pool */\n token1: GraphQLTokenData;\n /** 24-hour trading volume in USD */\n volumeUSD: string;\n /** Current tick of the pool */\n tick: string;\n /** Total liquidity in the pool */\n liquidity: string;\n /** Fee tier for the pool (optional) */\n feeTier?: string;\n /** 24-hour volume of token0 (optional) */\n volumeToken0?: string;\n /** 24-hour volume of token1 (optional) */\n volumeToken1?: string;\n /** Total value locked in ETH (optional) */\n totalValueLockedETH?: string;\n /** Alternative field name for volume USD (optional) */\n volumeUsd?: string;\n /** Alternative field name for TVL in ETH (optional) */\n totalValueLockedEth?: string;\n}\n\n/**\n * Filter criteria for querying pools\n * @interface PoolFilter\n */\nexport interface PoolFilter {\n /** Chain ID to filter pools by */\n chainId?: number;\n /** Protocol to filter pools by */\n protocol?: Protocol;\n /** Exact pool address/id to look up */\n poolAddress?: string;\n /** Minimum volume in USD to filter pools */\n minVolumeUSD?: number;\n /** Token address to find pools containing this token */\n tokenAddress?: string;\n /** Multiple token addresses to find pools for */\n tokenAddresses?: string[];\n /** Token symbol to find pools containing this token */\n tokenSymbol?: string;\n /** Multiple token symbols to find pools for */\n tokenSymbols?: string[];\n /** Maximum number of pools to return */\n limit?: number;\n}\n\n// GraphQL response interfaces (currently unused but kept for future use)\n// interface GraphQLResponse<T> {\n// data: T;\n// errors?: Array<{ message: string }>;\n// }\n\n/**\n * Response interface for top pools query\n * @interface TopPoolsResponse\n * @internal\n */\ninterface TopPoolsResponse {\n /** Standard pools array */\n pools: GraphQLPoolData[];\n /** Limit pools array (used by some protocols) */\n limitPools?: GraphQLPoolData[];\n /** CL pools array (used by some protocols) */\n clPools?: GraphQLPoolData[];\n}\n\n/**\n * Response interface for pool details query\n * @interface PoolDetailsResponse\n * @internal\n */\ninterface PoolDetailsResponse {\n /** Single pool data */\n pool: GraphQLPoolData;\n /** Single limit pool data (used by some protocols) */\n limitPool?: GraphQLPoolData;\n /** Single CL pool data (used by some protocols) */\n clPool?: GraphQLPoolData;\n}\n\n/**\n * Response interface for pools by token query\n * @interface PoolsByTokenResponse\n * @internal\n */\ninterface PoolsByTokenResponse {\n /** Standard pools array */\n pools?: GraphQLPoolData[];\n /** Limit pools array (used by some protocols) */\n limitPools?: GraphQLPoolData[];\n /** Token pools array (used by some protocols) */\n tokenPools?: GraphQLPoolData[];\n /** CL pools array (used by some protocols) */\n clPools?: GraphQLPoolData[];\n}\n\n/**\n * Client for fetching pool data from various DEX protocol subgraphs\n * \n * @example\n * ```typescript\n * import { createPublicClient, createWalletClient, http } from 'viem';\n * import { mainnet } from 'viem/chains';\n * import { PoolClient } from '@steerprotocol/sdk';\n * \n * const client = createPublicClient({\n * chain: mainnet,\n * transport: http()\n * }) as PublicClient & WalletClient;\n * \n * const poolClient = new PoolClient(client, 'your-subgraph-studio-key');\n * \n * // Fetch top pools\n * const topPools = await poolClient.getTopPools(100, Protocol.UniswapV3, 1);\n * ```\n * \n * @extends SubgraphClient\n * @group Pool\n */\nexport class PoolClient extends SubgraphClient {\n /** Public client for blockchain interactions */\n protected readonly publicClient: PublicClient;\n /** Default timeout for GraphQL queries in milliseconds */\n private readonly defaultTimeout: number = 60000;\n /** Counter for tracking API call metrics */\n private apiCallCount: number = 0;\n /** Subgraph Studio API key for rate limiting */\n private readonly subgraphStudioKey: string;\n\n /**\n * Creates a new PoolClient instance\n * \n * @param client - Combined public and wallet client for blockchain interactions\n * @param subgraphStudioKey - Optional Subgraph Studio API key for higher rate limits\n * \n * @example\n * ```typescript\n * const poolClient = new PoolClient(client, 'your-api-key');\n * ```\n */\n constructor(\n client: PublicClient & WalletClient,\n subgraphStudioKey: string = ''\n ) {\n super(client);\n this.publicClient = client;\n this.subgraphStudioKey = subgraphStudioKey;\n }\n\n /**\n * Resets the API call counter for metrics tracking\n * \n * @example\n * ```typescript\n * poolClient.resetMetrics();\n * ```\n */\n public resetMetrics(): void {\n this.apiCallCount = 0;\n }\n\n /**\n * Gets current metrics for monitoring API usage\n * \n * @returns Object containing current metrics\n * \n * @example\n * ```typescript\n * const metrics = poolClient.getMetrics();\n * console.log(`API calls made: ${metrics.apiCallCount}`);\n * ```\n */\n public getMetrics(): { apiCallCount: number } {\n return {\n apiCallCount: this.apiCallCount,\n };\n }\n\n private normalizeAddress(value?: string): string {\n return value?.toLowerCase() || '';\n }\n\n private normalizeSymbol(value?: string): string {\n return value?.trim().toLowerCase() || '';\n }\n\n private dedupePools(pools: GraphQLPoolData[]): GraphQLPoolData[] {\n const seen = new Set<string>();\n const deduped: GraphQLPoolData[] = [];\n\n pools.forEach((pool) => {\n const key = this.normalizeAddress(pool.id);\n if (!key || seen.has(key)) {\n return;\n }\n\n seen.add(key);\n deduped.push(pool);\n });\n\n return deduped;\n }\n\n private filterPoolsBySymbols(\n pools: GraphQLPoolData[],\n symbols: string[],\n ): GraphQLPoolData[] {\n if (symbols.length === 0) {\n return pools;\n }\n\n const normalizedSymbols = new Set(\n symbols.map((symbol) => this.normalizeSymbol(symbol)).filter(Boolean),\n );\n\n return pools.filter((pool) => {\n const token0Symbol = this.normalizeSymbol(pool.token0?.symbol);\n const token1Symbol = this.normalizeSymbol(pool.token1?.symbol);\n\n return normalizedSymbols.has(token0Symbol) || normalizedSymbols.has(token1Symbol);\n });\n }\n\n private applyPoolSearchResultFilters(\n pools: GraphQLPoolData[],\n filter: PoolFilter,\n ): GraphQLPoolData[] {\n let filteredPools = this.dedupePools(pools);\n\n if (typeof filter.minVolumeUSD === 'number') {\n filteredPools = filteredPools.filter((pool) => {\n const volumeUSD = parseFloat(pool.volumeUSD || pool.volumeUsd || '0');\n return !Number.isNaN(volumeUSD) && volumeUSD >= filter.minVolumeUSD!;\n });\n }\n\n if (typeof filter.limit === 'number' && filter.limit >= 0) {\n filteredPools = filteredPools.slice(0, filter.limit);\n }\n\n return filteredPools;\n }\n\n private async searchPoolsBySymbols(\n filter: Required<Pick<PoolFilter, 'chainId' | 'protocol'>> & PoolFilter,\n symbols: string[],\n ): Promise<SteerResponse<GraphQLPoolData[]>> {\n // Symbol relation filtering is not portable across all supported AMM subgraphs.\n // Use bounded top-pools fetch plus local symbol filtering as the baseline path.\n const boundedLimit = Math.min(Math.max(filter.limit ?? 200, 1), 500);\n const topPools = await this.getTopPools(boundedLimit, filter.protocol, filter.chainId);\n\n if (!topPools.success || !topPools.data) {\n return topPools;\n }\n\n const symbolMatches = this.filterPoolsBySymbols(topPools.data, symbols);\n\n return {\n data: this.applyPoolSearchResultFilters(symbolMatches, filter),\n status: 200,\n success: true,\n };\n }\n\n /**\n * Fetches data from GraphQL endpoint with retry logic for rate limits\n * \n * @param query - GraphQL query string\n * @param variables - Variables for the GraphQL query\n * @param protocol - Protocol to query\n * @param chainId - Chain ID to query\n * @returns Promise containing the response data\n * \n * @throws {Error} When subgraph endpoint is not available\n * @throws {Error} When rate limit is exceeded after max retries\n * @throws {Error} When GraphQL query times out\n * \n * @internal\n */\n private async fetchFromGraph<T>(\n query: string,\n variables: Record<string, unknown>,\n protocol: Protocol,\n chainId: number\n ): Promise<SteerResponse<T>> {\n try {\n const chainName = chainIdToName(chainId);\n const endpoint = getProtocolSubgraphURL(protocol, chainName as Chain, this.subgraphStudioKey);\n\n if (!endpoint) {\n throw new Error(`No subgraph endpoint available for protocol ${protocol} on chain ${chainName}`);\n }\n\n const MAX_RETRIES = 3;\n const RETRY_DELAY_MS = 11000;\n\n const fetchWithRetry = async (retries = 0): Promise<T> => {\n const response = await fetch(endpoint, {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\",\n },\n body: JSON.stringify({ query, variables }),\n });\n\n const data = await response.json() as { data: T; error?: string; errors?: Array<{ message: string }> };\n\n if (data.error && typeof data.error === \"string\" && data.error.includes(\"surpassed your query allowance\")) {\n if (retries < MAX_RETRIES) {\n console.warn(`Rate limit hit for ${endpoint}, retrying in ${RETRY_DELAY_MS / 1000}s (attempt ${retries + 1})`);\n await new Promise(res => setTimeout(res, RETRY_DELAY_MS));\n return fetchWithRetry(retries + 1);\n } else {\n throw new Error(`Rate limit exceeded after ${MAX_RETRIES} retries: ${data.error}`);\n }\n }\n\n if (data.error) {\n throw new Error(`GraphQL endpoint error: ${data.error}`);\n }\n\n if (data.errors) {\n throw new Error(`GraphQL errors: ${JSON.stringify(data.errors)}`);\n }\n\n return data.data;\n };\n\n this.apiCallCount++;\n console.log(\"Total API calls:\", this.apiCallCount);\n\n const timeoutPromise = new Promise<never>((_, reject) => {\n setTimeout(\n () => reject(new Error(\"GraphQL query timeout\")),\n this.defaultTimeout\n );\n });\n\n const data = await Promise.race([fetchWithRetry(), timeoutPromise]);\n\n return {\n data: data as T,\n status: 200,\n success: true,\n };\n } catch (error) {\n return {\n data: null,\n status: 500,\n success: false,\n error: error instanceof Error ? error.message : 'Unknown error occurred',\n };\n }\n }\n\n /**\n * Fetches the top pools for a specific protocol by trading volume\n * \n * @param count - Number of pools to fetch (default: 500)\n * @param protocol - Protocol to fetch pools from\n * @param chainId - Chain ID to fetch pools from\n * @returns Promise containing an array of top pools\n * \n * @example\n * ```typescript\n * // Get top 100 Uniswap V3 pools on Ethereum\n * const topPools = await poolClient.getTopPools(100, Protocol.UniswapV3, 1);\n * if (topPools.success) {\n * console.log(`Found ${topPools.data.length} pools`);\n * }\n * ```\n * \n * @throws {Error} When failed to fetch pools from subgraph\n */\n public async getTopPools(\n count: number = 500,\n protocol: Protocol,\n chainId: number\n ): Promise<SteerResponse<GraphQLPoolData[]>> {\n try {\n const isAlgebraPool = isAlgebraProtocol(protocol);\n const query = getTopPoolsQuery(protocol, isAlgebraPool);\n\n console.log(`[Chain ${chainId}] [Protocol ${protocol}] 📊 Fetching top ${count} pools from the subgraph...`);\n\n const response = await this.fetchFromGraph<TopPoolsResponse>(\n query,\n { limit: count },\n protocol,\n chainId\n );\n\n if (!response.success || !response.data) {\n throw new Error(response.error || 'Failed to fetch pools');\n }\n\n const pools = response.data.pools || response.data.limitPools || response.data.clPools || [];\n \n console.log(`[Chain ${chainId}] [Protocol ${protocol}] ✅ Received ${pools.length} pools from the subgraph`);\n\n // Filter out pools with invalid volumeUSD\n const validPools = pools.filter(pool => {\n const volumeUSD = parseFloat(pool.volumeUSD || pool.volumeUsd || \"0\");\n return !isNaN(volumeUSD) && volumeUSD > 0;\n });\n\n console.log(`[Chain ${chainId}] [Protocol ${protocol}] ✅ Found ${validPools.length} valid pools with positive volumeUSD`);\n\n return {\n data: validPools,\n status: 200,\n success: true,\n };\n } catch (error) {\n console.error(`[Chain ${chainId}] [Protocol ${protocol}] Error in getTopPools:`, error);\n return {\n data: null,\n status: 500,\n success: false,\n error: error instanceof Error ? error.message : 'Unknown error occurred',\n };\n }\n }\n\n /**\n * Fetches detailed information for a specific pool by its ID\n * \n * @param poolId - Pool contract address to fetch\n * @param protocol - Protocol the pool belongs to\n * @param chainId - Chain ID where the pool exists\n * @returns Promise containing pool details or null if not found\n * \n * @example\n * ```typescript\n * // Get specific pool details\n * const poolDetails = await poolClient.getPoolById(\n * '0x88e6a0c2ddd26feeb64f039a2c41296fcb3f5640',\n * Protocol.UniswapV3,\n * 1\n * );\n * if (poolDetails.success && poolDetails.data) {\n * console.log(`Pool: ${poolDetails.data.token0.symbol}/${poolDetails.data.token1.symbol}`);\n * }\n * ```\n * \n * @throws {Error} When failed to fetch pool from subgraph\n */\n public async getPoolById(\n poolId: string,\n protocol: Protocol,\n chainId: number\n ): Promise<SteerResponse<GraphQLPoolData | null>> {\n try {\n\n const isAlgebraPool = isAlgebraProtocol(protocol);\n const query = getPoolDetailsQuery(isAlgebraPool, protocol);\n\n \n const response = await this.fetchFromGraph<PoolDetailsResponse>(\n query,\n { pool: poolId },\n protocol,\n chainId\n );\n\n if (!response.success || !response.data) {\n throw new Error(response.error || 'Failed to fetch pool');\n }\n\n const pool = response.data.pool || response.data.clPool || response.data.limitPool || null;\n\n\n return {\n data: pool,\n status: 200,\n success: true,\n };\n } catch (error) {\n console.error(`Error fetching pool ${poolId}:`, error);\n return {\n data: null,\n status: 500,\n success: false,\n error: error instanceof Error ? error.message : 'Unknown error occurred',\n };\n }\n }\n\n /**\n * Fetches pools containing multiple tokens in batches for better performance\n * \n * @param tokenAddresses - Array of token contract addresses\n * @param protocol - Protocol to fetch pools from\n * @param chainId - Chain ID to fetch pools from\n * @param batchSize - Number of tokens to process in each batch (default: 10)\n * @returns Promise containing all pools found for the tokens\n * \n * @example\n * ```typescript\n * // Get pools for multiple tokens\n * const tokenAddresses = [\n * '0xa0b86a33e6f8b07b71c3a39ef77a6b6e8f1b7b7e', // USDC\n * '0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2' // WETH\n * ];\n * const pools = await poolClient.fetchPoolsForTokensBatch(\n * tokenAddresses,\n * Protocol.UniswapV3,\n * 1,\n * 5\n * );\n * ```\n * \n * @throws {Error} When batch processing fails\n */\n public async fetchPoolsForTokensBatch(\n tokenAddresses: string[],\n protocol: Protocol,\n chainId: number,\n batchSize: number = 10\n ): Promise<SteerResponse<GraphQLPoolData[]>> {\n try {\n if (tokenAddresses.length === 0) {\n return {\n data: [],\n status: 200,\n success: true,\n };\n }\n\n console.log(`\\n🔍 Batch Pool Fetch Summary:`);\n console.log(`📥 Total tokens to process: ${tokenAddresses.length}`);\n\n const isAlgebraPool = isAlgebraProtocol(protocol);\n const normalizedAddresses = tokenAddresses.map(addr => addr.toLowerCase());\n\n // Split into chunks\n const chunkSize = batchSize;\n const addressChunks = [];\n for (let i = 0; i < normalizedAddresses.length; i += chunkSize) {\n addressChunks.push(normalizedAddresses.slice(i, i + chunkSize));\n }\n\n console.log(`📦 Processing ${addressChunks.length} chunks of max ${chunkSize} tokens each`);\n\n const allPools: GraphQLPoolData[] = [];\n\n // Process chunks in parallel\n const results = await Promise.all(\n addressChunks.map(async (chunk, chunkIndex) => {\n console.log(`\\n🔄 Processing chunk ${chunkIndex + 1}/${addressChunks.length} with ${chunk.length} tokens`);\n\n const chunkResults = await Promise.all(\n chunk.map(async (token) => {\n try {\n const query = getTokenPoolsQueryByAddress(isAlgebraPool, protocol);\n const queryStartTime = performance.now();\n \n const response = await this.fetchFromGraph<PoolsByTokenResponse>(\n query,\n { token },\n protocol,\n chainId\n );\n\n const queryTime = performance.now() - queryStartTime;\n console.log(`⏱️ GraphQL query for token ${token.slice(0, 6)}... completed in ${queryTime.toFixed(2)}ms`);\n\n if (!response.success || !response.data) {\n console.error(`❌ No pools found for token: ${token} on chainId: ${chainId}`);\n return [];\n }\n\n // Extract pools from different possible response structures\n let pools: GraphQLPoolData[] = [];\n if (response.data.pools) {\n pools = response.data.pools;\n } else if (response.data.clPools) {\n pools = response.data.clPools;\n } else if (response.data.limitPools) {\n pools = response.data.limitPools;\n } else if (response.data.tokenPools) {\n pools = response.data.tokenPools;\n }\n\n if (pools.length === 0) {\n console.error(`❌ No pools found for token: ${token} on chainId: ${chainId}`);\n return [];\n }\n\n return pools;\n } catch (error) {\n console.error(`❌ Error fetching pools for token: ${token} on chainId: ${chainId}`, error);\n return [];\n }\n })\n );\n\n return chunkResults.flat();\n })\n );\n\n // Flatten all results\n allPools.push(...results.flat());\n\n return {\n data: allPools,\n status: 200,\n success: true,\n };\n } catch (error) {\n console.error(\"Error in fetchPoolsForTokensBatch:\", error);\n return {\n data: null,\n status: 500,\n success: false,\n error: error instanceof Error ? error.message : 'Unknown error occurred',\n };\n }\n }\n\n /**\n * Fetches all pools containing a specific token\n * \n * @param tokenAddress - Token contract address\n * @param protocol - Protocol to fetch pools from\n * @param chainId - Chain ID to fetch pools from\n * @returns Promise containing pools that include the specified token\n * \n * @example\n * ```typescript\n * // Get all USDC pools on Uniswap V3\n * const usdcPools = await poolClient.fetchPoolsForToken(\n * '0xa0b86a33e6f8b07b71c3a39ef77a6b6e8f1b7b7e',\n * Protocol.UniswapV3,\n * 1\n * );\n * if (usdcPools.success) {\n * console.log(`Found ${usdcPools.data.length} USDC pools`);\n * }\n * ```\n * \n * @throws {Error} When failed to fetch pools for token\n */\n public async fetchPoolsForToken(\n tokenAddress: string,\n protocol: Protocol,\n chainId: number\n ): Promise<SteerResponse<GraphQLPoolData[]>> {\n try {\n const isAlgebraPool = isAlgebraProtocol(protocol);\n const query = getTokenPoolsQueryByAddress(isAlgebraPool, protocol);\n\n const response = await this.fetchFromGraph<PoolsByTokenResponse>(\n query,\n { token: tokenAddress.toLowerCase() },\n protocol,\n chainId\n );\n\n if (!response.success || !response.data) {\n throw new Error(response.error || 'Failed to fetch pools for token');\n }\n\n // Extract pools from different possible response structures\n let pools: GraphQLPoolData[] = [];\n if (response.data.pools) {\n pools = response.data.pools;\n } else if (response.data.limitPools) {\n pools = response.data.limitPools;\n } else if (response.data.tokenPools) {\n pools = response.data.tokenPools;\n } else if (response.data.clPools) {\n pools = response.data.clPools;\n }\n\n return {\n data: pools,\n status: 200,\n success: true,\n };\n } catch (error) {\n console.error(`Error fetching pools for token ${tokenAddress}:`, error);\n return {\n data: null,\n status: 500,\n success: false,\n error: error instanceof Error ? error.message : 'Unknown error occurred',\n };\n }\n }\n\n /**\n * Filters pools based on validity criteria such as tick range and liquidity\n * \n * @param pools - Array of pools to filter\n * @returns Array of valid pools that meet the criteria\n * \n * @example\n * ```typescript\n * const validPools = poolClient.filterValidPools(allPools);\n * console.log(`Filtered down to ${validPools.length} valid pools`);\n * ```\n */\n public filterValidPools(pools: PoolData[]): PoolData[] {\n return pools.filter(pool => {\n // Check for required fields\n if (!pool.id || !pool.tick || !pool.liquidity) {\n return false;\n }\n\n // Parse values\n const tick = parseInt(pool.tick);\n const liquidity = parseFloat(pool.liquidity);\n\n // Check for valid tick range and liquidity\n const TICK_MIN = -887272;\n const TICK_MAX = 887272;\n const TICK_EDGE_THRESHOLD = 1;\n\n if (\n isNaN(tick) ||\n isNaN(liquidity) ||\n liquidity <= 0 ||\n tick <= TICK_MIN + TICK_EDGE_THRESHOLD ||\n tick >= TICK_MAX - TICK_EDGE_THRESHOLD\n ) {\n return false;\n }\n\n return true;\n });\n }\n\n /**\n * Searches pools using exact-address lookups where supported and local symbol\n * filtering as a portable fallback.\n *\n * Symbol-based matching is best-effort because not every downstream AMM\n * subgraph exposes portable nested token-symbol filters.\n */\n public async searchPools(\n filter: PoolFilter,\n ): Promise<SteerResponse<GraphQLPoolData[]>> {\n const { chainId, protocol } = filter;\n\n if (!chainId || !protocol) {\n return {\n data: null,\n status: 400,\n success: false,\n error: 'searchPools requires both chainId and protocol',\n };\n }\n\n const normalizedPoolAddress = this.normalizeAddress(filter.poolAddress);\n const normalizedTokenAddress = this.normalizeAddress(filter.tokenAddress);\n const normalizedTokenAddresses = (filter.tokenAddresses || [])\n .map((address) => this.normalizeAddress(address))\n .filter(Boolean);\n const tokenSymbols = [\n ...(filter.tokenSymbol ? [filter.tokenSymbol] : []),\n ...(filter.tokenSymbols || []),\n ].filter(Boolean);\n\n if (\n !normalizedPoolAddress &&\n !normalizedTokenAddress &&\n normalizedTokenAddresses.length === 0 &&\n tokenSymbols.length === 0\n ) {\n return {\n data: null,\n status: 400,\n success: false,\n error: 'searchPools requires at least one of poolAddress, tokenAddress, tokenAddresses, tokenSymbol, or tokenSymbols',\n };\n }\n\n const collectedPools: GraphQLPoolData[] = [];\n\n if (normalizedPoolAddress) {\n const exactPool = await this.getPoolById(normalizedPoolAddress, protocol, chainId);\n if (!exactPool.success) {\n return {\n data: null,\n status: exactPool.status,\n success: false,\n error: exactPool.error,\n };\n }\n\n if (exactPool.data) {\n collectedPools.push(exactPool.data);\n }\n }\n\n if (normalizedTokenAddress) {\n const tokenPools = await this.fetchPoolsForToken(normalizedTokenAddress, protocol, chainId);\n if (!tokenPools.success) {\n return tokenPools;\n }\n\n collectedPools.push(...(tokenPools.data || []));\n }\n\n if (normalizedTokenAddresses.length > 0) {\n const batchPools = await this.fetchPoolsForTokensBatch(\n normalizedTokenAddresses,\n protocol,\n chainId,\n );\n if (!batchPools.success) {\n return batchPools;\n }\n\n collectedPools.push(...(batchPools.data || []));\n }\n\n if (tokenSymbols.length > 0) {\n const symbolPools = await this.searchPoolsBySymbols(\n { ...filter, chainId, protocol },\n tokenSymbols,\n );\n if (!symbolPools.success) {\n return symbolPools;\n }\n\n collectedPools.push(...(symbolPools.data || []));\n }\n\n return {\n data: this.applyPoolSearchResultFilters(collectedPools, filter),\n status: 200,\n success: true,\n };\n }\n}\n"]}
|
|
@@ -208,8 +208,15 @@ class VaultClient extends SubgraphClient_js_1.SubgraphClient {
|
|
|
208
208
|
if (!filter) {
|
|
209
209
|
return undefined;
|
|
210
210
|
}
|
|
211
|
-
const { protocol,
|
|
212
|
-
const apiFilter = {
|
|
211
|
+
const { protocol, poolAddress, chainId, isActive, beaconName } = filter;
|
|
212
|
+
const apiFilter = {
|
|
213
|
+
chainId,
|
|
214
|
+
isActive,
|
|
215
|
+
beaconName,
|
|
216
|
+
};
|
|
217
|
+
if (poolAddress) {
|
|
218
|
+
apiFilter.pool = poolAddress;
|
|
219
|
+
}
|
|
213
220
|
if (!apiFilter.beaconName && protocol) {
|
|
214
221
|
const primaryBeaconName = this.getPrimaryProtocolBeaconName(protocol);
|
|
215
222
|
if (primaryBeaconName) {
|
|
@@ -249,6 +256,58 @@ class VaultClient extends SubgraphClient_js_1.SubgraphClient {
|
|
|
249
256
|
edges: filteredEdges
|
|
250
257
|
};
|
|
251
258
|
}
|
|
259
|
+
normalizeAddress(value) {
|
|
260
|
+
return value?.toLowerCase() || '';
|
|
261
|
+
}
|
|
262
|
+
normalizeSymbol(value) {
|
|
263
|
+
return value?.trim().toLowerCase() || '';
|
|
264
|
+
}
|
|
265
|
+
matchesAnyAddress(candidates, filterValues) {
|
|
266
|
+
if (filterValues.length === 0) {
|
|
267
|
+
return true;
|
|
268
|
+
}
|
|
269
|
+
const normalizedCandidates = new Set(candidates.map((candidate) => this.normalizeAddress(candidate)).filter(Boolean));
|
|
270
|
+
return filterValues.some((value) => normalizedCandidates.has(value));
|
|
271
|
+
}
|
|
272
|
+
matchesAnySymbol(candidates, filterValues) {
|
|
273
|
+
if (filterValues.length === 0) {
|
|
274
|
+
return true;
|
|
275
|
+
}
|
|
276
|
+
const normalizedCandidates = new Set(candidates.map((candidate) => this.normalizeSymbol(candidate)).filter(Boolean));
|
|
277
|
+
return filterValues.some((value) => normalizedCandidates.has(value));
|
|
278
|
+
}
|
|
279
|
+
filterVaultNodes(vaults, filter) {
|
|
280
|
+
const vaultAddress = this.normalizeAddress(filter.vaultAddress);
|
|
281
|
+
const poolAddress = this.normalizeAddress(filter.poolAddress);
|
|
282
|
+
const tokenAddressFilters = [
|
|
283
|
+
...(filter.tokenAddress ? [filter.tokenAddress] : []),
|
|
284
|
+
...(filter.tokenAddresses || []),
|
|
285
|
+
]
|
|
286
|
+
.map((address) => this.normalizeAddress(address))
|
|
287
|
+
.filter(Boolean);
|
|
288
|
+
const tokenSymbolFilters = [
|
|
289
|
+
...(filter.tokenSymbol ? [filter.tokenSymbol] : []),
|
|
290
|
+
...(filter.tokenSymbols || []),
|
|
291
|
+
]
|
|
292
|
+
.map((symbol) => this.normalizeSymbol(symbol))
|
|
293
|
+
.filter(Boolean);
|
|
294
|
+
return vaults.filter((vault) => {
|
|
295
|
+
if (vaultAddress && this.normalizeAddress(vault.vaultAddress) !== vaultAddress) {
|
|
296
|
+
return false;
|
|
297
|
+
}
|
|
298
|
+
if (poolAddress &&
|
|
299
|
+
!this.matchesAnyAddress([vault.pool.poolAddress, vault.pool.id], [poolAddress])) {
|
|
300
|
+
return false;
|
|
301
|
+
}
|
|
302
|
+
if (!this.matchesAnyAddress([vault.token0.address, vault.token0.id, vault.token1.address, vault.token1.id], tokenAddressFilters)) {
|
|
303
|
+
return false;
|
|
304
|
+
}
|
|
305
|
+
if (!this.matchesAnySymbol([vault.token0.symbol, vault.token1.symbol], tokenSymbolFilters)) {
|
|
306
|
+
return false;
|
|
307
|
+
}
|
|
308
|
+
return true;
|
|
309
|
+
});
|
|
310
|
+
}
|
|
252
311
|
/**
|
|
253
312
|
* Gets vaults with pagination support
|
|
254
313
|
* Fetches ALL data from both API (database) and subgraph in parallel, merges without duplicates, then paginates
|
|
@@ -1021,6 +1080,56 @@ class VaultClient extends SubgraphClient_js_1.SubgraphClient {
|
|
|
1021
1080
|
};
|
|
1022
1081
|
}
|
|
1023
1082
|
}
|
|
1083
|
+
/**
|
|
1084
|
+
* Searches vaults by combining verified API-supported filters with local
|
|
1085
|
+
* filtering over the merged vault result set for unsupported server-side fields.
|
|
1086
|
+
*/
|
|
1087
|
+
async searchVaults(filter) {
|
|
1088
|
+
const response = await this.getAllVaults(filter);
|
|
1089
|
+
if (!response.success || !response.data) {
|
|
1090
|
+
return response;
|
|
1091
|
+
}
|
|
1092
|
+
return {
|
|
1093
|
+
data: this.filterVaultNodes(response.data, filter || {}),
|
|
1094
|
+
status: 200,
|
|
1095
|
+
success: true,
|
|
1096
|
+
};
|
|
1097
|
+
}
|
|
1098
|
+
async getVaultByAddress(vaultAddress, filter) {
|
|
1099
|
+
const response = await this.searchVaults({
|
|
1100
|
+
...filter,
|
|
1101
|
+
vaultAddress,
|
|
1102
|
+
});
|
|
1103
|
+
if (!response.success || !response.data) {
|
|
1104
|
+
return {
|
|
1105
|
+
data: null,
|
|
1106
|
+
status: response.status,
|
|
1107
|
+
success: response.success,
|
|
1108
|
+
error: response.error,
|
|
1109
|
+
};
|
|
1110
|
+
}
|
|
1111
|
+
return {
|
|
1112
|
+
data: response.data[0] || null,
|
|
1113
|
+
status: 200,
|
|
1114
|
+
success: true,
|
|
1115
|
+
};
|
|
1116
|
+
}
|
|
1117
|
+
async getVaultsForPool(poolAddress, filter) {
|
|
1118
|
+
return this.searchVaults({
|
|
1119
|
+
...filter,
|
|
1120
|
+
poolAddress,
|
|
1121
|
+
});
|
|
1122
|
+
}
|
|
1123
|
+
async getVaultsForToken(tokenAddressOrSymbol, filter) {
|
|
1124
|
+
const normalizedValue = tokenAddressOrSymbol.trim();
|
|
1125
|
+
const isAddress = /^0x[a-fA-F0-9]{40}$/.test(normalizedValue);
|
|
1126
|
+
return this.searchVaults({
|
|
1127
|
+
...filter,
|
|
1128
|
+
...(isAddress
|
|
1129
|
+
? { tokenAddress: normalizedValue }
|
|
1130
|
+
: { tokenSymbol: normalizedValue }),
|
|
1131
|
+
});
|
|
1132
|
+
}
|
|
1024
1133
|
/**
|
|
1025
1134
|
* Gets APR data for vaults from the Steer Finance API
|
|
1026
1135
|
* @param filter - Filter containing chainId and protocol
|