Files
zot/pkg/extensions/extension_events.go
T
Andrei Aaron da426850e7 chore: update golangci-lint and fix all issues (#3575)
* chore: Update golangci-lint

Signed-off-by: Lars Francke <git@lars-francke.de>

* chore: fix all golangci-lint issues

- Remove deprecated `// +build` tags
- Fix godoclint, modernize, wsl_v5, govet, lll, gci, noctx issues
- Update linter configuration
- Modernize code to use Go 1.22+ features (for range N, slices.Contains, etc.)
- Update make check lint the privileged tests

Signed-off-by: Andrei Aaron <andreifdaaron@gmail.com>

---------

Signed-off-by: Lars Francke <git@lars-francke.de>
Signed-off-by: Andrei Aaron <andreifdaaron@gmail.com>
Co-authored-by: Lars Francke <git@lars-francke.de>
2025-11-22 23:36:48 +02:00

62 lines
1.5 KiB
Go

//go:build events
package extensions
import (
zerr "zotregistry.dev/zot/v2/errors"
"zotregistry.dev/zot/v2/pkg/api/config"
eventsconfig "zotregistry.dev/zot/v2/pkg/extensions/config/events"
"zotregistry.dev/zot/v2/pkg/extensions/events"
"zotregistry.dev/zot/v2/pkg/log"
)
func NewEventRecorder(config *config.Config, log log.Logger) (events.Recorder, error) {
// Get extensions config safely
extensionsConfig := config.CopyExtensionsConfig()
if !extensionsConfig.IsEventRecorderEnabled() {
log.Info().Msg("events disabled in configuration")
return nil, zerr.ErrExtensionNotEnabled
}
eventConfig := extensionsConfig.GetEventsConfig()
if eventConfig == nil || eventConfig.Sinks == nil || len(eventConfig.Sinks) == 0 {
log.Info().Msg("no sinks provided, skipping events extension setup")
return nil, zerr.ErrExtensionNotEnabled
}
var sinks []events.Sink
log.Info().Msg("setting up event sinks")
for _, sinkConfig := range eventConfig.Sinks {
switch sinkConfig.Type {
case eventsconfig.HTTP:
sink, err := events.NewHTTPSink(sinkConfig)
if err != nil {
return nil, err
}
sinks = append(sinks, sink)
case eventsconfig.NATS:
sink, err := events.NewNATSSink(sinkConfig)
if err != nil {
return nil, err
}
sinks = append(sinks, sink)
default:
log.Warn().Msgf("skipping unsupported sink type: %s", sinkConfig.Type)
}
}
if len(sinks) == 0 {
log.Warn().Msg("no sinks provided, skipping events extension setup")
return nil, zerr.ErrExtensionNotEnabled
}
return events.NewRecorder(log, sinks...)
}