fix: load multiple registries via env

This commit is contained in:
Mohamed Sohail 2025-03-13 12:20:10 +03:00
parent 414b14a92e
commit 9c97ce2d2f
Signed by: kamikazechaser
GPG Key ID: 7DD45520C01CD85D
3 changed files with 15 additions and 6 deletions

View File

@ -74,7 +74,7 @@ func main() {
cacheOpts := cache.CacheOpts{ cacheOpts := cache.CacheOpts{
Chain: chain, Chain: chain,
Registries: []string{ko.MustString("bootstrap.ge_registry")}, Registries: ko.MustStrings("bootstrap.ge_registry"),
Watchlist: ko.Strings("bootstrap.watchlist"), Watchlist: ko.Strings("bootstrap.watchlist"),
Blacklist: ko.Strings("bootstrap.blacklist"), Blacklist: ko.Strings("bootstrap.blacklist"),
CacheType: ko.MustString("core.cache_type"), CacheType: ko.MustString("core.cache_type"),

View File

@ -27,7 +27,7 @@ start_block = 0
[bootstrap] [bootstrap]
# This will bootstrap the cache on which addresses to track # This will bootstrap the cache on which addresses to track
ge_registry = "0x0f8E97ef2d6A42CF62549D4924FCBdcE83A1C6A5" ge_registry = ["0x0f8E97ef2d6A42CF62549D4924FCBdcE83A1C6A5"]
watchlist = [""] watchlist = [""]
blacklist = [""] blacklist = [""]

View File

@ -41,13 +41,22 @@ func InitConfig(lo *slog.Logger, confFilePath string) *koanf.Koanf {
os.Exit(1) os.Exit(1)
} }
if err := ko.Load(env.Provider("TRACKER_", ".", func(s string) string { err := ko.Load(env.ProviderWithValue("TRACKER_", ".", func(s string, v string) (string, interface{}) {
return strings.ReplaceAll(strings.ToLower( key := strings.ReplaceAll(strings.ToLower(strings.TrimPrefix(s, "TRACKER_")), "__", ".")
strings.TrimPrefix(s, "TRACKER_")), "__", ".") if strings.Contains(v, " ") {
}), nil); err != nil { return key, strings.Split(v, " ")
}
return key, v
}), nil)
if err != nil {
lo.Error("could not override config from env vars", "error", err) lo.Error("could not override config from env vars", "error", err)
os.Exit(1) os.Exit(1)
} }
if os.Getenv("DEBUG") != "" {
ko.Print()
}
return ko return ko
} }