Skip to content

Commit

Permalink
Merge pull request #815 from tellor-io/improved-aerodrome-source
Browse files Browse the repository at this point in the history
fixed routing for superOETHb/eth pair
  • Loading branch information
0xSpuddy authored Oct 4, 2024
2 parents d3909fd + b05da7f commit 65f694e
Showing 1 changed file with 17 additions and 19 deletions.
36 changes: 17 additions & 19 deletions src/telliot_feeds/sources/superoethb_source.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,9 +30,10 @@
]
SRC_LEN = 1
CONNECTORS = [
"0xDBFeFD2e8460a6Ee4955A68582F85708BAEA60A3",
"0x4200000000000000000000000000000000000006",
"0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913",
"0xDBFeFD2e8460a6Ee4955A68582F85708BAEA60A3", # superOETHb
"0x7002458B1DF59EccB57387bC79fFc7C29E22e6f7", # OGNb
"0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913", # USDCb
"0x4200000000000000000000000000000000000006", # wETHb
]


Expand All @@ -49,7 +50,7 @@ def __init__(self, **kwargs: Any) -> None:
self.src_len: Optional[int] = None
self.connectors: Optional[List[Any]] = None

def get_aerodrome_usd_price(self) -> Optional[float]:
def get_aerodrome_eth_ratio(self) -> Optional[float]:
# get endpoint
endpoint = self.cfg.endpoints.find(chain_id=8453)
if not endpoint:
Expand All @@ -63,7 +64,7 @@ def get_aerodrome_usd_price(self) -> Optional[float]:
if w3 is None:
logger.error("Unable to get web3 for mainnet to get superoethb_eth_ratio")
return None
# get usd price of superOETHb
# get superOETHb/eth ratio
try:
src_len = SRC_LEN
connectors = CONNECTORS
Expand All @@ -72,12 +73,14 @@ def get_aerodrome_usd_price(self) -> Optional[float]:
contract_function = contract.functions.getManyRatesWithConnectors(src_len, connectors)
aerodrome_response = contract_function.call()
response_int = aerodrome_response[0]
response_usd_price = w3.fromWei(response_int, "ether")
response_price_float = float(response_usd_price)
response_eth_ratio = w3.fromWei(response_int, "ether")
eth_ratio = float(response_eth_ratio)
logger.info(f"Aerodrome Response (superOETHb): {eth_ratio}")

except Exception as e:
print(f"Error querying Aerodrome: {e}")
logger.error(f"Error querying Aerodrome: {e}")

return response_price_float
return eth_ratio

async def get_price(self, asset: str, currency: str) -> OptionalDataPoint[float]:
"""This implementation gets the superOETHb/ETH ratio by checking the oracle
Expand All @@ -92,18 +95,13 @@ async def get_price(self, asset: str, currency: str) -> OptionalDataPoint[float]
logger.error("Unable to get eth/usd price for superOETHb conversion")
return None, None

usd_price = self.get_aerodrome_usd_price()
logger.info(f"superoethb usd_price: {usd_price}")
if usd_price is None:
logger.error("usd_price is None for superOETHb (check source)")
return None, None

superoethb_eth_ratio = float(usd_price / eth_price)
if superoethb_eth_ratio is None:
logger.error("Unable to get superoethb_eth_ratio")
eth_ratio = self.get_aerodrome_eth_ratio()
logger.info(f"superoethb usd_price: {eth_ratio}")
if eth_ratio is None:
logger.error("eth_ratio is None for superOETHb (check source)")
return None, None

return superoethb_eth_ratio, datetime_now_utc()
return eth_ratio, datetime_now_utc()


@dataclass
Expand Down

0 comments on commit 65f694e

Please sign in to comment.