Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use new UnmarshalKey in a few locations. Fix edge cases. #29225

Merged
merged 16 commits into from
Sep 24, 2024
Merged
Show file tree
Hide file tree
Changes from 13 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 3 additions & 2 deletions cmd/agent/common/autodiscovery.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ import (
confad "github.com/DataDog/datadog-agent/pkg/config/autodiscovery"
pkgconfigenv "github.com/DataDog/datadog-agent/pkg/config/env"
pkgconfigsetup "github.com/DataDog/datadog-agent/pkg/config/setup"
"github.com/DataDog/datadog-agent/pkg/config/structure"
"github.com/DataDog/datadog-agent/pkg/util/jsonquery"
"github.com/DataDog/datadog-agent/pkg/util/log"
)
Expand Down Expand Up @@ -62,7 +63,7 @@ func setupAutoDiscovery(confSearchPaths []string, wmeta workloadmeta.Component,
// Register additional configuration providers
var configProviders []pkgconfigsetup.ConfigurationProviders
var uniqueConfigProviders map[string]pkgconfigsetup.ConfigurationProviders
err := pkgconfigsetup.Datadog().UnmarshalKey("config_providers", &configProviders)
err := structure.UnmarshalKey(pkgconfigsetup.Datadog(), "config_providers", &configProviders)

if err == nil {
uniqueConfigProviders = make(map[string]pkgconfigsetup.ConfigurationProviders, len(configProviders)+len(extraEnvProviders)+len(configProviders))
Expand Down Expand Up @@ -125,7 +126,7 @@ func setupAutoDiscovery(confSearchPaths []string, wmeta workloadmeta.Component,
}

var listeners []pkgconfigsetup.Listeners
err = pkgconfigsetup.Datadog().UnmarshalKey("listeners", &listeners)
err = structure.UnmarshalKey(pkgconfigsetup.Datadog(), "listeners", &listeners)
if err == nil {
// Add extra listeners
for _, name := range pkgconfigsetup.Datadog().GetStringSlice("extra_listeners") {
Expand Down
1 change: 1 addition & 0 deletions cmd/serverless/dependencies_linux_amd64.txt
Original file line number Diff line number Diff line change
Expand Up @@ -144,6 +144,7 @@ github.com/DataDog/datadog-agent/pkg/config/model
github.com/DataDog/datadog-agent/pkg/config/remote/data
github.com/DataDog/datadog-agent/pkg/config/setup
github.com/DataDog/datadog-agent/pkg/config/setup/constants
github.com/DataDog/datadog-agent/pkg/config/structure
github.com/DataDog/datadog-agent/pkg/config/utils
github.com/DataDog/datadog-agent/pkg/diagnose/diagnosis
github.com/DataDog/datadog-agent/pkg/errors
Expand Down
1 change: 1 addition & 0 deletions cmd/serverless/dependencies_linux_arm64.txt
Original file line number Diff line number Diff line change
Expand Up @@ -144,6 +144,7 @@ github.com/DataDog/datadog-agent/pkg/config/model
github.com/DataDog/datadog-agent/pkg/config/remote/data
github.com/DataDog/datadog-agent/pkg/config/setup
github.com/DataDog/datadog-agent/pkg/config/setup/constants
github.com/DataDog/datadog-agent/pkg/config/structure
github.com/DataDog/datadog-agent/pkg/config/utils
github.com/DataDog/datadog-agent/pkg/diagnose/diagnosis
github.com/DataDog/datadog-agent/pkg/errors
Expand Down
3 changes: 2 additions & 1 deletion comp/autoscaling/datadogclient/impl/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import (
configComponent "github.com/DataDog/datadog-agent/comp/core/config"
logComp "github.com/DataDog/datadog-agent/comp/core/log/def"
"github.com/DataDog/datadog-agent/comp/core/status"
"github.com/DataDog/datadog-agent/pkg/config/structure"
"gopkg.in/zorkian/go-datadog-api.v2"
)

Expand Down Expand Up @@ -120,7 +121,7 @@ func (d *datadogClientWrapper) refreshClient() {
func createDatadogClient(cfg configComponent.Component, logger logComp.Component) (datadogclient.Component, error) {
if cfg.IsSet(metricsRedundantEndpointConfig) {
var endpoints []endpoint
if err := cfg.UnmarshalKey(metricsRedundantEndpointConfig, &endpoints); err != nil {
if err := structure.UnmarshalKey(cfg, metricsRedundantEndpointConfig, &endpoints); err != nil {
return nil, fmt.Errorf("could not parse %s: %v", metricsRedundantEndpointConfig, err)
}

Expand Down
3 changes: 2 additions & 1 deletion comp/dogstatsd/mapper/mapper_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import (
"github.com/stretchr/testify/require"

configComponent "github.com/DataDog/datadog-agent/comp/core/config"
"github.com/DataDog/datadog-agent/pkg/config/structure"
)

func TestMappings(t *testing.T) {
Expand Down Expand Up @@ -519,7 +520,7 @@ func getMapper(t *testing.T, configString string) (*MetricMapper, error) {

cfg := configComponent.NewMockFromYAML(t, configString)

err := cfg.UnmarshalKey("dogstatsd_mapper_profiles", &profiles)
err := structure.UnmarshalKey(cfg, "dogstatsd_mapper_profiles", &profiles)
if err != nil {
return nil, err
}
Expand Down
3 changes: 2 additions & 1 deletion comp/dogstatsd/server/server.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ import (
serverdebug "github.com/DataDog/datadog-agent/comp/dogstatsd/serverDebug"
"github.com/DataDog/datadog-agent/pkg/aggregator"
"github.com/DataDog/datadog-agent/pkg/config/model"
"github.com/DataDog/datadog-agent/pkg/config/structure"
"github.com/DataDog/datadog-agent/pkg/config/utils"
"github.com/DataDog/datadog-agent/pkg/metrics"
"github.com/DataDog/datadog-agent/pkg/metrics/event"
Expand Down Expand Up @@ -835,7 +836,7 @@ func getBuckets(cfg model.Reader, logger log.Component, option string) []float64
func getDogstatsdMappingProfiles(cfg model.Reader) ([]mapper.MappingProfileConfig, error) {
var mappings []mapper.MappingProfileConfig
if cfg.IsSet("dogstatsd_mapper_profiles") {
err := cfg.UnmarshalKey("dogstatsd_mapper_profiles", &mappings)
err := structure.UnmarshalKey(cfg, "dogstatsd_mapper_profiles", &mappings)
if err != nil {
return []mapper.MappingProfileConfig{}, fmt.Errorf("Could not parse dogstatsd_mapper_profiles: %v", err)
}
Expand Down
3 changes: 2 additions & 1 deletion comp/logs/agent/config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import (
"time"

pkgconfigmodel "github.com/DataDog/datadog-agent/pkg/config/model"
"github.com/DataDog/datadog-agent/pkg/config/structure"
pkgconfigutils "github.com/DataDog/datadog-agent/pkg/config/utils"
"github.com/DataDog/datadog-agent/pkg/util/log"
)
Expand Down Expand Up @@ -70,7 +71,7 @@ func GlobalProcessingRules(coreConfig pkgconfigmodel.Reader) ([]*ProcessingRule,
if s, ok := raw.(string); ok && s != "" {
err = json.Unmarshal([]byte(s), &rules)
} else {
err = coreConfig.UnmarshalKey("logs_config.processing_rules", &rules)
err = structure.UnmarshalKey(coreConfig, "logs_config.processing_rules", &rules, structure.ConvertEmptyStringToNil)
}
if err != nil {
return nil, err
Expand Down
3 changes: 2 additions & 1 deletion comp/logs/agent/config/config_keys.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import (

pkgconfigmodel "github.com/DataDog/datadog-agent/pkg/config/model"
pkgconfigsetup "github.com/DataDog/datadog-agent/pkg/config/setup"
"github.com/DataDog/datadog-agent/pkg/config/structure"
"github.com/DataDog/datadog-agent/pkg/util/log"
)

Expand Down Expand Up @@ -152,7 +153,7 @@ func (l *LogsConfigKeys) getAdditionalEndpoints() []unmarshalEndpoint {
if s, ok := raw.(string); ok && s != "" {
err = json.Unmarshal([]byte(s), &endpoints)
} else {
err = l.getConfig().UnmarshalKey(configKey, &endpoints)
err = structure.UnmarshalKey(l.getConfig(), configKey, &endpoints, structure.EnableSquash)
}
if err != nil {
log.Warnf("Could not parse additional_endpoints for logs: %v", err)
Expand Down
32 changes: 17 additions & 15 deletions comp/logs/agent/config/go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ replace (
github.com/DataDog/datadog-agent/pkg/config/mock => ../../../../pkg/config/mock
github.com/DataDog/datadog-agent/pkg/config/model => ../../../../pkg/config/model/
github.com/DataDog/datadog-agent/pkg/config/setup => ../../../../pkg/config/setup
github.com/DataDog/datadog-agent/pkg/config/structure => ../../../../pkg/config/structure
github.com/DataDog/datadog-agent/pkg/config/utils => ../../../../pkg/config/utils
github.com/DataDog/datadog-agent/pkg/telemetry => ../../../../pkg/telemetry
github.com/DataDog/datadog-agent/pkg/util/executable => ../../../../pkg/util/executable
Expand All @@ -35,12 +36,13 @@ replace (

require (
github.com/DataDog/datadog-agent/comp/core/config v0.56.0-rc.3
github.com/DataDog/datadog-agent/pkg/config/model v0.56.0-rc.3
github.com/DataDog/datadog-agent/pkg/config/setup v0.56.0-rc.3
github.com/DataDog/datadog-agent/pkg/config/model v0.57.0
github.com/DataDog/datadog-agent/pkg/config/setup v0.57.0
github.com/DataDog/datadog-agent/pkg/config/structure v0.0.0-00010101000000-000000000000
github.com/DataDog/datadog-agent/pkg/config/utils v0.56.0-rc.3
github.com/DataDog/datadog-agent/pkg/util/fxutil v0.56.0-rc.3
github.com/DataDog/datadog-agent/pkg/util/log v0.56.0-rc.3
github.com/DataDog/datadog-agent/pkg/util/pointer v0.56.0-rc.3
github.com/DataDog/datadog-agent/pkg/util/log v0.57.0
github.com/DataDog/datadog-agent/pkg/util/pointer v0.57.0
github.com/DataDog/viper v1.13.5
github.com/stretchr/testify v1.9.0
go.uber.org/fx v1.22.2
Expand All @@ -49,19 +51,19 @@ require (
require (
github.com/DataDog/datadog-agent/comp/core/flare/builder v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/comp/core/flare/types v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/comp/core/secrets v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/comp/core/secrets v0.57.0 // indirect
github.com/DataDog/datadog-agent/comp/def v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/collector/check/defaults v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/config/env v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/collector/check/defaults v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/config/env v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/config/mock v0.58.0-devel // indirect
github.com/DataDog/datadog-agent/pkg/util/executable v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/filesystem v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/hostname/validate v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/optional v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/scrubber v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/system v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/system/socket v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/winutil v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/executable v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/filesystem v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/hostname/validate v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/optional v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/scrubber v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/system v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/system/socket v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/winutil v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/version v0.56.0-rc.3 // indirect
github.com/Microsoft/go-winio v0.6.1 // indirect
github.com/cihub/seelog v0.0.0-20170130134532-f561c5e57575 // indirect
Expand Down
3 changes: 2 additions & 1 deletion comp/netflow/config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import (
"github.com/DataDog/datadog-agent/comp/core/config"
log "github.com/DataDog/datadog-agent/comp/core/log/def"

"github.com/DataDog/datadog-agent/pkg/config/structure"
"github.com/DataDog/datadog-agent/pkg/snmp/utils"

"github.com/DataDog/datadog-agent/comp/netflow/common"
Expand Down Expand Up @@ -59,7 +60,7 @@ type Mapping struct {
func ReadConfig(conf config.Component, logger log.Component) (*NetflowConfig, error) {
var mainConfig NetflowConfig

err := conf.UnmarshalKey("network_devices.netflow", &mainConfig)
err := structure.UnmarshalKey(conf, "network_devices.netflow", &mainConfig)
if err != nil {
return nil, err
}
Expand Down
32 changes: 17 additions & 15 deletions comp/otelcol/logsagentpipeline/go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ replace (
github.com/DataDog/datadog-agent/pkg/config/mock => ../../../pkg/config/mock
github.com/DataDog/datadog-agent/pkg/config/model => ../../../pkg/config/model
github.com/DataDog/datadog-agent/pkg/config/setup => ../../../pkg/config/setup
github.com/DataDog/datadog-agent/pkg/config/structure => ../../../pkg/config/structure
github.com/DataDog/datadog-agent/pkg/config/utils => ../../../pkg/config/utils
github.com/DataDog/datadog-agent/pkg/logs/auditor => ../../../pkg/logs/auditor
github.com/DataDog/datadog-agent/pkg/logs/client => ../../../pkg/logs/client
Expand Down Expand Up @@ -61,14 +62,15 @@ require github.com/DataDog/datadog-agent/pkg/logs/pipeline v0.56.0-rc.3
require (
github.com/DataDog/agent-payload/v5 v5.0.106 // indirect
github.com/DataDog/datadog-agent/comp/core/hostname/hostnameinterface v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/comp/core/secrets v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/comp/core/secrets v0.57.0 // indirect
github.com/DataDog/datadog-agent/comp/core/telemetry v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/comp/def v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/comp/logs/agent/config v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/collector/check/defaults v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/config/env v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/config/model v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/config/setup v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/collector/check/defaults v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/config/env v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/config/model v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/config/setup v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/config/structure v0.0.0-00010101000000-000000000000 // indirect
github.com/DataDog/datadog-agent/pkg/config/utils v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/logs/auditor v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/logs/client v0.56.0-rc.3 // indirect
Expand All @@ -84,20 +86,20 @@ require (
github.com/DataDog/datadog-agent/pkg/status/health v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/telemetry v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/backoff v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/executable v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/filesystem v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/executable v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/filesystem v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/fxutil v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/hostname/validate v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/hostname/validate v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/http v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/log v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/optional v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/pointer v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/scrubber v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/log v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/optional v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/pointer v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/scrubber v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/startstop v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/statstracker v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/system v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/system/socket v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/winutil v0.56.0-rc.3 // indirect
github.com/DataDog/datadog-agent/pkg/util/system v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/system/socket v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/winutil v0.57.0 // indirect
github.com/DataDog/datadog-agent/pkg/version v0.56.0-rc.3 // indirect
github.com/DataDog/dd-sensitive-data-scanner/sds-go/go v0.0.0-20240816154533-f7f9beb53a42 // indirect
github.com/DataDog/viper v1.13.5 // indirect
Expand Down
Loading
Loading