From df35547f8a0fb1286ec199356aef079aff3d5f24 Mon Sep 17 00:00:00 2001 From: Evan Bradley <11745660+evan-bradley@users.noreply.github.com> Date: Wed, 20 Nov 2024 15:12:58 -0700 Subject: [PATCH] Update generated config types (#6347) This updates the generated config types to be created with go-jsonschema v0.17.0, which includes an update to add a struct tag the `AdditionalProperties` field that allows it to be marshaled. Making this change fixes the following error that occurs when I marshal a basic `otelcol.Config` struct, then run it with the Collector: ``` 'metrics.readers[0].pull.exporter' has invalid keys: additionalproperties ``` Related to https://github.com/open-telemetry/opentelemetry-collector/issues/11711. --- CHANGELOG.md | 1 + config/generated_config.go | 22 +++++++++++----------- 2 files changed, 12 insertions(+), 11 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 654e7c555e1..f022916f572 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -16,6 +16,7 @@ This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.htm ### Fixed - Fixed the value for configuring the OTLP exporter to use `grpc` instead of `grpc/protobuf` in `go.opentelemetry.io/contrib/config`. (#6338) +- Allow marshaling types in `go.opentelemetry.io/contrib/config`. (#6347) diff --git a/config/generated_config.go b/config/generated_config.go index fbf69c3927e..8fe7310e9de 100644 --- a/config/generated_config.go +++ b/config/generated_config.go @@ -11,7 +11,7 @@ type AttributeLimits struct { // "attribute_value_length_limit". AttributeValueLengthLimit *int `json:"attribute_value_length_limit,omitempty" yaml:"attribute_value_length_limit,omitempty" mapstructure:"attribute_value_length_limit,omitempty"` - AdditionalProperties interface{} + AdditionalProperties interface{} `mapstructure:",remain"` } type AttributeNameValue struct { @@ -186,7 +186,7 @@ type LogRecordExporter struct { // OTLP corresponds to the JSON schema field "otlp". OTLP *OTLP `json:"otlp,omitempty" yaml:"otlp,omitempty" mapstructure:"otlp,omitempty"` - AdditionalProperties interface{} + AdditionalProperties interface{} `mapstructure:",remain"` } type LogRecordLimits struct { @@ -206,7 +206,7 @@ type LogRecordProcessor struct { // Simple corresponds to the JSON schema field "simple". Simple *SimpleLogRecordProcessor `json:"simple,omitempty" yaml:"simple,omitempty" mapstructure:"simple,omitempty"` - AdditionalProperties interface{} + AdditionalProperties interface{} `mapstructure:",remain"` } type LoggerProvider struct { @@ -229,7 +229,7 @@ type MetricProducer struct { // Opencensus corresponds to the JSON schema field "opencensus". Opencensus MetricProducerOpencensus `json:"opencensus,omitempty" yaml:"opencensus,omitempty" mapstructure:"opencensus,omitempty"` - AdditionalProperties interface{} + AdditionalProperties interface{} `mapstructure:",remain"` } type MetricProducerOpencensus map[string]interface{} @@ -358,7 +358,7 @@ type OpenTelemetryConfiguration struct { // TracerProvider corresponds to the JSON schema field "tracer_provider". TracerProvider *TracerProvider `json:"tracer_provider,omitempty" yaml:"tracer_provider,omitempty" mapstructure:"tracer_provider,omitempty"` - AdditionalProperties interface{} + AdditionalProperties interface{} `mapstructure:",remain"` } type PeriodicMetricReader struct { @@ -397,14 +397,14 @@ type Propagator struct { // Composite corresponds to the JSON schema field "composite". Composite []*string `json:"composite,omitempty" yaml:"composite,omitempty" mapstructure:"composite,omitempty"` - AdditionalProperties interface{} + AdditionalProperties interface{} `mapstructure:",remain"` } type PullMetricExporter struct { // Prometheus corresponds to the JSON schema field "prometheus". Prometheus *Prometheus `json:"prometheus,omitempty" yaml:"prometheus,omitempty" mapstructure:"prometheus,omitempty"` - AdditionalProperties interface{} + AdditionalProperties interface{} `mapstructure:",remain"` } type PullMetricReader struct { @@ -419,7 +419,7 @@ type PushMetricExporter struct { // OTLP corresponds to the JSON schema field "otlp". OTLP *OTLPMetric `json:"otlp,omitempty" yaml:"otlp,omitempty" mapstructure:"otlp,omitempty"` - AdditionalProperties interface{} + AdditionalProperties interface{} `mapstructure:",remain"` } type Resource struct { @@ -452,7 +452,7 @@ type Sampler struct { // TraceIDRatioBased corresponds to the JSON schema field "trace_id_ratio_based". TraceIDRatioBased *SamplerTraceIDRatioBased `json:"trace_id_ratio_based,omitempty" yaml:"trace_id_ratio_based,omitempty" mapstructure:"trace_id_ratio_based,omitempty"` - AdditionalProperties interface{} + AdditionalProperties interface{} `mapstructure:",remain"` } type SamplerAlwaysOff map[string]interface{} @@ -515,7 +515,7 @@ type SpanExporter struct { // Zipkin corresponds to the JSON schema field "zipkin". Zipkin *Zipkin `json:"zipkin,omitempty" yaml:"zipkin,omitempty" mapstructure:"zipkin,omitempty"` - AdditionalProperties interface{} + AdditionalProperties interface{} `mapstructure:",remain"` } type SpanLimits struct { @@ -549,7 +549,7 @@ type SpanProcessor struct { // Simple corresponds to the JSON schema field "simple". Simple *SimpleSpanProcessor `json:"simple,omitempty" yaml:"simple,omitempty" mapstructure:"simple,omitempty"` - AdditionalProperties interface{} + AdditionalProperties interface{} `mapstructure:",remain"` } type TracerProvider struct {