From 861b6daa71d182c847fc4e180e4704a773f3cfb7 Mon Sep 17 00:00:00 2001 From: Denis Date: Tue, 19 Sep 2023 18:45:06 +0300 Subject: [PATCH] Fix incorrect index logic --- contracts/oracles/CurveOracle.sol | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/contracts/oracles/CurveOracle.sol b/contracts/oracles/CurveOracle.sol index 87faa3e6..8b845e16 100644 --- a/contracts/oracles/CurveOracle.sol +++ b/contracts/oracles/CurveOracle.sol @@ -43,8 +43,10 @@ contract CurveOracle is IOracle { FunctionInfo memory info; uint256 index = 0; for (uint256 i = 0; i < REGISTRIES_COUNT && index < MAX_POOLS; i++) { - address pool = registries[i].find_pool_for_coins(address(srcToken), address(dstToken), index); + uint256 registryIndex = 0; + address pool = registries[i].find_pool_for_coins(address(srcToken), address(dstToken), registryIndex); while (pool != address(0) && index < MAX_POOLS) { + index++; (int128 srcTokenIndex, int128 dstTokenIndex, bool isUnderlying) = registries[i].get_coin_indices(pool, address(srcToken), address(dstToken)); if (!isUnderlying) { info = FunctionInfo({ @@ -74,7 +76,7 @@ contract CurveOracle is IOracle { } ratesAndWeights.append(OraclePrices.OraclePrice(Math.mulDiv(b1, 1e18, b0), w)); } - pool = registries[i].find_pool_for_coins(address(srcToken), address(dstToken), ++index); + pool = registries[i].find_pool_for_coins(address(srcToken), address(dstToken), ++registryIndex); } } (rate, weight) = ratesAndWeights.getRateAndWeight(thresholdFilter);