forked from open-telemetry/opentelemetry-go-contrib
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
config: separate schema version support into separate directories (op…
…en-telemetry#6412) This makes the migration from one version to another explicit in any downstream dependencies. This will make dealing with breaking changes much easier in the Collector as it will allow us to have end users toggle a feature gate to enable support for new schema versions. Doing this today is not possible as we cannot import both a v0.2.0 and a v0.3.0 compatible config package. With the change in this PR, this will be possible. v0.2.0 directory was a copy based on 355fbbd --------- Signed-off-by: Alex Boten <[email protected]> Co-authored-by: Damien Mathieu <[email protected]>
- Loading branch information
Showing
27 changed files
with
4,421 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,10 @@ | ||
// Copyright The OpenTelemetry Authors | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
// Package config can be used to parse a configuration file | ||
// that follows the JSON Schema defined by the OpenTelemetry | ||
// Configuration schema. | ||
// Package config can be used to parse a configuration file that follows | ||
// the JSON Schema defined by the OpenTelemetry Configuration schema. Different | ||
// versions of the schema are supported by the code in the directory that | ||
// matches the version number of the schema. For example, the import | ||
// go.opentelemetry.io/contrib/config/v0.3.0 includes code that supports the | ||
// v0.3.0 release of the configuration schema. | ||
package config // import "go.opentelemetry.io/contrib/config" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,152 @@ | ||
// Copyright The OpenTelemetry Authors | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
package config // import "go.opentelemetry.io/contrib/config/v0.2.0" | ||
|
||
import ( | ||
"context" | ||
"errors" | ||
|
||
"gopkg.in/yaml.v3" | ||
|
||
"go.opentelemetry.io/otel/log" | ||
nooplog "go.opentelemetry.io/otel/log/noop" | ||
"go.opentelemetry.io/otel/metric" | ||
noopmetric "go.opentelemetry.io/otel/metric/noop" | ||
"go.opentelemetry.io/otel/trace" | ||
nooptrace "go.opentelemetry.io/otel/trace/noop" | ||
) | ||
|
||
const ( | ||
protocolProtobufHTTP = "http/protobuf" | ||
protocolProtobufGRPC = "grpc/protobuf" | ||
|
||
compressionGzip = "gzip" | ||
compressionNone = "none" | ||
) | ||
|
||
type configOptions struct { | ||
ctx context.Context | ||
opentelemetryConfig OpenTelemetryConfiguration | ||
} | ||
|
||
type shutdownFunc func(context.Context) error | ||
|
||
func noopShutdown(context.Context) error { | ||
return nil | ||
} | ||
|
||
// SDK is a struct that contains all the providers | ||
// configured via the configuration model. | ||
type SDK struct { | ||
meterProvider metric.MeterProvider | ||
tracerProvider trace.TracerProvider | ||
loggerProvider log.LoggerProvider | ||
shutdown shutdownFunc | ||
} | ||
|
||
// TracerProvider returns a configured trace.TracerProvider. | ||
func (s *SDK) TracerProvider() trace.TracerProvider { | ||
return s.tracerProvider | ||
} | ||
|
||
// MeterProvider returns a configured metric.MeterProvider. | ||
func (s *SDK) MeterProvider() metric.MeterProvider { | ||
return s.meterProvider | ||
} | ||
|
||
// LoggerProvider returns a configured log.LoggerProvider. | ||
func (s *SDK) LoggerProvider() log.LoggerProvider { | ||
return s.loggerProvider | ||
} | ||
|
||
// Shutdown calls shutdown on all configured providers. | ||
func (s *SDK) Shutdown(ctx context.Context) error { | ||
return s.shutdown(ctx) | ||
} | ||
|
||
var noopSDK = SDK{ | ||
loggerProvider: nooplog.LoggerProvider{}, | ||
meterProvider: noopmetric.MeterProvider{}, | ||
tracerProvider: nooptrace.TracerProvider{}, | ||
shutdown: func(ctx context.Context) error { return nil }, | ||
} | ||
|
||
// NewSDK creates SDK providers based on the configuration model. | ||
func NewSDK(opts ...ConfigurationOption) (SDK, error) { | ||
o := configOptions{} | ||
for _, opt := range opts { | ||
o = opt.apply(o) | ||
} | ||
if o.opentelemetryConfig.Disabled != nil && *o.opentelemetryConfig.Disabled { | ||
return noopSDK, nil | ||
} | ||
|
||
r, err := newResource(o.opentelemetryConfig.Resource) | ||
if err != nil { | ||
return noopSDK, err | ||
} | ||
|
||
mp, mpShutdown, err := meterProvider(o, r) | ||
if err != nil { | ||
return noopSDK, err | ||
} | ||
|
||
tp, tpShutdown, err := tracerProvider(o, r) | ||
if err != nil { | ||
return noopSDK, err | ||
} | ||
|
||
lp, lpShutdown, err := loggerProvider(o, r) | ||
if err != nil { | ||
return noopSDK, err | ||
} | ||
|
||
return SDK{ | ||
meterProvider: mp, | ||
tracerProvider: tp, | ||
loggerProvider: lp, | ||
shutdown: func(ctx context.Context) error { | ||
return errors.Join(mpShutdown(ctx), tpShutdown(ctx), lpShutdown(ctx)) | ||
}, | ||
}, nil | ||
} | ||
|
||
// ConfigurationOption configures options for providers. | ||
type ConfigurationOption interface { | ||
apply(configOptions) configOptions | ||
} | ||
|
||
type configurationOptionFunc func(configOptions) configOptions | ||
|
||
func (fn configurationOptionFunc) apply(cfg configOptions) configOptions { | ||
return fn(cfg) | ||
} | ||
|
||
// WithContext sets the context.Context for the SDK. | ||
func WithContext(ctx context.Context) ConfigurationOption { | ||
return configurationOptionFunc(func(c configOptions) configOptions { | ||
c.ctx = ctx | ||
return c | ||
}) | ||
} | ||
|
||
// WithOpenTelemetryConfiguration sets the OpenTelemetryConfiguration used | ||
// to produce the SDK. | ||
func WithOpenTelemetryConfiguration(cfg OpenTelemetryConfiguration) ConfigurationOption { | ||
return configurationOptionFunc(func(c configOptions) configOptions { | ||
c.opentelemetryConfig = cfg | ||
return c | ||
}) | ||
} | ||
|
||
// ParseYAML parses a YAML configuration file into an OpenTelemetryConfiguration. | ||
func ParseYAML(file []byte) (*OpenTelemetryConfiguration, error) { | ||
var cfg OpenTelemetryConfiguration | ||
err := yaml.Unmarshal(file, &cfg) | ||
if err != nil { | ||
return nil, err | ||
} | ||
|
||
return &cfg, nil | ||
} |
Oops, something went wrong.