From bef16d69e390be29e00ed93a7fb0aaafeb43a18d Mon Sep 17 00:00:00 2001 From: Patrick Schork <354473+pschork@users.noreply.github.com> Date: Mon, 28 Oct 2024 10:40:07 -0700 Subject: [PATCH] Normalize config allowlist to use lowercased account keys --- disperser/apiserver/config.go | 7 +++++-- disperser/apiserver/server.go | 13 +++---------- 2 files changed, 8 insertions(+), 12 deletions(-) diff --git a/disperser/apiserver/config.go b/disperser/apiserver/config.go index a4121427d3..201b871e7b 100644 --- a/disperser/apiserver/config.go +++ b/disperser/apiserver/config.go @@ -8,6 +8,7 @@ import ( "log" "os" "strconv" + "strings" "time" "github.com/Layr-Labs/eigenda/common" @@ -164,9 +165,11 @@ func ReadAllowlistFromFile(f string) (Allowlist, error) { } for _, entry := range allowlistEntries { - rateInfoByQuorum, ok := allowlist[entry.Account] + // Normalize to lowercase (non-checksummed) address + account := strings.ToLower(entry.Account) + rateInfoByQuorum, ok := allowlist[account] if !ok { - allowlist[entry.Account] = map[core.QuorumID]PerUserRateInfo{ + allowlist[account] = map[core.QuorumID]PerUserRateInfo{ core.QuorumID(entry.QuorumID): { Name: entry.Name, Throughput: common.RateParam(entry.ByteRate), diff --git a/disperser/apiserver/server.go b/disperser/apiserver/server.go index 578cf5622b..e11012db2b 100644 --- a/disperser/apiserver/server.go +++ b/disperser/apiserver/server.go @@ -325,16 +325,10 @@ func (s *DispersalServer) getAccountRate(origin, authenticatedAddress string, qu // Check if the address is in the allowlist if len(authenticatedAddress) > 0 { + // Normalize to lowercase (non-checksummed) address + authenticatedAddress = strings.ToLower(authenticatedAddress) + quorumRates, ok := s.rateConfig.Allowlist[authenticatedAddress] - if !ok { - // check fallback address (non-checksummed) - fallbackAuthenticatedAddress := strings.ToLower(authenticatedAddress) - quorumRates, ok = s.rateConfig.Allowlist[fallbackAuthenticatedAddress] - if ok { - s.logger.Warn("authenticated address found via fallback lookup", "authenticatedAddress", authenticatedAddress, "fallback", fallbackAuthenticatedAddress) - authenticatedAddress = fallbackAuthenticatedAddress - } - } if ok { rateInfo, ok := quorumRates[quorumID] if ok { @@ -351,7 +345,6 @@ func (s *DispersalServer) getAccountRate(origin, authenticatedAddress string, qu } else { s.logger.Warn("authenticated address not found in allowlist", "authenticatedAddress", authenticatedAddress) } - } // Check if the origin is in the allowlist