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

Slashing #171

Open
wants to merge 235 commits into
base: dev
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 20 commits
Commits
Show all changes
235 commits
Select commit Hold shift + click to select a range
e64e5de
add get staker shares method
TomasArrachea Nov 14, 2024
7f4378f
add get_delegated_operator method
TomasArrachea Nov 14, 2024
caca28e
change eigen middleware submodule to slashing branch
TomasArrachea Nov 19, 2024
f4afa71
upload updated bindings
TomasArrachea Nov 20, 2024
eb006a0
update middleware rev
Nov 21, 2024
e513be2
working bindings
TomasArrachea Nov 21, 2024
d4c0a26
restore deleted bindings
TomasArrachea Nov 21, 2024
37696a4
update get_staker_shares method
TomasArrachea Nov 21, 2024
fb4babf
remove deprecated methods and update ElChainReader attributes
TomasArrachea Nov 21, 2024
8b348dc
add mockavsservicemanager binding
TomasArrachea Nov 21, 2024
cac51e8
update ElContract Reader tests
TomasArrachea Nov 21, 2024
c9ef2a4
wip scripts
Nov 22, 2024
177ed4c
port scripts from incredible squaring
Nov 22, 2024
349b40d
update elcontracts writer
TomasArrachea Nov 22, 2024
277d61d
add elcontracts reader build method
TomasArrachea Nov 22, 2024
29afec5
add bindings
TomasArrachea Nov 22, 2024
1903878
add missing bindings
TomasArrachea Nov 22, 2024
7fc3b85
fix examples
TomasArrachea Nov 22, 2024
6f1c5ba
cargo fmt
TomasArrachea Nov 22, 2024
75ccd80
remove added bindings
TomasArrachea Nov 22, 2024
4fae355
fix bindings lib
TomasArrachea Nov 22, 2024
70e1e05
remove more bindings
TomasArrachea Nov 22, 2024
403f027
wip : scripts
Nov 25, 2024
651460e
ignore failing tests due to anvil state not updated
TomasArrachea Nov 25, 2024
bbd91dc
Merge branch 'main' into slashing_methods
TomasArrachea Nov 25, 2024
b48ecce
ignore tests
TomasArrachea Nov 25, 2024
b490ed0
add get_operators_for_operator_set method
TomasArrachea Nov 25, 2024
65db644
add updated bindings
TomasArrachea Nov 25, 2024
ceb82ef
wip : state load issue
Nov 26, 2024
cccec71
remove extra bindings
TomasArrachea Nov 22, 2024
21d812c
Merge branch 'slashing_methods' into add_slashing_methods
TomasArrachea Nov 26, 2024
ba83e54
fix getAllocatedSets return type
TomasArrachea Nov 26, 2024
f12f366
add get_strategies_for_operator_set method
TomasArrachea Nov 26, 2024
72f9650
pin anvil version
TomasArrachea Nov 26, 2024
7ab4a89
add get_operators_sets_for_operator method
TomasArrachea Nov 26, 2024
7d5a3f0
add get_delegated_and_slashable_shares_for_operator_sets_before method
TomasArrachea Nov 26, 2024
90947bf
add get_registered_sets method
TomasArrachea Nov 26, 2024
562413c
add get_allocation_delay method
TomasArrachea Nov 26, 2024
e3ec1e9
add get_slashable_shares_for_operator_sets method
TomasArrachea Nov 26, 2024
10060f5
add get_num_operators_for_operator_set method
TomasArrachea Nov 26, 2024
d80b4c5
add is_operator_registered_with_operator_set method
TomasArrachea Nov 26, 2024
148257c
add get_num_operator_sets_for_operator method
TomasArrachea Nov 26, 2024
dc9c6d9
add get_operators_shares method
TomasArrachea Nov 26, 2024
1e8e4a2
add get_operator_shares method
TomasArrachea Nov 26, 2024
e43ef8c
add get_allocation_info method
TomasArrachea Nov 26, 2024
7334a26
add get_max_magnitudes method
TomasArrachea Nov 26, 2024
4115a47
add get_allocatable_magnitude method
TomasArrachea Nov 26, 2024
6524f07
cargo fmt
TomasArrachea Nov 26, 2024
2c18682
Merge branch 'slashing_methods' into add_slashing_methods
TomasArrachea Nov 26, 2024
ca80e80
fix anvil version
TomasArrachea Nov 26, 2024
864ca99
clippy
TomasArrachea Nov 26, 2024
186f517
Merge branch 'slashing_methods' into add_slashing_methods
TomasArrachea Nov 26, 2024
d988583
restore anvil version to latest
TomasArrachea Nov 27, 2024
ef89f17
add updated anvil state
TomasArrachea Nov 27, 2024
7c0fc7b
update solc version of foyndry.toml
TomasArrachea Nov 27, 2024
ed1eba3
format solidity scripts
TomasArrachea Nov 27, 2024
a334e80
get_cumulative_claimed_for_root
pablodeymo Nov 27, 2024
2fbf75a
udpated CoreDeploymentLib.sol for slashing contracts
TomasArrachea Nov 27, 2024
e3272b4
add test_is_operator_registered
TomasArrachea Nov 27, 2024
cbb22f4
add test_get_staker_shares
TomasArrachea Nov 27, 2024
2379dd5
add test_get_delegated_operator
TomasArrachea Nov 27, 2024
bbe92d2
fix deploy eigenlayer
TomasArrachea Nov 28, 2024
09ae574
add forge script broadcast flag
TomasArrachea Nov 28, 2024
ffe9ed4
fix deploy avs
TomasArrachea Nov 28, 2024
e1eaa73
update anvil state
TomasArrachea Nov 28, 2024
876b862
test_get_registered_sets
pablodeymo Nov 28, 2024
ff30d78
update anvil state
TomasArrachea Nov 28, 2024
d4fa852
remove ignore on tests
TomasArrachea Nov 28, 2024
c439589
Add slashing bindings (#163)
TomasArrachea Nov 29, 2024
09e2b37
Merge branch 'anvil_state_for_slashing' into slashing
TomasArrachea Nov 29, 2024
9d127cb
Merge branch 'add_slashing_methods' into slashing
TomasArrachea Nov 29, 2024
e337eb5
clippy
TomasArrachea Nov 29, 2024
8d59985
changes from the PR with rewards methods
pablodeymo Nov 29, 2024
0d90bb9
fix test strategy and token addresses
TomasArrachea Dec 2, 2024
08e0603
add allocation manager to deployment json
TomasArrachea Dec 2, 2024
aeefb8f
upgrade allocation manager contract in deployment scripts
TomasArrachea Dec 2, 2024
1675c35
set anvil base fee to 0
TomasArrachea Dec 2, 2024
2ace59e
register operator with allocation delay not zero
TomasArrachea Dec 2, 2024
f47692d
add testing util get_allocation_manager_address
TomasArrachea Dec 3, 2024
4264833
register AllocationManager in ContractsRegistry
TomasArrachea Dec 3, 2024
21029af
register RewardsCoordinator in ContractsRegistry
TomasArrachea Dec 3, 2024
edb4a37
fix env vars error on deploy scripts
TomasArrachea Dec 3, 2024
b6bdd1b
small fixes on register rewardsCoordinator and allocationManager
TomasArrachea Dec 3, 2024
22b4c6d
update anvil state json
TomasArrachea Dec 3, 2024
4764345
remove old make deploy target
TomasArrachea Dec 3, 2024
dc958ed
remove mining blocks on anvil init
TomasArrachea Dec 3, 2024
b43dbb0
format deploy json files
TomasArrachea Dec 3, 2024
b7dca0e
fix ElContracts Writer register operator test
TomasArrachea Dec 3, 2024
7c02923
update register operator to EL testing util
TomasArrachea Dec 3, 2024
0201e5e
changes on register operator AvsRegistry Writer
TomasArrachea Dec 3, 2024
58626ae
fix operator registered tests in ElContracts Reader
TomasArrachea Dec 3, 2024
415bf0c
comment get_registered_sets method
TomasArrachea Dec 3, 2024
c3da346
clippy
TomasArrachea Dec 3, 2024
5d01570
fix instrumented client tests
TomasArrachea Dec 3, 2024
2eef1df
fix elcontracts writer register operator test
TomasArrachea Dec 3, 2024
94bdbe6
fix get_strategy_and_underlying_erc20_token method
TomasArrachea Dec 4, 2024
6221c14
remove debug prints
TomasArrachea Dec 4, 2024
4030e92
fix writer deposit erc20 test
TomasArrachea Dec 4, 2024
4a917b5
fix egn_addrs tests
TomasArrachea Dec 4, 2024
f2b8c9a
clean avsRegistry writer tests
TomasArrachea Dec 4, 2024
a332630
fix instrumented client tests
TomasArrachea Dec 4, 2024
c8ba87a
fix tx manager tests
TomasArrachea Dec 4, 2024
2772242
map_to_curve receiving a 32 bits array
pablodeymo Dec 4, 2024
475ef13
refactor bls agg test to register operators
TomasArrachea Dec 4, 2024
f08392b
json serialization in test
pablodeymo Dec 4, 2024
8e51708
Merge branch 'main' into slashing
TomasArrachea Dec 4, 2024
bc8875a
add rewards documentation
TomasArrachea Dec 5, 2024
b84668a
add rewards test
TomasArrachea Dec 5, 2024
49226eb
add deploy target
TomasArrachea Dec 5, 2024
90a47b3
Fix map_to_curve in utils bn254 (in the deserialization it was used t…
pablodeymo Dec 5, 2024
c9c9fa8
finish test test_compliance for signature
pablodeymo Dec 5, 2024
ab2b652
add test check claim and process claim with no root submitted
TomasArrachea Dec 6, 2024
c2f9f31
Merge branch 'fix_signature' into slashing
TomasArrachea Dec 6, 2024
4b0b527
restore elcontracts writer imports
TomasArrachea Dec 6, 2024
0501cac
update map_to_curve and sign_message tests
TomasArrachea Dec 6, 2024
5779918
write token addres to json on deployement
TomasArrachea Dec 6, 2024
1b955a1
replace token address with harcoded one
TomasArrachea Dec 6, 2024
fcddb6d
test_compliance_bls_signature with the same data as Go SDK
pablodeymo Dec 6, 2024
42cca06
test with hardcoded merkle root and claim
TomasArrachea Dec 6, 2024
105db21
use 0.8 for alloy-primitives (#175)
supernovahs Dec 8, 2024
db1978e
update anvil state json
TomasArrachea Dec 9, 2024
891c5de
add submit rewards root for tests
TomasArrachea Dec 9, 2024
35c3365
test name changed to test_bls_signature
pablodeymo Dec 9, 2024
a334a2c
fix deposit erc20 test
TomasArrachea Dec 9, 2024
b4c15b0
Merge branch 'fix_signature' into slashing
TomasArrachea Dec 9, 2024
b69d961
restore middleware rev
TomasArrachea Dec 10, 2024
ac48e08
Merge branch 'main' into slashing
pablodeymo Dec 11, 2024
3f9f370
update anvil state
TomasArrachea Dec 10, 2024
70a2356
wip add test register bls key
TomasArrachea Dec 10, 2024
3ebad16
remove logs
TomasArrachea Dec 12, 2024
c2f7eca
add allocation manager address to mockAvs deploy
TomasArrachea Dec 12, 2024
bb799d5
setSlashableStakeLookahead when deploying avs
TomasArrachea Dec 12, 2024
a8e296d
remove debug prints
TomasArrachea Dec 12, 2024
b86f00e
fix test register operator
TomasArrachea Dec 13, 2024
f9b50b2
update anvil state
TomasArrachea Dec 13, 2024
787360d
update middleware submodule to feat/slashing-release-branch
TomasArrachea Dec 13, 2024
e0b46a7
update deployment scripts
TomasArrachea Dec 13, 2024
3a9ab71
updated bindings
TomasArrachea Dec 13, 2024
7fa5c2a
fix bindings OperatorSet imports
TomasArrachea Dec 13, 2024
ceead5c
fix register operator and json keys
TomasArrachea Dec 16, 2024
40ad141
add pauserRegistry to deploy json
TomasArrachea Dec 16, 2024
ce647a4
update anvil dump state
TomasArrachea Dec 16, 2024
e4611f7
slashing fixes (#181)
supernovahs Dec 17, 2024
535670c
Add retries with exponential backoff to send transactions (#158)
TomasArrachea Dec 17, 2024
070d76d
query_registration_detail method (#162)
pablodeymo Dec 17, 2024
5a68213
remove deprecated get_operator_details method
TomasArrachea Dec 17, 2024
4f8a82d
nits
TomasArrachea Dec 17, 2024
7e1e9db
add slashing methods docs and tests
TomasArrachea Dec 17, 2024
ef5b9c2
fix slashing tests
TomasArrachea Dec 17, 2024
194a4a0
fix update operator test
TomasArrachea Dec 18, 2024
beae356
add get_slashable_shares method
TomasArrachea Dec 18, 2024
cb2a517
add can_call method and permission controller to ElContracts Reader
TomasArrachea Dec 18, 2024
8072e46
add list_appointees method
TomasArrachea Dec 18, 2024
f167d26
add list_appointee_permissions method
TomasArrachea Dec 18, 2024
0a91eea
add list_admins method
TomasArrachea Dec 18, 2024
7793c0b
add is_pending_admin method
TomasArrachea Dec 18, 2024
3824693
add is_admin method
TomasArrachea Dec 18, 2024
7e1f26b
add tests
TomasArrachea Dec 18, 2024
c0b65df
add debug
TomasArrachea Dec 18, 2024
382d69f
fix aggregator info test
TomasArrachea Dec 18, 2024
61ff3f2
remove_permission skeleton
pablodeymo Dec 18, 2024
6e8a150
add add_pending_admin and remove_pending_admin methods
TomasArrachea Dec 19, 2024
7556ad9
add accept_admin method
TomasArrachea Dec 19, 2024
6a31b45
add remove_admin method
TomasArrachea Dec 19, 2024
23c376c
add register_for_operator_sets method
TomasArrachea Dec 19, 2024
1cf06d7
add deregister_from_operator_sets method
TomasArrachea Dec 19, 2024
0635537
add set_allocation_delay method
TomasArrachea Dec 19, 2024
5e486a2
add modify_allocations method
TomasArrachea Dec 19, 2024
bde4a19
add set_permission method
TomasArrachea Dec 19, 2024
305a7ad
Fix Holesky RPC provider url (#184)
TomasArrachea Dec 19, 2024
7c4c5fa
lines in comments
pablodeymo Dec 19, 2024
f1bca11
remove_permission function in writer and lines in comments
pablodeymo Dec 19, 2024
f4b6b6f
Add clippy lints in Cargo.toml (#159)
pablodeymo Dec 19, 2024
7ceea9c
Fix operatorsinfo_inmemory tests
pablodeymo Dec 19, 2024
832d9bf
Blsagg logger (#154)
pablodeymo Dec 19, 2024
722a156
fix write/examples/register_operator_in_quorum_with_avs_registry_coor…
pablodeymo Dec 19, 2024
fadbe67
Remove logs in operatorsinfo test (#185)
TomasArrachea Dec 19, 2024
e5b362e
fix get_operator_info example
pablodeymo Dec 19, 2024
a24d2c5
Merge branch 'main' into slashing
TomasArrachea Dec 19, 2024
c89e96e
add slashing branch to CI
TomasArrachea Dec 19, 2024
aeeae03
remove test
TomasArrachea Dec 19, 2024
07dc094
restore bls tests expected values
TomasArrachea Dec 20, 2024
cfdd436
Test remove_permission
pablodeymo Dec 20, 2024
eb7b716
WIP test_register_for_operator_sets
pablodeymo Dec 20, 2024
1b977c1
refactor bls agg tests
TomasArrachea Dec 20, 2024
7576e99
refactoring bls agg tests
TomasArrachea Dec 20, 2024
cf48b48
add deposit into strategy on deployment
TomasArrachea Dec 23, 2024
c878a6b
fix test remove permission
TomasArrachea Dec 23, 2024
4b976ac
update anvil state
TomasArrachea Dec 23, 2024
135f28d
fmt
TomasArrachea Dec 23, 2024
56ab931
test_register_for_operator_sets
pablodeymo Dec 23, 2024
836496a
update deployment scripts to fund and register operators
TomasArrachea Dec 26, 2024
1eef053
refactor bls agg tests
TomasArrachea Dec 26, 2024
e035d12
remove register_operator_to_el_if_not_registered util
TomasArrachea Dec 26, 2024
c2f0434
clippy
TomasArrachea Dec 26, 2024
1433038
fix nonce on tx tests
TomasArrachea Dec 26, 2024
c54b510
update slashing tests expected values
TomasArrachea Dec 26, 2024
8e776e2
fix instrumented client test
TomasArrachea Dec 26, 2024
5882608
clippy
TomasArrachea Dec 26, 2024
584cbec
wip fixing register_for_operator_set
TomasArrachea Dec 27, 2024
988cd35
add modify allocations test
TomasArrachea Dec 30, 2024
ff2e06a
add pubkey registration params when register operator
TomasArrachea Dec 30, 2024
813ef2e
fix encoding for registration params
TomasArrachea Dec 30, 2024
206fb0f
update register_for_operator_sets and modify_allocation tests
TomasArrachea Dec 30, 2024
7f6705b
update operators info test
TomasArrachea Dec 30, 2024
a543ae9
update examples
TomasArrachea Dec 30, 2024
6ae5733
clippy
TomasArrachea Dec 30, 2024
81b648a
add operator sets test in bls agg (#188)
supernovahs Jan 3, 2025
cd88f3f
fix: test_bls_agg_operator_sets_enabled
Jan 3, 2025
ffad9a3
clippy
Jan 3, 2025
cace054
chore: remove line
MegaRedHand Jan 3, 2025
6281626
Merge branch 'dev' into slashing
MegaRedHand Jan 3, 2025
622352c
ci: run tests on all pull requests
MegaRedHand Jan 6, 2025
301d6c9
chore: remove chmod calls in Makefile
MegaRedHand Jan 6, 2025
13da50a
docs: add missing argument to function docs
MegaRedHand Jan 6, 2025
e8d712d
chore: remove unwrap
MegaRedHand Jan 6, 2025
3ee4c7f
chore: remove unwrap
MegaRedHand Jan 6, 2025
b8792b4
fix: sync `get_strategy_and_underlying_erc20_token` with Go SDK
MegaRedHand Jan 6, 2025
066be7f
chore: remove redundant var
MegaRedHand Jan 6, 2025
2f158ad
Revert "fix: sync `get_strategy_and_underlying_erc20_token` with Go SDK"
MegaRedHand Jan 6, 2025
ea52a92
feat: return contract bindings in `get_strategy_and_underlying_erc20_…
MegaRedHand Jan 6, 2025
b0e2066
feat: make `get_strategy_and_underlying_token` return contract binding
MegaRedHand Jan 6, 2025
3badfb1
fix: use signer provider
MegaRedHand Jan 6, 2025
f830c2a
chore: remove unwrap
MegaRedHand Jan 6, 2025
4b2284a
chore: rename list_appointee -> list_appointees
MegaRedHand Jan 6, 2025
7838f8a
chore: rename function to be same as Go SDK
MegaRedHand Jan 6, 2025
ab56695
chore: remove commented command
MegaRedHand Jan 6, 2025
0363cdd
fix: update paths used in contracts
MegaRedHand Jan 6, 2025
adfbd21
chore: remove stale comment
MegaRedHand Jan 6, 2025
0986564
chore: reintroduce sleep
MegaRedHand Jan 6, 2025
8bc7d45
refactor: move read functions from `ELChainWriter` to `ELChainReader`…
MegaRedHand Jan 7, 2025
45dfdeb
feat: add get and set `split` functions (#192)
MegaRedHand Jan 7, 2025
9c88c1c
feat: add `process_claims` function (#193)
MegaRedHand Jan 8, 2025
f82ad80
chore: use middleware's OpenZeppelin contracts (#199)
MegaRedHand Jan 8, 2025
366245b
bump metric-utils to 0.19and exporter prometheus to 0.16.1 (#198)
supernovahs Jan 8, 2025
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
5 changes: 1 addition & 4 deletions .github/workflows/integration.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,7 @@ on:
- main
- dev
pull_request:
branches:
- main
- dev
- slashing
branches: [ '**' ]

jobs:
build:
Expand Down
2 changes: 0 additions & 2 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,11 @@ deploy-eigenlayer:
./crates/contracts/anvil/deploy-eigenlayer.sh

deploy-avs:
chmod +x ./crates/contracts/anvil/deploy-avs.sh
./crates/contracts/anvil/deploy-avs.sh

deploy: deploy-eigenlayer deploy-avs ##

dump-state:
chmod +x ./crates/contracts/anvil/dump-state.sh
./crates/contracts/anvil/dump-state.sh

__TESTING__: ##
Expand Down
95 changes: 44 additions & 51 deletions crates/chainio/clients/elcontracts/src/reader.rs
Original file line number Diff line number Diff line change
@@ -1,15 +1,19 @@
use crate::error::ElContractsError;
use alloy::providers::Provider;
use alloy::{
providers::Provider,
transports::http::{Client, Http},
};
use alloy_primitives::{ruint::aliases::U256, Address, FixedBytes};
use eigen_logging::logger::SharedLogger;
use eigen_utils::{
allocationmanager::AllocationManager::{self, OperatorSet},
avsdirectory::AVSDirectory,
delegationmanager::DelegationManager,
erc20::ERC20,
erc20::ERC20::{self, ERC20Instance},
get_provider,
istrategy::IStrategy,
istrategy::IStrategy::{self, IStrategyInstance},
permissioncontroller::PermissionController,
SdkProvider,
};

#[derive(Debug, Clone)]
Expand All @@ -31,6 +35,7 @@ impl ELChainReader {
/// * `allocation_manager` - The address of the allocation manager contract.
/// * `delegation_manager` - The address of the delegation manager contract.
/// * `avs_directory` - The address of the avs directory contract.
/// * `permission_controller` - The address of the permission controller contract.
/// * `provider` - The provider to use for the RPC client.
///
/// # Returns
Expand Down Expand Up @@ -79,21 +84,19 @@ impl ELChainReader {

let contract_delegation_manager = DelegationManager::new(delegation_manager, provider);

let DelegationManager::allocationManagerReturn {
_0: allocation_manager,
} = contract_delegation_manager
let allocation_manager = contract_delegation_manager
.allocationManager()
.call()
.await
.unwrap();
.map_err(ElContractsError::AlloyContractError)?
._0;

let DelegationManager::permissionControllerReturn {
_0: permission_controller,
} = contract_delegation_manager
let permission_controller = contract_delegation_manager
.permissionController()
.call()
.await
.unwrap();
.map_err(ElContractsError::AlloyContractError)?
._0;

Ok(Self {
_logger,
Expand Down Expand Up @@ -240,28 +243,21 @@ impl ELChainReader {
pub async fn get_strategy_and_underlying_erc20_token(
&self,
strategy_addr: Address,
) -> Result<(Address, Address, Address), ElContractsError> {
let provider = get_provider(&self.provider);

let contract_strategy = IStrategy::new(strategy_addr, &provider);

let underlying_token = contract_strategy
.underlyingToken()
.call()
.await
.map_err(ElContractsError::AlloyContractError)?;

let IStrategy::underlyingTokenReturn {
_0: underlying_token_addr,
} = underlying_token;
) -> Result<
(
IStrategyInstance<Http<Client>, SdkProvider>,
ERC20Instance<Http<Client>, SdkProvider>,
Address,
),
ElContractsError,
> {
let (contract_strategy, underlying_token) = self
.get_strategy_and_underlying_token(strategy_addr)
.await?;

let contract_ierc20 = ERC20::new(underlying_token_addr, &provider);
let token_contract = ERC20::new(underlying_token, contract_strategy.provider().to_owned());

Ok((
strategy_addr,
*contract_ierc20.address(),
underlying_token_addr,
))
Ok((contract_strategy, token_contract, underlying_token))
}

/// Check if the operator is registered
Expand Down Expand Up @@ -289,10 +285,10 @@ impl ELChainReader {
.isOperator(operator)
.call()
.await
.map_err(ElContractsError::AlloyContractError)?;
.map_err(ElContractsError::AlloyContractError)?
._0;

let DelegationManager::isOperatorReturn { _0: is_operator_is } = is_operator;
Ok(is_operator_is)
Ok(is_operator)
}

/// Get the staker's shares in all of the strategies in which they have nonzero shares
Expand Down Expand Up @@ -374,23 +370,19 @@ impl ELChainReader {
pub async fn get_strategy_and_underlying_token(
&self,
strategy_addr: Address,
) -> Result<(Address, Address), ElContractsError> {
) -> Result<(IStrategyInstance<Http<Client>, SdkProvider>, Address), ElContractsError> {
let provider = get_provider(&self.provider);

let contract_strategy = IStrategy::new(strategy_addr, &provider);
let contract_strategy_address = contract_strategy.address();
let contract_strategy = IStrategy::new(strategy_addr, provider);

let underlying_token = contract_strategy
.underlyingToken()
.call()
.await
.map_err(ElContractsError::AlloyContractError)?;

let IStrategy::underlyingTokenReturn {
_0: underlying_token_addr,
} = underlying_token;
.map_err(ElContractsError::AlloyContractError)?
._0;

Ok((*contract_strategy_address, underlying_token_addr))
Ok((contract_strategy, underlying_token))
}

/// For a strategy, get the amount of magnitude not currently allocated to any operator set
Expand Down Expand Up @@ -472,8 +464,7 @@ impl ELChainReader {
.getStrategyAllocations(operator_address, strategy_address)
.call()
.await
.map_err(ElContractsError::AlloyContractError)
.unwrap();
.map_err(ElContractsError::AlloyContractError)?;

let AllocationManager::getStrategyAllocationsReturn {
_0: operator_sets,
Expand Down Expand Up @@ -775,7 +766,7 @@ impl ELChainReader {
let current_block_number = provider.get_block_number().await.map_err(|e| {
ElContractsError::AlloyContractError(alloy::contract::Error::TransportError(e))
})?;
self.get_delegated_and_slashable_shares_for_operator_sets_before(
self.get_slashable_shares_for_operator_sets_before(
operator_sets,
current_block_number as u32,
)
Expand All @@ -794,7 +785,7 @@ impl ELChainReader {
/// * `Vec<OperatorSetStakes>` - The operator sets, their strategies, operators, and slashable stakes
/// # Errors
/// * `ElContractsError` - if the call to the contract fails
pub async fn get_delegated_and_slashable_shares_for_operator_sets_before(
pub async fn get_slashable_shares_for_operator_sets_before(
&self,
operator_sets: Vec<OperatorSet>,
future_block: u32,
Expand Down Expand Up @@ -940,7 +931,7 @@ impl ELChainReader {
/// * `Vec<Address>` - The list of appointees
/// # Errors
/// * `ElContractsError` - if the call to the contract fails
pub async fn list_appointee(
pub async fn list_appointees(
&self,
account_address: Address,
target: Address,
Expand Down Expand Up @@ -1104,6 +1095,8 @@ impl ELChainReader {
}

// TODO: move to types.rs?

#[derive(Debug, Clone)]
pub struct OperatorSetStakes {
pub operator_set: OperatorSet,
pub strategies: Vec<Address>,
Expand Down Expand Up @@ -1317,7 +1310,7 @@ mod tests {
"0x36C02dA8a0983159322a80FFE9F24b1acfF8B570"
);

let strategy_contract_addr_str = strategy_contract_addr.to_string();
let strategy_contract_addr_str = strategy_contract_addr.address().to_string();
assert_eq!(
strategy_contract_addr_str,
"0xeC4cFde48EAdca2bC63E94BB437BbeAcE1371bF3"
Expand Down Expand Up @@ -1545,7 +1538,7 @@ mod tests {
.await
.unwrap() as u32;
let slashable_shares = chain_reader
.get_delegated_and_slashable_shares_for_operator_sets_before(
.get_slashable_shares_for_operator_sets_before(
vec![operator_set],
current_block_number + 1,
)
Expand Down Expand Up @@ -1592,7 +1585,7 @@ mod tests {
let target = Address::ZERO;
let selector = FixedBytes::from([0x00; 4]);
let appointees = chain_reader
.list_appointee(OPERATOR_ADDRESS, target, selector)
.list_appointees(OPERATOR_ADDRESS, target, selector)
.await
.unwrap();

Expand Down
12 changes: 5 additions & 7 deletions crates/chainio/clients/elcontracts/src/writer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -179,23 +179,21 @@ impl ELChainWriter {
amount: U256,
) -> Result<TxHash, ElContractsError> {
info!("depositing {amount:?} tokens into strategy {strategy_addr:?}");
let tokens = self
let (_strategy, token_address) = self
.el_chain_reader
.get_strategy_and_underlying_erc20_token(strategy_addr)
.get_strategy_and_underlying_token(strategy_addr)
.await?;
let (_, underlying_token_contract, underlying_token) = tokens;
let provider = get_signer(&self.signer.clone(), &self.provider);
let token_contract = ERC20::new(token_address, &provider);

let contract_underlying_token = ERC20::new(underlying_token_contract, &provider);

let contract_call = contract_underlying_token.approve(self.strategy_manager, amount);
let contract_call = token_contract.approve(self.strategy_manager, amount);

let _approve = contract_call.send().await?;

let contract_strategy_manager = StrategyManager::new(self.strategy_manager, &provider);

let deposit_contract_call =
contract_strategy_manager.depositIntoStrategy(strategy_addr, underlying_token, amount);
contract_strategy_manager.depositIntoStrategy(strategy_addr, token_address, amount);

let tx = deposit_contract_call.send().await?;

Expand Down
3 changes: 0 additions & 3 deletions crates/contracts/anvil/deploy-avs.sh
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,3 @@ cd ../
forge script script/DeployMockAvs.s.sol --rpc-url $RPC_URL --private-key $DEPLOYER_PRIVATE_KEY --broadcast --slow -vvv

forge script script/ContractsRegistry.s.sol --rpc-url $RPC_URL --private-key $DEPLOYER_PRIVATE_KEY --broadcast --slow


# forge script script/SetupPayments.s.sol --rpc-url $RPC_URL --broadcast --slow --private-key $PRIVATE_KEY
2 changes: 1 addition & 1 deletion crates/contracts/anvil/dump-state.sh
Original file line number Diff line number Diff line change
Expand Up @@ -34,4 +34,4 @@ set +a

# start an empty anvil chain in the background and dump its state to a json file upon exit
start_anvil_docker "" $anvil_dir/dump_state.json
sleep 1
sleep 1
14 changes: 2 additions & 12 deletions crates/contracts/anvil/utils.sh
100644 → 100755
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
#!/bin/bash


# pinning at old foundry commit because of https://github.com/foundry-rs/foundry/issues/7502
FOUNDRY_IMAGE=ghcr.io/foundry-rs/foundry:latest

set -e -o nounset
Expand Down Expand Up @@ -32,19 +30,11 @@ start_anvil_docker() {
DUMP_STATE_ANVIL_ARG=$([[ -z $DUMP_STATE_FILE ]] && echo "" || echo "--dump-state /dump-state.json")

trap 'docker stop anvil 2>/dev/null || true' EXIT
docker run --name anvil -p 8545:8545 $LOAD_STATE_VOLUME_DOCKER_ARG $DUMP_STATE_VOLUME_DOCKER_ARG \
docker run -d --name anvil -p 8545:8545 $LOAD_STATE_VOLUME_DOCKER_ARG $DUMP_STATE_VOLUME_DOCKER_ARG \
--entrypoint anvil \
$FOUNDRY_IMAGE \
$LOAD_STATE_ANVIL_ARG $DUMP_STATE_ANVIL_ARG --host 0.0.0.0 -v \
--base-fee 0
sleep 2
docker attach anvil
}









6 changes: 3 additions & 3 deletions crates/contracts/foundry.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,16 @@
src = "src"
out = "out"
libs = ["lib"]
fs_permissions = [{ access = "read-write", path = "./"}]
fs_permissions = [{ access = "read-write", path = "./" }]
solc = "0.8.27"
via-ir = true

remappings = [
"@eigenlayer/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/src/",
"@eigenlayer-scripts/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/script/",
"@eigenlayer-middleware/=lib/eigenlayer-middleware/",
"@openzeppelin/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/lib/openzeppelin-contracts/",
"@openzeppelin-upgrades/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/lib/openzeppelin-contracts-upgradeable/",
"@openzeppelin/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/lib/openzeppelin-contracts-v4.9.0/",
supernovahs marked this conversation as resolved.
Show resolved Hide resolved
"@openzeppelin-upgrades/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/lib/openzeppelin-contracts-upgradeable-v4.9.0/",
"forge-std/=lib/forge-std/src/",
]

Expand Down
6 changes: 3 additions & 3 deletions crates/contracts/remappings.txt
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
@eigenlayer/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/src/
@eigenlayer-scripts/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/script/
@eigenlayer-middleware/=lib/eigenlayer-middleware/
@openzeppelin/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/lib/openzeppelin-contracts/
@openzeppelin-upgrades/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/lib/openzeppelin-contracts-upgradeable/
@openzeppelin/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/lib/openzeppelin-contracts-v4.9.0/
@openzeppelin-upgrades/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/lib/openzeppelin-contracts-upgradeable-v4.9.0/
forge-std/=lib/forge-std/src/
ds-test/=lib/eigenlayer-middleware/lib/ds-test/src/
eigenlayer-contracts/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/
Expand All @@ -12,4 +12,4 @@ openzeppelin-contracts-upgradeable-v4.9.0/=lib/eigenlayer-middleware/lib/eigenla
openzeppelin-contracts-upgradeable/=lib/eigenlayer-middleware/lib/openzeppelin-contracts-upgradeable/
openzeppelin-contracts-v4.9.0/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/lib/openzeppelin-contracts-v4.9.0/
openzeppelin-contracts/=lib/eigenlayer-middleware/lib/openzeppelin-contracts/
openzeppelin/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/lib/openzeppelin-contracts-upgradeable-v4.9.0/contracts/
openzeppelin/=lib/eigenlayer-middleware/lib/eigenlayer-contracts/lib/openzeppelin-contracts-upgradeable-v4.9.0/contracts/
6 changes: 3 additions & 3 deletions crates/contracts/script/utils/UpgradeableProxyLib.sol
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ pragma solidity ^0.8.12;

import {Vm} from "forge-std/Vm.sol";
import {ProxyAdmin} from "@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol";
import {TransparentUpgradeableProxy} from "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol";
import {TransparentUpgradeableProxy, ITransparentUpgradeableProxy} from "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol";
import {EmptyContract} from "@eigenlayer/test/mocks/EmptyContract.sol";

library UpgradeableProxyLib {
Expand All @@ -27,7 +27,7 @@ library UpgradeableProxyLib {

function upgrade(address proxy, address impl) internal {
ProxyAdmin admin = getProxyAdmin(proxy);
admin.upgrade(TransparentUpgradeableProxy(payable(proxy)), impl);
admin.upgrade(ITransparentUpgradeableProxy(payable(proxy)), impl);
}

function upgradeAndCall(
Expand All @@ -37,7 +37,7 @@ library UpgradeableProxyLib {
) internal {
ProxyAdmin admin = getProxyAdmin(proxy);
admin.upgradeAndCall(
TransparentUpgradeableProxy(payable(proxy)),
ITransparentUpgradeableProxy(payable(proxy)),
impl,
initData
);
Expand Down
1 change: 0 additions & 1 deletion crates/metrics/src/prometheus.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@ pub fn init_registry(socket_addr: SocketAddr) {
}

#[cfg(test)]

mod tests {
use std::collections::HashMap;

Expand Down
Loading
Loading