Skip to content

Latest commit

 

History

History
81 lines (53 loc) · 2.87 KB

095.md

File metadata and controls

81 lines (53 loc) · 2.87 KB

juancito

medium

Static oracles in StableOracleDAI and StableOracleWBGL have wrong addresses

Summary

Static oracles in StableOracleDAI and StableOracleWBGL have wrong addresses. Those are used on their corresponding getPriceUSD functions, making the function revert.

It will be impossible to mint USSD tokens with DAI and WBGL as collateral, as their getPriceUSD will always revert.

Vulnerability Detail

Both StableOracleDAI and StableOracleWBGL set their static oracles to 0x982152A6C7f732Ec7C9EA998dDD9Ebde00Dfa16e.

That is not an static oracle, but the Uniswap WBGL/ETH pool.

It does not implement the expected interface, nor does it have the quoteSpecificPoolsWithTimePeriod() function.

When trying to call getPrice, it will always revert, as it will try to call quoteSpecificPoolsWithTimePeriod() on the "static oracle", but it doesn't exist there.

getPrice() is used when trying to mint USSD tokens on the USSD contract. So, it is impossible to use these oracles for that purpose.

    // constructor()
    DAIEthOracle = IStaticOracle(
        0x982152A6C7f732Ec7C9EA998dDD9Ebde00Dfa16e
    );

    // getPrice()
    uint256 DAIWethPrice = DAIEthOracle.quoteSpecificPoolsWithTimePeriod(

Link to code

    // constructor()
    staticOracleUniV3 = IStaticOracle(
        0x982152A6C7f732Ec7C9EA998dDD9Ebde00Dfa16e
    );

    // getPrice()
    uint256 wbglWethPrice = staticOracleUniV3
        .quoteSpecificPoolsWithTimePeriod(

Link to code

Impact

It will be impossible to mint USSD tokens with DAI and WBGL as collateral, as their getPriceUSD will always revert.

Code Snippet

Tool used

Manual Review

Recommendation

Set the correct address for the static oracles.

One example could be Mean Finance implementation 0xB210CE856631EeEB767eFa666EC7C1C57738d438 with their Ethereum contract here.

    DAIEthOracle = IStaticOracle(
-        0x982152A6C7f732Ec7C9EA998dDD9Ebde00Dfa16e
+        0xB210CE856631EeEB767eFa666EC7C1C57738d438
    );
    staticOracleUniV3 = IStaticOracle(
-        0x982152A6C7f732Ec7C9EA998dDD9Ebde00Dfa16e
+        0xB210CE856631EeEB767eFa666EC7C1C57738d438
    );