data:image/s3,"s3://crabby-images/103e3/103e3fcd93555921997f352f9c87df50678e7c67" alt=""
AggregatorV2V3Interface
AggregatorV2V3Interface is intended for use by contracts that were originally built to use Chainlink data feeds. All considerations from the contract integration page still apply.
⚠️ Warning
API3 data feeds are aggregated from asynchronous data feeds to provide maximal availability guarantees, which means they are not updated in rounds. As a side effect, Api3ReaderProxyV1 does not implement the round-related functionality of AggregatorV2V3Interface. If your contract depends on round-related functionality, it would not be appropriate to use Api3ReaderProxyV1 via AggregatorV2V3Interface. Instead, we recommend using IApi3ReaderProxy with a custom adapter that fits your specific needs.
You can interact with Api3ReaderProxyV1 through AggregatorV2V3Interface if all of the following conditions apply:
- Your contract primarily relies on the current data feed value (
latestAnswer()
of AggregatorInterface oranswer
returned bylatestRoundData()
of AggregatorV3Interface). - If your contract uses the current data feed timestamp (
latestTimestamp()
of AggregatorInterface orupdatedAt
returned bylatestRoundData()
of AggregatorV3Interface), it must be used only for staleness checks (e.g., to verify if the feed has been updated within the last heartbeat interval). - Any other values used must not affect your contract's logic or your dApp's off-chain infrastructure. For example, your contract may emit
roundId
in an event strictly for logging purposes. - Your dApp's off-chain infrastructure does not depend on events defined in AggregatorInterface.
💡 Tip
Lending protocols typically satisfy these conditions.
On the other hand, you should not interact with Api3ReaderProxyV1 through AggregatorV2V3Interface if any of the following conditions applies:
- Your contract depends on Chainlink feed implementation details, such as the round ID increasing with every update.
- Your contract depends on querying past updates using
getAnswer()
orgetTimestamp()
of AggregatorInterface, orgetRoundData()
of AggregatorV3Interface. - Your dApp's off-chain infrastructure depends on events defined in AggregatorInterface.
💡 Tip
DeFi protocols such as perpetual derivative exchanges are typically vulnerable to MEV searchers performing time arbitrage. Chainlink data feeds provide past round data primarily to address this issue, but this solution significantly degrades UX by requiring multiple transactions for certain actions. Instead, you can simply read the latest data feed value from an API3 data feed and receive compensation for time arbitrage value extraction through OEV Rewards.
If you have any doubts about interacting with Api3ReaderProxyV1 through AggregatorV2V3Interface, you can refer to the Api3ReaderProxyV1 implementation to see exactly how these functions behave.