From b81273596c7ac9468c3eeadb93d5c85535ee1e78 Mon Sep 17 00:00:00 2001 From: Madhur Shrimal Date: Wed, 26 Jun 2024 16:56:26 -0700 Subject: [PATCH 1/4] add set claimer for --- chainio/clients/builder.go | 5 ++- chainio/clients/elcontracts/bindings.go | 54 ++++++++++++++++--------- chainio/clients/elcontracts/reader.go | 24 +++++------ chainio/clients/elcontracts/writer.go | 51 ++++++++++++++++++++--- 4 files changed, 96 insertions(+), 38 deletions(-) diff --git a/chainio/clients/builder.go b/chainio/clients/builder.go index b082a566..e5033f1f 100644 --- a/chainio/clients/builder.go +++ b/chainio/clients/builder.go @@ -175,11 +175,11 @@ func (config *BuildAllConfig) BuildELClients( delegationManagerAddr, err := avsRegistryContractBindings.StakeRegistry.Delegation(&bind.CallOpts{}) if err != nil { - logger.Fatal("Failed to fetch Slasher contract", "err", err) + logger.Fatal("Failed to fetch DelegationManager contract", "err", err) } avsDirectoryAddr, err := avsRegistryContractBindings.ServiceManager.AvsDirectory(&bind.CallOpts{}) if err != nil { - logger.Fatal("Failed to fetch Slasher contract", "err", err) + logger.Fatal("Failed to fetch AVSDirectory contract", "err", err) } elContractBindings, err := config.buildEigenLayerContractBindings( @@ -206,6 +206,7 @@ func (config *BuildAllConfig) BuildELClients( elContractBindings.Slasher, elContractBindings.DelegationManager, elContractBindings.StrategyManager, + nil, elContractBindings.StrategyManagerAddr, elChainReader, ethHttpClient, diff --git a/chainio/clients/elcontracts/bindings.go b/chainio/clients/elcontracts/bindings.go index 2896a691..9c85d843 100644 --- a/chainio/clients/elcontracts/bindings.go +++ b/chainio/clients/elcontracts/bindings.go @@ -9,6 +9,7 @@ import ( "github.com/Layr-Labs/eigensdk-go/chainio/clients/eth" avsdirectory "github.com/Layr-Labs/eigensdk-go/contracts/bindings/AVSDirectory" delegationmanager "github.com/Layr-Labs/eigensdk-go/contracts/bindings/DelegationManager" + rewardscoordinator "github.com/Layr-Labs/eigensdk-go/contracts/bindings/IRewardsCoordinator" slasher "github.com/Layr-Labs/eigensdk-go/contracts/bindings/ISlasher" strategymanager "github.com/Layr-Labs/eigensdk-go/contracts/bindings/StrategyManager" "github.com/Layr-Labs/eigensdk-go/logging" @@ -20,14 +21,16 @@ import ( // Unclear why geth bindings don't store and expose the contract address, // so we also store them here in case the different constructors that use this struct need them type ContractBindings struct { - SlasherAddr gethcommon.Address - StrategyManagerAddr gethcommon.Address - DelegationManagerAddr gethcommon.Address - AvsDirectoryAddr gethcommon.Address - Slasher *slasher.ContractISlasher - DelegationManager *delegationmanager.ContractDelegationManager - StrategyManager *strategymanager.ContractStrategyManager - AvsDirectory *avsdirectory.ContractAVSDirectory + SlasherAddr gethcommon.Address + StrategyManagerAddr gethcommon.Address + DelegationManagerAddr gethcommon.Address + AvsDirectoryAddr gethcommon.Address + RewardsCoordinatorAddress gethcommon.Address + Slasher *slasher.ContractISlasher + DelegationManager *delegationmanager.ContractDelegationManager + StrategyManager *strategymanager.ContractStrategyManager + AvsDirectory *avsdirectory.ContractAVSDirectory + RewardsCoordinator *rewardscoordinator.ContractIRewardsCoordinator } func NewBindingsFromConfig( @@ -41,9 +44,10 @@ func NewBindingsFromConfig( var slasherAddr gethcommon.Address var strategyManagerAddr gethcommon.Address var avsDirectory *avsdirectory.ContractAVSDirectory + var rewardsCoordinator *rewardscoordinator.ContractIRewardsCoordinator var err error - if gethcommon.IsHexAddress(cfg.DelegationManagerAddress.String()) { + if isZeroAddress(cfg.DelegationManagerAddress) { logger.Warn("DelegationManager address not provided, the calls to the contract will not work") } else { contractDelegationManager, err = delegationmanager.NewContractDelegationManager(cfg.DelegationManagerAddress, client) @@ -70,7 +74,7 @@ func NewBindingsFromConfig( } } - if gethcommon.IsHexAddress(cfg.AvsDirectoryAddress.String()) { + if isZeroAddress(cfg.AvsDirectoryAddress) { logger.Warn("AVSDirectory address not provided, the calls to the contract will not work") } else { avsDirectory, err = avsdirectory.NewContractAVSDirectory(cfg.AvsDirectoryAddress, client) @@ -79,17 +83,31 @@ func NewBindingsFromConfig( } } + if isZeroAddress(cfg.RewardsCoordinatorAddress) { + logger.Warn("RewardsCoordinator address not provided, the calls to the contract will not work") + } else { + rewardsCoordinator, err = rewardscoordinator.NewContractIRewardsCoordinator(cfg.RewardsCoordinatorAddress, client) + if err != nil { + return nil, utils.WrapError("Failed to fetch RewardsCoordinator contract", err) + } + } + return &ContractBindings{ - SlasherAddr: slasherAddr, - StrategyManagerAddr: strategyManagerAddr, - DelegationManagerAddr: cfg.DelegationManagerAddress, - AvsDirectoryAddr: cfg.AvsDirectoryAddress, - Slasher: contractSlasher, - StrategyManager: contractStrategyManager, - DelegationManager: contractDelegationManager, - AvsDirectory: avsDirectory, + SlasherAddr: slasherAddr, + StrategyManagerAddr: strategyManagerAddr, + DelegationManagerAddr: cfg.DelegationManagerAddress, + AvsDirectoryAddr: cfg.AvsDirectoryAddress, + RewardsCoordinatorAddress: cfg.RewardsCoordinatorAddress, + Slasher: contractSlasher, + StrategyManager: contractStrategyManager, + DelegationManager: contractDelegationManager, + AvsDirectory: avsDirectory, + RewardsCoordinator: rewardsCoordinator, }, nil } +func isZeroAddress(address gethcommon.Address) bool { + return address == gethcommon.Address{} +} // NewEigenlayerContractBindings creates a new ContractBindings struct with the provided contract addresses // Deprecated: Use NewBindingsFromConfig instead diff --git a/chainio/clients/elcontracts/reader.go b/chainio/clients/elcontracts/reader.go index 3e6efb07..ee9de49c 100644 --- a/chainio/clients/elcontracts/reader.go +++ b/chainio/clients/elcontracts/reader.go @@ -9,16 +9,15 @@ import ( gethcommon "github.com/ethereum/go-ethereum/common" "github.com/Layr-Labs/eigensdk-go/chainio/clients/eth" - "github.com/Layr-Labs/eigensdk-go/logging" - "github.com/Layr-Labs/eigensdk-go/types" - "github.com/Layr-Labs/eigensdk-go/utils" - avsdirectory "github.com/Layr-Labs/eigensdk-go/contracts/bindings/AVSDirectory" delegationmanager "github.com/Layr-Labs/eigensdk-go/contracts/bindings/DelegationManager" erc20 "github.com/Layr-Labs/eigensdk-go/contracts/bindings/IERC20" slasher "github.com/Layr-Labs/eigensdk-go/contracts/bindings/ISlasher" strategy "github.com/Layr-Labs/eigensdk-go/contracts/bindings/IStrategy" strategymanager "github.com/Layr-Labs/eigensdk-go/contracts/bindings/StrategyManager" + "github.com/Layr-Labs/eigensdk-go/logging" + "github.com/Layr-Labs/eigensdk-go/types" + "github.com/Layr-Labs/eigensdk-go/utils" ) type ELReader interface { @@ -62,16 +61,17 @@ type ELReader interface { } type Config struct { - DelegationManagerAddress common.Address - AvsDirectoryAddress common.Address + DelegationManagerAddress common.Address + AvsDirectoryAddress common.Address + RewardsCoordinatorAddress common.Address } type ELChainReader struct { logger logging.Logger slasher slasher.ContractISlasherCalls - delegationManager delegationmanager.ContractDelegationManagerCalls - strategyManager strategymanager.ContractStrategyManagerCalls - avsDirectory avsdirectory.ContractAVSDirectoryCalls + delegationManager *delegationmanager.ContractDelegationManager + strategyManager *strategymanager.ContractStrategyManager + avsDirectory *avsdirectory.ContractAVSDirectory ethClient eth.Client } @@ -80,9 +80,9 @@ var _ ELReader = (*ELChainReader)(nil) func NewELChainReader( slasher slasher.ContractISlasherCalls, - delegationManager delegationmanager.ContractDelegationManagerCalls, - strategyManager strategymanager.ContractStrategyManagerCalls, - avsDirectory avsdirectory.ContractAVSDirectoryCalls, + delegationManager *delegationmanager.ContractDelegationManager, + strategyManager *strategymanager.ContractStrategyManager, + avsDirectory *avsdirectory.ContractAVSDirectory, logger logging.Logger, ethClient eth.Client, ) *ELChainReader { diff --git a/chainio/clients/elcontracts/writer.go b/chainio/clients/elcontracts/writer.go index a0cfbf53..aa44dc38 100644 --- a/chainio/clients/elcontracts/writer.go +++ b/chainio/clients/elcontracts/writer.go @@ -3,6 +3,7 @@ package elcontracts import ( "context" "errors" + "math/big" "github.com/ethereum/go-ethereum/accounts/abi/bind" @@ -12,6 +13,7 @@ import ( "github.com/Layr-Labs/eigensdk-go/chainio/clients/eth" "github.com/Layr-Labs/eigensdk-go/chainio/txmgr" delegationmanager "github.com/Layr-Labs/eigensdk-go/contracts/bindings/DelegationManager" + rewardscoordinator "github.com/Layr-Labs/eigensdk-go/contracts/bindings/IRewardsCoordinator" slasher "github.com/Layr-Labs/eigensdk-go/contracts/bindings/ISlasher" strategymanager "github.com/Layr-Labs/eigensdk-go/contracts/bindings/StrategyManager" "github.com/Layr-Labs/eigensdk-go/logging" @@ -36,12 +38,18 @@ type ELWriter interface { strategyAddr gethcommon.Address, amount *big.Int, ) (*gethtypes.Receipt, error) + + SetClaimerFor( + ctx context.Context, + claimer gethcommon.Address, + ) (*gethtypes.Receipt, error) } type ELChainWriter struct { - slasher slasher.ContractISlasherTransacts - delegationManager delegationmanager.ContractDelegationManagerTransacts - strategyManager strategymanager.ContractStrategyManagerTransacts + slasher *slasher.ContractISlasher + delegationManager *delegationmanager.ContractDelegationManager + strategyManager *strategymanager.ContractStrategyManager + rewardsCoordinator *rewardscoordinator.ContractIRewardsCoordinator strategyManagerAddr gethcommon.Address elChainReader ELReader ethClient eth.Client @@ -52,9 +60,10 @@ type ELChainWriter struct { var _ ELWriter = (*ELChainWriter)(nil) func NewELChainWriter( - slasher slasher.ContractISlasherTransacts, - delegationManager delegationmanager.ContractDelegationManagerTransacts, - strategyManager strategymanager.ContractStrategyManagerTransacts, + slasher *slasher.ContractISlasher, + delegationManager *delegationmanager.ContractDelegationManager, + strategyManager *strategymanager.ContractStrategyManager, + rewardsCoordinator *rewardscoordinator.ContractIRewardsCoordinator, strategyManagerAddr gethcommon.Address, elChainReader ELReader, ethClient eth.Client, @@ -69,6 +78,7 @@ func NewELChainWriter( delegationManager: delegationManager, strategyManager: strategyManager, strategyManagerAddr: strategyManagerAddr, + rewardsCoordinator: rewardsCoordinator, elChainReader: elChainReader, logger: logger, ethClient: ethClient, @@ -107,6 +117,7 @@ func BuildELChainWriter( elContractBindings.Slasher, elContractBindings.DelegationManager, elContractBindings.StrategyManager, + nil, elContractBindings.StrategyManagerAddr, elChainReader, ethClient, @@ -143,6 +154,7 @@ func NewWriterFromConfig( elContractBindings.Slasher, elContractBindings.DelegationManager, elContractBindings.StrategyManager, + elContractBindings.RewardsCoordinator, elContractBindings.StrategyManagerAddr, elChainReader, ethClient, @@ -290,3 +302,30 @@ func (w *ELChainWriter) DepositERC20IntoStrategy( w.logger.Infof("deposited %s into strategy %s", amount.String(), strategyAddr) return receipt, nil } + +func (w *ELChainWriter) SetClaimerFor( + ctx context.Context, + claimer gethcommon.Address, +) (*gethtypes.Receipt, error) { + if w.rewardsCoordinator == nil { + return nil, errors.New("RewardsCoordinator contract not provided") + } + + w.logger.Infof("setting claimer %s", claimer) + noSendTxOpts, err := w.txMgr.GetNoSendTxOpts() + if err != nil { + return nil, err + } + + tx, err := w.rewardsCoordinator.SetClaimerFor(noSendTxOpts, claimer) + if err != nil { + return nil, err + } + receipt, err := w.txMgr.Send(ctx, tx) + if err != nil { + return nil, errors.New("failed to send tx with err: " + err.Error()) + } + + w.logger.Infof("set claimer %s successful", claimer) + return receipt, nil +} From aa18aee1161660ff642ceae600eed3b1a8515a41 Mon Sep 17 00:00:00 2001 From: Madhur Shrimal Date: Wed, 26 Jun 2024 17:00:51 -0700 Subject: [PATCH 2/4] add mocks --- chainio/mocks/elContractsWriter.go | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/chainio/mocks/elContractsWriter.go b/chainio/mocks/elContractsWriter.go index 5b5af23d..f497184f 100644 --- a/chainio/mocks/elContractsWriter.go +++ b/chainio/mocks/elContractsWriter.go @@ -73,6 +73,21 @@ func (mr *MockELWriterMockRecorder) RegisterAsOperator(arg0, arg1 any) *gomock.C return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "RegisterAsOperator", reflect.TypeOf((*MockELWriter)(nil).RegisterAsOperator), arg0, arg1) } +// SetClaimerFor mocks base method. +func (m *MockELWriter) SetClaimerFor(arg0 context.Context, arg1 common.Address) (*types0.Receipt, error) { + m.ctrl.T.Helper() + ret := m.ctrl.Call(m, "SetClaimerFor", arg0, arg1) + ret0, _ := ret[0].(*types0.Receipt) + ret1, _ := ret[1].(error) + return ret0, ret1 +} + +// SetClaimerFor indicates an expected call of SetClaimerFor. +func (mr *MockELWriterMockRecorder) SetClaimerFor(arg0, arg1 any) *gomock.Call { + mr.mock.ctrl.T.Helper() + return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "SetClaimerFor", reflect.TypeOf((*MockELWriter)(nil).SetClaimerFor), arg0, arg1) +} + // UpdateMetadataURI mocks base method. func (m *MockELWriter) UpdateMetadataURI(arg0 context.Context, arg1 string) (*types0.Receipt, error) { m.ctrl.T.Helper() From 599a3176240a861d0d3986348b300a784e596666 Mon Sep 17 00:00:00 2001 From: Madhur Shrimal Date: Wed, 26 Jun 2024 17:41:46 -0700 Subject: [PATCH 3/4] remove logs and send error --- chainio/clients/elcontracts/writer.go | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/chainio/clients/elcontracts/writer.go b/chainio/clients/elcontracts/writer.go index aa44dc38..a2e93bee 100644 --- a/chainio/clients/elcontracts/writer.go +++ b/chainio/clients/elcontracts/writer.go @@ -3,6 +3,7 @@ package elcontracts import ( "context" "errors" + "github.com/Layr-Labs/eigensdk-go/utils" "math/big" @@ -311,7 +312,6 @@ func (w *ELChainWriter) SetClaimerFor( return nil, errors.New("RewardsCoordinator contract not provided") } - w.logger.Infof("setting claimer %s", claimer) noSendTxOpts, err := w.txMgr.GetNoSendTxOpts() if err != nil { return nil, err @@ -323,9 +323,8 @@ func (w *ELChainWriter) SetClaimerFor( } receipt, err := w.txMgr.Send(ctx, tx) if err != nil { - return nil, errors.New("failed to send tx with err: " + err.Error()) + return nil, utils.WrapError("failed to send tx", err) } - w.logger.Infof("set claimer %s successful", claimer) return receipt, nil } From 7110a2a1af0d56c03fe7bbea16e30f52e33b904f Mon Sep 17 00:00:00 2001 From: Madhur Shrimal Date: Wed, 26 Jun 2024 17:44:27 -0700 Subject: [PATCH 4/4] add comment --- chainio/clients/builder.go | 2 +- chainio/clients/elcontracts/writer.go | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/chainio/clients/builder.go b/chainio/clients/builder.go index e5033f1f..b17673a4 100644 --- a/chainio/clients/builder.go +++ b/chainio/clients/builder.go @@ -206,7 +206,7 @@ func (config *BuildAllConfig) BuildELClients( elContractBindings.Slasher, elContractBindings.DelegationManager, elContractBindings.StrategyManager, - nil, + nil, // this is nil because we don't have access to the rewards coordinator contract right now. we are going to refactor this method later elContractBindings.StrategyManagerAddr, elChainReader, ethHttpClient, diff --git a/chainio/clients/elcontracts/writer.go b/chainio/clients/elcontracts/writer.go index a2e93bee..6c95468a 100644 --- a/chainio/clients/elcontracts/writer.go +++ b/chainio/clients/elcontracts/writer.go @@ -3,6 +3,7 @@ package elcontracts import ( "context" "errors" + "github.com/Layr-Labs/eigensdk-go/utils" "math/big"