Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: quite a lot of stuff I've maintained for the past few months #715

Merged
merged 55 commits into from
Nov 9, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
55 commits
Select commit Hold shift + click to select a range
69eab43
chore: replace deprecated Logger.warn
BobTheBuidler Oct 8, 2024
b2602e2
feat: filter out lps with vaults
BobTheBuidler Oct 8, 2024
63887a0
feat: refactor to prep for bal apy previews
BobTheBuidler Oct 8, 2024
44e9f83
update make
0xBasically Oct 8, 2024
60988ef
feat: delay curve loading
BobTheBuidler Oct 8, 2024
7448733
chore: remove deprecated code
BobTheBuidler Oct 8, 2024
9e93063
chore: add comment
BobTheBuidler Oct 8, 2024
1fe6f0e
feat: async log loading
BobTheBuidler Oct 8, 2024
aa03fa7
feat: more stuff
BobTheBuidler Oct 8, 2024
589d446
feat: more stuff
BobTheBuidler Oct 8, 2024
d6c18c9
fix: load_strategies
BobTheBuidler Oct 8, 2024
8f8ae24
fix: Harvests
BobTheBuidler Oct 8, 2024
008913d
fix: registry loader time
BobTheBuidler Oct 8, 2024
5392357
str not encodable
BobTheBuidler Oct 8, 2024
bac8316
feat: support rkp3r in ypm
BobTheBuidler Oct 8, 2024
e19b386
fix: vault loader
BobTheBuidler Oct 8, 2024
8bee62e
chore: cleanup treasury-txs logs
BobTheBuidler Oct 8, 2024
fb5fb53
chore: contract -> Contract
BobTheBuidler Oct 8, 2024
c18f5fa
chore: cleanup
BobTheBuidler Oct 8, 2024
66f87f5
chore: add comment
BobTheBuidler Oct 8, 2024
3ee9aa3
feat: asyncify curve simple
BobTheBuidler Oct 8, 2024
3867862
chore: remove unneeded code
BobTheBuidler Oct 8, 2024
08eaa3a
fix: treasury txs TypeErr
BobTheBuidler Oct 8, 2024
1c60a6f
fix: from_address is None
BobTheBuidler Oct 8, 2024
090fa54
fix: SyntaxError
BobTheBuidler Oct 8, 2024
f6a19f1
fix(temp): logs for treasury-tx
BobTheBuidler Oct 8, 2024
d822ac2
chore: refactor with new dep members
BobTheBuidler Oct 8, 2024
a9b10dd
chore: replace contract with Contract
BobTheBuidler Oct 8, 2024
2a901c0
feat: optimize db entity handling
BobTheBuidler Oct 8, 2024
e22c38e
feat: load streams with treasry txs exporter
BobTheBuidler Oct 8, 2024
0a04813
fix: asyncify yeth
BobTheBuidler Oct 8, 2024
de1bb0a
feat: make build --no-cache
BobTheBuidler Oct 8, 2024
fbe8fe9
feat: processing queue
BobTheBuidler Oct 8, 2024
b35b609
fix: adapt to ypm 3.6
BobTheBuidler Oct 8, 2024
9a7d3b0
feat: make way less eth_getLogs calls
BobTheBuidler Oct 8, 2024
32354d1
feat: disable sms exporter on base
BobTheBuidler Oct 8, 2024
0117236
chore: replace deprecated dank_w3
BobTheBuidler Oct 8, 2024
885ae0a
fix: treasury and sms on non-mainnet
BobTheBuidler Oct 8, 2024
0363c0e
feat: use Queue, save ram
BobTheBuidler Oct 8, 2024
ca902c5
feat: sort txs
BobTheBuidler Oct 8, 2024
84774db
fix: hanging sorter
BobTheBuidler Oct 8, 2024
b752259
feat: brownie 1.20.3 disables eager caching
BobTheBuidler Oct 8, 2024
1627d97
feat: faster eth-abi
BobTheBuidler Oct 8, 2024
c8aec10
feat: faster builds with poetry
BobTheBuidler Nov 9, 2024
db9cff1
chore: add shitcoins to shitcoins
BobTheBuidler Nov 9, 2024
0c73a52
feat: sort txs
BobTheBuidler Nov 9, 2024
29c3c52
chore: bump eth-portfolio and ypricemagic
BobTheBuidler Nov 9, 2024
5f53f2f
feat: a bunch of old stuff
BobTheBuidler Nov 9, 2024
716ab75
chore: remove unused imports
BobTheBuidler Nov 9, 2024
49992cf
chore: refactor accountant
BobTheBuidler Nov 9, 2024
b3a4f1c
chore: bump deps
BobTheBuidler Nov 9, 2024
2cf031b
feat: optimize streams with caches
BobTheBuidler Nov 9, 2024
95f6f3b
chore: add detail to exc
BobTheBuidler Nov 9, 2024
df2aa4a
chore: rename constant
BobTheBuidler Nov 9, 2024
661963a
chore: bump brownie to 1.20
BobTheBuidler Nov 9, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
chore: remove deprecated code
  • Loading branch information
