diff --git a/CHANGELOG.md b/CHANGELOG.md index bf71d921cd..fd47f609a0 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -14,6 +14,7 @@ 1. [18600](https://github.com/influxdata/influxdb/pull/18600): Extend influx apply with resource filter capabilities 1. [18601](https://github.com/influxdata/influxdb/pull/18601): Provide active config running influx config without args 1. [18606](https://github.com/influxdata/influxdb/pull/18606): Enable influxd binary to look for a config file on startup +1. [18647](https://github.com/influxdata/influxdb/pull/18647): Add support for env ref default values to the template parser ### Bug Fixes diff --git a/pkger/parser.go b/pkger/parser.go index 72cf30da54..adeb35cab2 100644 --- a/pkger/parser.go +++ b/pkger/parser.go @@ -1639,6 +1639,7 @@ func (r Resource) references(key string) *references { switch f { case fieldReferencesEnv: ref.EnvRef = keyRes.stringShort(fieldKey) + ref.defaultVal = keyRes.stringShort(fieldDefault) case fieldReferencesSecret: ref.Secret = keyRes.stringShort(fieldKey) } diff --git a/pkger/parser_models.go b/pkger/parser_models.go index 816af9d37a..da61e00a52 100644 --- a/pkger/parser_models.go +++ b/pkger/parser_models.go @@ -50,6 +50,7 @@ func summarizeCommonReferences(ident identity, labels sortedLabels) []SummaryRef const ( fieldAPIVersion = "apiVersion" fieldAssociations = "associations" + fieldDefault = "default" fieldDescription = "description" fieldEvery = "every" fieldKey = "key" @@ -1992,9 +1993,10 @@ const ( ) type references struct { - val interface{} - EnvRef string - Secret string + val interface{} + defaultVal string + EnvRef string + Secret string } func (r *references) hasValue() bool { @@ -2019,6 +2021,9 @@ func (r *references) String() string { } func (r *references) defaultEnvValue() string { + if r.defaultVal != "" { + return r.defaultVal + } return "env-" + r.EnvRef } diff --git a/pkger/parser_test.go b/pkger/parser_test.go index ded5c1b378..9f3c65b1c9 100644 --- a/pkger/parser_test.go +++ b/pkger/parser_test.go @@ -60,12 +60,12 @@ func TestParse(t *testing.T) { { Field: "metadata.name", EnvRefKey: "meta-name", - DefaultValue: "env-meta-name", + DefaultValue: "meta", }, { Field: "spec.name", EnvRefKey: "spec-name", - DefaultValue: "env-spec-name", + DefaultValue: "spectacles", }, { Field: "spec.associations[0].name", @@ -582,12 +582,12 @@ spec: { Field: "metadata.name", EnvRefKey: "meta-name", - DefaultValue: "env-meta-name", + DefaultValue: "meta", }, { Field: "spec.name", EnvRefKey: "spec-name", - DefaultValue: "env-spec-name", + DefaultValue: "spectacles", }, { Field: "spec.associations[0].name", @@ -2281,12 +2281,12 @@ spec: { Field: "metadata.name", EnvRefKey: "meta-name", - DefaultValue: "env-meta-name", + DefaultValue: "meta", }, { Field: "spec.name", EnvRefKey: "spec-name", - DefaultValue: "env-spec-name", + DefaultValue: "spectacles", }, { Field: "spec.associations[0].name", @@ -2528,12 +2528,12 @@ spec: { Field: "metadata.name", EnvRefKey: "meta-name", - DefaultValue: "env-meta-name", + DefaultValue: "meta", }, { Field: "spec.name", EnvRefKey: "spec-name", - DefaultValue: "env-spec-name", + DefaultValue: "spectacles", }, { Field: "spec.associations[0].name", @@ -2852,12 +2852,12 @@ spec: { Field: "metadata.name", EnvRefKey: "meta-name", - DefaultValue: "env-meta-name", + DefaultValue: "meta", }, { Field: "spec.name", EnvRefKey: "spec-name", - DefaultValue: "env-spec-name", + DefaultValue: "spectacles", }, { Field: "spec.associations[0].name", @@ -3189,12 +3189,12 @@ spec: { Field: "metadata.name", EnvRefKey: "meta-name", - DefaultValue: "env-meta-name", + DefaultValue: "meta", }, { Field: "spec.name", EnvRefKey: "spec-name", - DefaultValue: "env-spec-name", + DefaultValue: "spectacles", }, { Field: "spec.associations[0].name", @@ -3407,12 +3407,12 @@ spec: { Field: "metadata.name", EnvRefKey: "meta-name", - DefaultValue: "env-meta-name", + DefaultValue: "meta", }, { Field: "spec.name", EnvRefKey: "spec-name", - DefaultValue: "env-spec-name", + DefaultValue: "spectacles", }, { Field: "spec.associations[0].name", @@ -3527,12 +3527,12 @@ spec: { Field: "metadata.name", EnvRefKey: "meta-name", - DefaultValue: "env-meta-name", + DefaultValue: "meta", }, { Field: "spec.name", EnvRefKey: "spec-name", - DefaultValue: "env-spec-name", + DefaultValue: "spectacles", }, { Field: "spec.associations[0].name", diff --git a/pkger/testdata/bucket_ref.yml b/pkger/testdata/bucket_ref.yml index f27a672735..6870fc6517 100644 --- a/pkger/testdata/bucket_ref.yml +++ b/pkger/testdata/bucket_ref.yml @@ -4,10 +4,12 @@ metadata: name: envRef: key: meta-name + default: meta spec: name: envRef: key: spec-name + default: spectacles associations: - kind: Label name: diff --git a/pkger/testdata/checks_ref.yml b/pkger/testdata/checks_ref.yml index 8ace9cb73c..4e1590655a 100644 --- a/pkger/testdata/checks_ref.yml +++ b/pkger/testdata/checks_ref.yml @@ -4,10 +4,12 @@ metadata: name: envRef: key: meta-name + default: meta spec: name: envRef: key: spec-name + default: spectacles every: 1m offset: 15s query: | diff --git a/pkger/testdata/dashboard_ref.yml b/pkger/testdata/dashboard_ref.yml index 77ed973ce5..76cafe5274 100644 --- a/pkger/testdata/dashboard_ref.yml +++ b/pkger/testdata/dashboard_ref.yml @@ -4,10 +4,12 @@ metadata: name: envRef: key: meta-name + default: meta spec: name: envRef: key: spec-name + default: spectacles associations: - kind: Label name: diff --git a/pkger/testdata/notification_endpoint_ref.yml b/pkger/testdata/notification_endpoint_ref.yml index da813a4742..2cd6837349 100644 --- a/pkger/testdata/notification_endpoint_ref.yml +++ b/pkger/testdata/notification_endpoint_ref.yml @@ -4,10 +4,12 @@ metadata: name: envRef: key: meta-name + default: meta spec: name: envRef: key: spec-name + default: spectacles url: https://hooks.slack.com/services/bip/piddy/boppidy token: tokenval associations: diff --git a/pkger/testdata/notification_rule_ref.yml b/pkger/testdata/notification_rule_ref.yml index fc82e9b440..c32773c56e 100644 --- a/pkger/testdata/notification_rule_ref.yml +++ b/pkger/testdata/notification_rule_ref.yml @@ -4,10 +4,12 @@ metadata: name: envRef: key: meta-name + default: meta spec: name: envRef: key: spec-name + default: spectacles endpointName: envRef: key: endpoint-meta-name diff --git a/pkger/testdata/task_ref.yml b/pkger/testdata/task_ref.yml index 45ccd834dc..ce8f0c6273 100644 --- a/pkger/testdata/task_ref.yml +++ b/pkger/testdata/task_ref.yml @@ -4,10 +4,12 @@ metadata: name: envRef: key: meta-name + default: meta spec: name: envRef: key: spec-name + default: spectacles every: 10m offset: 15s query: > diff --git a/pkger/testdata/telegraf_ref.yml b/pkger/testdata/telegraf_ref.yml index f7a14f8084..ffad1dda56 100644 --- a/pkger/testdata/telegraf_ref.yml +++ b/pkger/testdata/telegraf_ref.yml @@ -4,10 +4,12 @@ metadata: name: envRef: key: meta-name + default: meta spec: name: envRef: key: spec-name + default: spectacles config: | # Configuration for telegraf agent [agent] diff --git a/pkger/testdata/variable_ref.yml b/pkger/testdata/variable_ref.yml index 798f330497..199ca4f337 100644 --- a/pkger/testdata/variable_ref.yml +++ b/pkger/testdata/variable_ref.yml @@ -4,10 +4,12 @@ metadata: name: envRef: key: meta-name + default: meta spec: name: envRef: key: spec-name + default: spectacles type: constant values: - first val