Skip to content

Commit

Permalink
Merge pull request #42 from valory-xyz/feat/add-lending-strategy
Browse files Browse the repository at this point in the history
Feat/add lending strategy
  • Loading branch information
dagacha authored Dec 10, 2024
2 parents a48c316 + 009d2e4 commit 1a70dc0
Showing 1 changed file with 61 additions and 19 deletions.
80 changes: 61 additions & 19 deletions run_service.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@
from termcolor import colored
from web3 import Web3
from web3.types import Wei, TxParams
from typing import Dict, Any
from typing import Dict, Any, Optional

from operate.account.user import UserAccount
from operate.cli import OperateApp
Expand Down Expand Up @@ -125,6 +125,7 @@ class Strategy(Enum):
"""Strategy type"""
MerklPoolSearchStrategy = "merkl_pools_search"
BalancerPoolSearchStrategy = "balancer_pools_search"
SturdyLendingStrategy = "asset_lending"

def estimate_priority_fee(
web3_object: Web3,
Expand Down Expand Up @@ -464,6 +465,13 @@ def configure_local_config() -> OptimusConfig:

if optimus_config.selected_strategies is None:
optimus_config.selected_strategies = [Strategy.MerklPoolSearchStrategy.value, Strategy.BalancerPoolSearchStrategy.value]

if "mode" in optimus_config.target_investment_chains:
if Strategy.SturdyLendingStrategy.value not in optimus_config.selected_strategies:
optimus_config.selected_strategies.append(Strategy.SturdyLendingStrategy.value)
else:
if Strategy.SturdyLendingStrategy.value in optimus_config.selected_strategies:
optimus_config.selected_strategies.remove(Strategy.SturdyLendingStrategy.value)

optimus_config.store()
return optimus_config
Expand Down Expand Up @@ -499,7 +507,7 @@ def get_service_template(config: OptimusConfig) -> ServiceTemplate:
home_chain_id = "10" if config.staking_chain == "optimism" else "34443"
return ServiceTemplate({
"name": "Optimus",
"hash": "bafybeierrvod33ljm2lmuzmdc4bdyke57jlylpa3dwvnnbxsdu7z23f5um",
"hash": "bafybeigp444eluxn77x5qdtuqok45gbhrg7l2ptdgntafldbay3x7bpsja",

"description": "Optimus",
"image": "https://gateway.autonolas.tech/ipfs/bafybeiaakdeconw7j5z76fgghfdjmsr6tzejotxcwnvmp3nroaw3glgyve",
Expand Down Expand Up @@ -687,26 +695,60 @@ def fetch_investing_funding_requirements(chain_name: str) -> None:

optimus_config.store()

def calculate_fund_requirement(rpc, fee_history_blocks: int, gas_amount: int, fee_history_percentile: int = 50, priority_fee_increase_boundary: int = 200) -> int:
if rpc is None:
def calculate_fund_requirement(
rpc: str,
fee_history_blocks: int,
gas_amount: int,
fee_history_percentile: int = 50,
safety_margin: int = 500_000_000_000_000
) -> Optional[int]:
"""
Calculate the estimated fund requirement for a transaction.
Args:
rpc (str): RPC URL of the Ethereum node.
fee_history_blocks (int): Number of recent blocks for fee history.
gas_amount (int): Gas amount required for the transaction.
fee_history_percentile (int): Percentile for priority fee (default: 50).
safety_margin (int): Safety margin in wei (default: 500,000,000,000,000).
Returns:
Optional[int]: Estimated fund requirement in wei, or None if unavailable.
"""
if not rpc:
print("RPC URL is required.")
return None

web3 = Web3(Web3.HTTPProvider(rpc))
block_number = web3.eth.block_number
latest_block = web3.eth.get_block("latest")
base_fee = latest_block.get("baseFeePerGas")

if base_fee is None or block_number is None:

try:
web3 = Web3(Web3.HTTPProvider(rpc))
block_number = web3.eth.block_number
fee_history = web3.eth.fee_history(
fee_history_blocks, block_number, [fee_history_percentile]
)
except Exception as e:
return None

priority_fee = estimate_priority_fee(web3, block_number, fee_history_blocks, fee_history_percentile, priority_fee_increase_boundary)
if priority_fee is None:

if not fee_history or 'baseFeePerGas' not in fee_history:
return None

gas_price = base_fee + priority_fee
safety_margin = 500_000_000_000_000
fund_requirement = int((gas_price * gas_amount) + safety_margin)
return fund_requirement

base_fees = fee_history.get('baseFeePerGas', [])
priority_fees = [reward[0] for reward in fee_history.get('reward', []) if reward]

if not base_fees or not priority_fees:
return None

try:
# Calculate averages
average_base_fee = sum(base_fees) / len(base_fees)
average_priority_fee = sum(priority_fees) / len(priority_fees)
average_gas_price = average_base_fee + average_priority_fee

# Calculate fund requirement
fund_requirement = int((average_gas_price * gas_amount) + safety_margin)
return fund_requirement
except Exception as e:
return None


def fetch_agent_fund_requirement(chain_id, rpc, fee_history_blocks: int = 500000) -> int:
gas_amount = 50_000_000
Expand Down

0 comments on commit 1a70dc0

Please sign in to comment.