IPOR Oracle

“Someone’s sitting in the shade today because someone planted a tree a long time ago.”

Warren Buffet

Oracle structure

Oracle structure consists of 2 contracts and an off-chain component.

  1. Rate calculation contract: https://etherscan.io/address/0x9D4BD8CB9DA419A9cA1343A5340eD4Ce07E85140

    This stateless contract fetches the data from all the protocols supported by IPOR Index and runs all the calculations to compute IPOR Rate.

  2. Oracle contract This contract keeps the state of the IPOR rate and IBT. Oracle contract allows for permissionless update of the IPOR rate (as long as requested is willing to cover the gas costs associated with the rate calculation) by invoking updateIndex(asset Address) function.

  3. Rate publication off-chain oracle service. This service reads the value calculated in the rate calculation contract are publishes it to the IPOR Oracle contract. This is mainly done due to gas optimization reasons.

Public Functions

FunctionNotes

getIndex (address asset)

It returns the most recently published IPOR value for a given asset.

getAccruedIndex(uint256 calcTimestamp, address asset)

It returns the structure with: - the most recent IPOR Index - IBT as calculated to the current timestamp. See calculateAccruedIbtPrice

calculateAccruedIbtPrice (address asset, uint256 calcTimestamp)

For a given asset it calculates the current value of IBT considering the time passed from the last IPOR publication. Change in IBT is made based on the recently published IPOR.

updateIndex (address asset, uint256 value)

Function available only to whitelisted addresses. It allows for IPOR publication. This function will also trigger a recalculation of IBT.

updateIndex (address asset)

Function available only to whitelisted addresses. When invoked, it will make a request to index-calculating smart contract (also used by the off-chain oracle) publish the index, and return value (same sa getIndex)

updateIndexes (address[] assets, uint256[] values)

Allows IPOR updating for multiple assets simultaneously.

addUpdater (address updater)

Available for Owner only. Adds address to whitelist of IPOR index updaters

removeUpdater (address updater)

Available for Owner only. Removes address from the whitelist of IPOR index updaters

addAsset (address asset, uint256 updateTimestamp

Available for Owner only. Adds asset for which IPOR can be compiled.

removeAsset (address asset)

Available for Owner only. It removes asset.

Last updated