From f9ee728fcfc10bb4c76b4f1f31bbe242d1b5e555 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Juraci=20Paix=C3=A3o=20Kr=C3=B6hling?= Date: Thu, 7 Jul 2022 11:36:36 -0300 Subject: [PATCH 1/2] Change metadata lookup to be case insensitive MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Before this change, users would make references to headers such as "authorization" and "X-CloudFront-Viewer-Latitude", which would potentially fail, as they would be stored in the context as "X-Cloudfront-Viewer-Latitude" or "Authorization". This PR changes this behavior, to attempt a case insensitive lookup to the backing map in case the key wasn't found under the requested casing. Under the assumption that the lookup key specified by users won't change, on a subsequent lookup, we proactively copy the value to the looked up key, to make the next lookup faster. Fixes #5610 Fixes open-telemetry/opentelemetry-collector-contrib#8994 Signed-off-by: Juraci Paixão Kröhling --- client/client.go | 15 ++++++++++++++- client/client_test.go | 1 + 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/client/client.go b/client/client.go index b5974e53a06..4b3f701badb 100644 --- a/client/client.go +++ b/client/client.go @@ -91,6 +91,7 @@ package client // import "go.opentelemetry.io/collector/client" import ( "context" "net" + "strings" ) type ctxKey struct{} @@ -160,7 +161,19 @@ func NewMetadata(md map[string][]string) Metadata { func (m Metadata) Get(key string) []string { vals := m.data[key] if len(vals) == 0 { - return nil + // we didn't find the key, but perhaps it just has different cases? + for k, v := range m.data { + if strings.EqualFold(key, k) { + vals = v + // we optimize for the next lookup + m.data[key] = v + } + } + + // if it's still not found, it's really not here + if len(vals) == 0 { + return nil + } } ret := make([]string, len(vals)) diff --git a/client/client_test.go b/client/client_test.go index 3249e84e905..a43fecc7e0b 100644 --- a/client/client_test.go +++ b/client/client_test.go @@ -91,6 +91,7 @@ func TestMetadata(t *testing.T) { source := map[string][]string{"test-key": {"test-val"}} md := NewMetadata(source) assert.Equal(t, []string{"test-val"}, md.Get("test-key")) + assert.Equal(t, []string{"test-val"}, md.Get("test-KEY")) // case insensitive lookup // test if copy. In regular use, source cannot change val := md.Get("test-key") From cdefedb036844102dce381a75216abc1db2cb98e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Juraci=20Paix=C3=A3o=20Kr=C3=B6hling?= Date: Thu, 7 Jul 2022 11:40:30 -0300 Subject: [PATCH 2/2] Add changelog entry MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Juraci Paixão Kröhling --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index eb1f277c22c..3b790c99924 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,7 @@ ### 💡 Enhancements 💡 - Add `linux-ppc64le` architecture to cross build tests in CI +- `client`: perform case insensitive lookups in case the requested metadata value isn't found (#5646) ## v0.55.0 Beta