From e2330477573b70e75ea56c4b0c459067a67e8b47 Mon Sep 17 00:00:00 2001 From: Samuel Laferriere Date: Thu, 24 Oct 2024 22:46:30 +0100 Subject: [PATCH] fix: fetch quorum parameters from edasm at RBN instead of latest block (#190) * fix: fetch quorum parameters from edasm at RBN instead of latest block * docs: fix getQuorumAdversaryThreshold comment --- verify/verifier.go | 20 ++++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) diff --git a/verify/verifier.go b/verify/verifier.go index 5e374f0f..e42d3375 100644 --- a/verify/verifier.go +++ b/verify/verifier.go @@ -2,10 +2,12 @@ package verify import ( "fmt" + "math/big" "github.com/consensys/gnark-crypto/ecc" "github.com/consensys/gnark-crypto/ecc/bn254" "github.com/consensys/gnark-crypto/ecc/bn254/fp" + "github.com/ethereum/go-ethereum/accounts/abi/bind" "github.com/ethereum/go-ethereum/log" binding "github.com/Layr-Labs/eigenda/contracts/bindings/EigenDAServiceManager" @@ -149,8 +151,10 @@ func (v *Verifier) VerifySecurityParams(blobHeader BlobHeader, batchHeader bindi if blobHeader.QuorumBlobParams[i].AdversaryThresholdPercentage > blobHeader.QuorumBlobParams[i].ConfirmationThresholdPercentage { return fmt.Errorf("adversary threshold percentage must be greater than or equal to confirmation threshold percentage") } - - quorumAdversaryThreshold, err := v.getQuorumAdversaryThreshold(blobHeader.QuorumBlobParams[i].QuorumNumber) + // we get the quorum adversary threshold at the batch's reference block number. This is not strictly needed right now + // since this threshold is hardcoded into the contract: https://github.com/Layr-Labs/eigenda/blob/master/contracts/src/core/EigenDAServiceManagerStorage.sol + // but it is good practice in case the contract changes in the future + quorumAdversaryThreshold, err := v.getQuorumAdversaryThreshold(blobHeader.QuorumBlobParams[i].QuorumNumber, int64(batchHeader.ReferenceBlockNumber)) if err != nil { log.Warn("failed to get quorum adversary threshold", "err", err) } @@ -166,9 +170,9 @@ func (v *Verifier) VerifySecurityParams(blobHeader BlobHeader, batchHeader bindi confirmedQuorums[blobHeader.QuorumBlobParams[i].QuorumNumber] = true } - requiredQuorums, err := v.cv.manager.QuorumNumbersRequired(nil) + requiredQuorums, err := v.cv.manager.QuorumNumbersRequired(&bind.CallOpts{BlockNumber: big.NewInt(int64(batchHeader.ReferenceBlockNumber))}) if err != nil { - log.Warn("failed to get required quorum numbers", "err", err) + log.Warn("failed to get required quorum numbers at block number", "err", err, "referenceBlockNumber", batchHeader.ReferenceBlockNumber) } // ensure that required quorums are present in the confirmed ones @@ -181,10 +185,10 @@ func (v *Verifier) VerifySecurityParams(blobHeader BlobHeader, batchHeader bindi return nil } -// getQuorumAdversaryThreshold reads the adversarial threshold percentage for a given quorum number -// returns 0 if DNE -func (v *Verifier) getQuorumAdversaryThreshold(quorumNum uint8) (uint8, error) { - percentages, err := v.cv.manager.QuorumAdversaryThresholdPercentages(nil) +// getQuorumAdversaryThreshold reads the adversarial threshold percentage for a given quorum number, +// at a given block number. If the quorum number does not exist, it returns 0. +func (v *Verifier) getQuorumAdversaryThreshold(quorumNum uint8, blockNumber int64) (uint8, error) { + percentages, err := v.cv.manager.QuorumAdversaryThresholdPercentages(&bind.CallOpts{BlockNumber: big.NewInt(blockNumber)}) if err != nil { return 0, err }