BobTheBuidler committed Oct 8, 2024
commit 744873327566d3e679d9db1735d7221addadde56
179 changes: 3 additions & 176 deletions yearn/prices/curve.py
Original file line number Diff line number Diff line change
Expand Up @@ -236,6 +236,7 @@ def get_factory(self, pool: AddressOrContract) -> EthAddress:
"""
Get metapool factory that has spawned a pool.
"""
self.ensure_loaded()
try:
return next(
factory
Expand All @@ -249,6 +250,7 @@ def get_registry(self, pool: AddressOrContract) -> EthAddress:
"""
Get registry containing a pool.
"""
self.ensure_loaded()
try:
return next(
registry
Expand Down Expand Up @@ -276,6 +278,7 @@ def get_gauge(self, pool: AddressOrContract, lp_token: AddressOrContract) -> Eth
"""
Get liquidity gauge address by pool or lp_token.
"""
self.ensure_loaded()
pool = to_address(pool)
lp_token = to_address(lp_token)
if chain.id == Network.Mainnet:
Expand All @@ -297,7 +300,6 @@ def get_gauge(self, pool: AddressOrContract, lp_token: AddressOrContract) -> Eth
if gauge != ZERO_ADDRESS:
return gauge


@lru_cache(maxsize=None)
def get_coins(self, pool: AddressOrContract) -> List[EthAddress]:
"""
Expand All @@ -317,182 +319,7 @@ def get_coins(self, pool: AddressOrContract) -> List[EthAddress]:

return [coin for coin in coins if coin not in {None, ZERO_ADDRESS}]

@lru_cache(maxsize=None)
def get_underlying_coins(self, pool: AddressOrContract) -> List[EthAddress]:
pool = to_address(pool)
factory = self.get_factory(pool)
registry = self.get_registry(pool)

if factory:
factory = contract(factory)
# new factory reverts for non-meta pools
if not hasattr(factory, 'is_meta') or factory.is_meta(pool):
if hasattr(factory, 'get_underlying_coins'):
coins = factory.get_underlying_coins(pool)
elif hasattr(factory, 'get_coins'):
coins = factory.get_coins(pool)
else:
coins = {ZERO_ADDRESS}
else:
coins = factory.get_coins(pool)
elif registry:
registry = contract(registry)
if hasattr(registry, 'get_underlying_coins'):
coins = registry.get_underlying_coins(pool)
elif hasattr(registry, 'get_coins'):
coins = registry.get_coins(pool)

# pool not in registry, not checking for underlying_coins here
if set(coins) == {ZERO_ADDRESS}:
return self.get_coins(pool)

return [coin for coin in coins if coin != ZERO_ADDRESS]

@lru_cache(maxsize=None)
def get_decimals(self, pool: AddressOrContract) -> List[int]:
pool = to_address(pool)
factory = self.get_factory(pool)
registry = self.get_registry(pool)
source = contract(factory or registry)
decimals = source.get_decimals(pool)

# pool not in registry
if not any(decimals):
coins = self.get_coins(pool)
decimals = fetch_multicall(
*[[contract(token), 'decimals'] for token in coins]
)

return [dec for dec in decimals if dec != 0]

def get_balances(self, pool: AddressOrContract, block: Optional[Block] = None, should_raise_err: bool = True) -> Optional[Dict[EthAddress,float]]:
"""
Get {token: balance} of liquidity in the pool.
"""
pool = to_address(pool)
factory = self.get_factory(pool)
registry = self.get_registry(pool)
coins = self.get_coins(pool)
decimals = self.get_decimals(pool)

try:
source = contract(factory or registry)
balances = source.get_balances(pool, block_identifier=block)
# fallback for historical queries
except ValueError as e:
if str(e) not in [
'execution reverted',
'No data was returned - the call likely reverted'
]: raise

balances = fetch_multicall(
*[[contract(pool), 'balances', i] for i, _ in enumerate(coins)],
block=block
)

if not any(balances):
if should_raise_err:
raise ValueError(f'could not fetch balances {pool} at {block}')
return None

return {
coin: balance / 10 ** dec
for coin, balance, dec in zip(coins, balances, decimals)
}

def get_virtual_price(self, pool: Address, block: Optional[Block] = None) -> Optional[float]:
pool = contract(pool)
try:
return pool.get_virtual_price(block_identifier=block) / 1e18
except ValueError as e:
if str(e) == "execution reverted":
return None
raise

def get_tvl(self, pool: AddressOrContract, block: Optional[Block] = None) -> float:
"""
Get total value in Curve pool.
"""
pool = to_address(pool)
balances = self.get_balances(pool, block=block)

return sum(
amount * magic.get_price(coin, block=block)
for coin, amount in balances.items()
)

@ttl_cache(maxsize=None, ttl=600)
def get_price(self, token: AddressOrContract, block: Optional[Block] = None) -> Optional[float]:
token = to_address(token)
pool = self.get_pool(token)
# crypto pools can have different tokens, use slow method
try:
tvl = self.get_tvl(pool, block=block)
except ValueError:
tvl = 0
supply = contract(token).totalSupply(block_identifier=block) / 1e18
if supply == 0:
if tvl > 0:
raise ValueError('curve pool has balance but no supply')
return 0
return tvl / supply

def get_coin_price(self, token: AddressOrContract, block: Optional[Block] = None) -> Optional[float]:

# Select the most appropriate pool
pools = self.coin_to_pools[token]
if not pools:
return
elif len(pools) == 1:
pool = pools[0]
else:
# We need to find the pool with the deepest liquidity
balances = [self.get_balances(pool, block, should_raise_err=False) for pool in pools]
deepest_pool, deepest_bal = None, 0
for pool, pool_bals in zip(pools, balances):
if pool_bals is None:
continue
if isinstance(pool_bals, Exception):
if str(pool_bals).startswith("could not fetch balances"):
continue
raise pool_bals
for _token, bal in pool_bals.items():
if _token == token and bal > deepest_bal:
deepest_pool = pool
deepest_bal = bal
pool = deepest_pool

# Get the index for `token`
coins = self.get_coins(pool)
token_in_ix = [i for i, coin in enumerate(coins) if coin == token][0]
amount_in = 10 ** contract(str(token)).decimals()
if len(coins) == 2:
# this works for most typical metapools
token_out_ix = 0 if token_in_ix == 1 else 1 if token_in_ix == 0 else None
elif len(coins) == 3:
# We will just default to using token 0 until we have a reason to make this more flexible
token_out_ix = 0 if token_in_ix in [1, 2] else 1 if token_in_ix == 0 else None
else:
# TODO: handle this sitch if necessary
return None

# Get the price for `token` using the selected pool.
try:
dy = contract(pool).get_dy(token_in_ix, token_out_ix, amount_in, block_identifier = block)
except:
return None

if coins[token_out_ix] == EEE_ADDRESS:
token_out = EEE_ADDRESS
amount_out = dy / 10 ** 18
else:
token_out = contract(coins[token_out_ix])
amount_out = dy / 10 ** token_out.decimals()
try:
return amount_out * magic.get_price(token_out, block = block)
except PriceError:
return None

async def calculate_boost(self, gauge: Contract, addr: Address, block: Optional[Block] = None) -> Dict[str,float]:
results = await fetch_multicall_async(
[gauge, "balanceOf", addr],
Expand Down
9 changes: 2 additions & 7 deletions yearn/prices/magic.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
from y.networks import Network

from yearn.constants import CRV
from yearn.prices import constants, curve
from yearn.prices import constants
from yearn.prices.aave import aave
from yearn.prices.balancer import balancer as bal
from yearn.prices.band import band
Expand Down Expand Up @@ -124,7 +124,7 @@ def find_price(
elif chain.id == Network.Mainnet:
# no liquid market for yveCRV-DAO -> return CRV token price
if token == Backscratcher().vault.address and block < 11786563:
if curve.curve and CRV:
if CRV:
return get_price(CRV, block=block)
# no liquidity for curve pool (yvecrv-f) -> return 0
elif token == "0x7E46fd8a30869aa9ed55af031067Df666EfE87da" and block < 14987514:
Expand All @@ -134,7 +134,6 @@ def find_price(
return 0

markets = [
curve.curve,
compound,
fixed_forex,
generic_amm,
Expand All @@ -160,10 +159,6 @@ def find_price(
price, underlying = price
logger.debug("peel %s %s", price, underlying)
return price * get_price(underlying, block=block)

if price is None and token in curve.curve.coin_to_pools:
logger.debug(f'Curve.get_coin_price -> {price}')
price = curve.curve.get_coin_price(token, block = block)

if price is None and return_price_during_vault_downtime:
for incident in INCIDENTS[token]:
Expand Down