From 0068acaeef44139f4d88cada20d680d84b45f015 Mon Sep 17 00:00:00 2001 From: "Tyler.S" Date: Thu, 30 Nov 2023 10:34:51 -0800 Subject: [PATCH] Add timeout for initializing captive core --- cmd/soroban-rpc/internal/config/config.go | 1 + cmd/soroban-rpc/internal/config/options.go | 6 ++++++ cmd/soroban-rpc/internal/daemon/daemon.go | 3 +++ 3 files changed, 10 insertions(+) diff --git a/cmd/soroban-rpc/internal/config/config.go b/cmd/soroban-rpc/internal/config/config.go index 1f89ab2b..64c8edb8 100644 --- a/cmd/soroban-rpc/internal/config/config.go +++ b/cmd/soroban-rpc/internal/config/config.go @@ -29,6 +29,7 @@ type Config struct { FriendbotURL string HistoryArchiveURLs []string IngestionTimeout time.Duration + CaptiveCoreTimeout time.Duration LogFormat LogFormat LogLevel logrus.Level MaxEventsLimit uint diff --git a/cmd/soroban-rpc/internal/config/options.go b/cmd/soroban-rpc/internal/config/options.go index cecfb2e7..6f5f6255 100644 --- a/cmd/soroban-rpc/internal/config/options.go +++ b/cmd/soroban-rpc/internal/config/options.go @@ -174,6 +174,12 @@ func (cfg *Config) options() ConfigOptions { } }, }, + { + Name: "captive-core-timeout", + Usage: "Timeout for configuring and connecting to the specified Stellar Core instance", + ConfigKey: &cfg.CaptiveCoreTimeout, + DefaultValue: 1 * time.Minute, + }, { Name: "history-archive-urls", Usage: "comma-separated list of stellar history archives to connect with", diff --git a/cmd/soroban-rpc/internal/daemon/daemon.go b/cmd/soroban-rpc/internal/daemon/daemon.go index 63afb9a7..c4d6602e 100644 --- a/cmd/soroban-rpc/internal/daemon/daemon.go +++ b/cmd/soroban-rpc/internal/daemon/daemon.go @@ -113,6 +113,8 @@ func newCaptiveCore(cfg *config.Config, logger *supportlog.Entry) (*ledgerbacken logger.WithError(err).Fatal("Invalid captive core toml") } + newCaptiveCoreCtx, cancelNewCaptiveCore := context.WithTimeout(context.Background(), cfg.CaptiveCoreTimeout) + defer cancelNewCaptiveCore() captiveConfig := ledgerbackend.CaptiveCoreConfig{ BinaryPath: cfg.StellarCoreBinaryPath, StoragePath: cfg.CaptiveCoreStoragePath, @@ -123,6 +125,7 @@ func newCaptiveCore(cfg *config.Config, logger *supportlog.Entry) (*ledgerbacken Toml: captiveCoreToml, UserAgent: "captivecore", UseDB: true, + Context: newCaptiveCoreCtx, } return ledgerbackend.NewCaptive(captiveConfig)