Skip to content

Commit

Permalink
Add connectors to otelcol config
Browse files Browse the repository at this point in the history
  • Loading branch information
djaglowski committed Jan 19, 2023
1 parent c251f3d commit 60535e7
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 2 deletions.
22 changes: 22 additions & 0 deletions otelcol/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import (
"fmt"

"go.opentelemetry.io/collector/component"
"go.opentelemetry.io/collector/featuregate"
"go.opentelemetry.io/collector/service"
)

Expand All @@ -27,6 +28,20 @@ var (
errMissingReceivers = errors.New("no receiver configuration specified in config")
)

const (
connectorsFeatureGateID = "otelcol.enableConnectors"
connectorsFeatureStage = featuregate.StageAlpha
)

func init() {
featuregate.GetRegistry().MustRegisterID(
connectorsFeatureGateID,
connectorsFeatureStage,
featuregate.WithRegisterDescription("Enables 'connectors', a new type of component for transmitting signals between pipelines."),
featuregate.WithRegisterReferenceURL("https://github.com/open-telemetry/opentelemetry-collector/issues/2336"),
)
}

// Config defines the configuration for the various elements of collector or agent.
type Config struct {
// Receivers is a map of ComponentID to Receivers.
Expand All @@ -38,6 +53,9 @@ type Config struct {
// Processors is a map of ComponentID to Processors.
Processors map[component.ID]component.Config

// Connectors is a map of ComponentID to connectors.
Connectors map[component.ID]component.Config

// Extensions is a map of ComponentID to extensions.
Extensions map[component.ID]component.Config

Expand Down Expand Up @@ -90,6 +108,10 @@ func (cfg *Config) Validate() error {
}
}

if len(cfg.Extensions) != 0 && !featuregate.GetRegistry().IsEnabled(connectorsFeatureGateID) {
return fmt.Errorf("connectors require feature gate: %s", connectorsFeatureGateID)
}

if err := cfg.Service.Validate(); err != nil {
return err
}
Expand Down
1 change: 1 addition & 0 deletions otelcol/configprovider.go
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,7 @@ func (cm *configProvider) Get(ctx context.Context, factories Factories) (*Config
Receivers: cfg.Receivers.Configs(),
Processors: cfg.Processors.Configs(),
Exporters: cfg.Exporters.Configs(),
Connectors: cfg.Connectors.Configs(),
Extensions: cfg.Extensions.Configs(),
Service: cfg.Service,
}, nil
Expand Down
3 changes: 1 addition & 2 deletions otelcol/unmarshaler.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ package otelcol // import "go.opentelemetry.io/collector/otelcol"
import (
"go.uber.org/zap/zapcore"

"go.opentelemetry.io/collector/component"
"go.opentelemetry.io/collector/config/configtelemetry"
"go.opentelemetry.io/collector/confmap"
"go.opentelemetry.io/collector/connector"
Expand Down Expand Up @@ -47,7 +46,7 @@ func unmarshal(v *confmap.Conf, factories Factories) (*configSettings, error) {
Receivers: configunmarshaler.NewConfigs(factories.Receivers),
Processors: configunmarshaler.NewConfigs(factories.Processors),
Exporters: configunmarshaler.NewConfigs(factories.Exporters),
Connectors: configunmarshaler.NewConfigs(map[component.Type]connector.Factory{}),
Connectors: configunmarshaler.NewConfigs(factories.Connectors),
Extensions: configunmarshaler.NewConfigs(factories.Extensions),
// TODO: Add a component.ServiceFactory to allow this to be defined by the Service.
Service: service.Config{
Expand Down

0 comments on commit 60535e7

Please sign in to comment.