From 990078dcf5c893d95c078fa9899621803ee7fff8 Mon Sep 17 00:00:00 2001 From: urvisavla Date: Thu, 27 Jul 2023 09:56:13 -0700 Subject: [PATCH] Services/horizon: Skip querying stellar-core on 127.0.0.1 when Horizon is in build state (#4977) --- services/horizon/internal/app.go | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/services/horizon/internal/app.go b/services/horizon/internal/app.go index f5373d07a8..5eca2f0033 100644 --- a/services/horizon/internal/app.go +++ b/services/horizon/internal/app.go @@ -7,6 +7,7 @@ import ( "net/http" "os" "os/signal" + "strings" "sync" "syscall" "time" @@ -196,6 +197,13 @@ func (a *App) Paths() paths.Finder { return a.paths } +func isLocalAddress(url string, port uint) bool { + localHostURL := fmt.Sprintf("http://localhost:%d", port) + localIPURL := fmt.Sprintf("http://127.0.0.1:%d", port) + + return strings.HasPrefix(url, localHostURL) || strings.HasPrefix(url, localIPURL) +} + // UpdateCoreLedgerState triggers a refresh of Stellar-Core ledger state. // This is done separately from Horizon ledger state update to prevent issues // in case Stellar-Core query timeout. @@ -205,7 +213,7 @@ func (a *App) UpdateCoreLedgerState(ctx context.Context) { // #4446 If the ingestion state machine is in the build state, the query can time out // because the captive-core buffer may be full. In this case, skip the check. if a.config.CaptiveCoreToml != nil && - a.config.StellarCoreURL == fmt.Sprintf("http://localhost:%d", a.config.CaptiveCoreToml.HTTPPort) && + isLocalAddress(a.config.StellarCoreURL, a.config.CaptiveCoreToml.HTTPPort) && a.ingester != nil && a.ingester.GetCurrentState() == ingest.Build { return }