From 10ff04b6eac6a712dd224dff0fbf1b8da7a7d61f Mon Sep 17 00:00:00 2001 From: Bernd Verst Date: Wed, 21 Feb 2024 10:47:28 -0800 Subject: [PATCH] 1.13 Cherry-pick: Fix Azure App Config not working with gRPC (#3358) (#3359) Signed-off-by: Bernd Verst --- configuration/azure/appconfig/appconfig.go | 23 +++++++++++++++---- .../azure/appconfig/appconfig_test.go | 2 +- 2 files changed, 20 insertions(+), 5 deletions(-) diff --git a/configuration/azure/appconfig/appconfig.go b/configuration/azure/appconfig/appconfig.go index 8b6a7c1395..2e1b90d57f 100644 --- a/configuration/azure/appconfig/appconfig.go +++ b/configuration/azure/appconfig/appconfig.go @@ -32,6 +32,8 @@ import ( "github.com/dapr/components-contrib/configuration" contribMetadata "github.com/dapr/components-contrib/metadata" + kitmd "github.com/dapr/kit/metadata" + "github.com/dapr/kit/logger" ) @@ -201,8 +203,14 @@ func (r *ConfigurationStore) getAll(ctx context.Context, req *configuration.GetR } func (r *ConfigurationStore) getLabelFromMetadata(metadata map[string]string) *string { - if s, ok := metadata["label"]; ok && s != "" { - return to.Ptr(s) + type labelMetadata = struct { + Label string `mapstructure:"label"` + } + var label labelMetadata + kitmd.DecodeMetadata(metadata, &label) + + if label.Label != "" { + return to.Ptr(label.Label) } return nil @@ -284,9 +292,16 @@ func (r *ConfigurationStore) handleSubscribedChange(ctx context.Context, handler } func (r *ConfigurationStore) getSentinelKeyFromMetadata(metadata map[string]string) string { - if s, ok := metadata["sentinelKey"]; ok && s != "" { - return s + type sentinelKeyMetadata = struct { + SentinelKey string `mapstructure:"sentinelKey"` } + var sentinelKey sentinelKeyMetadata + kitmd.DecodeMetadata(metadata, &sentinelKey) + + if sentinelKey.SentinelKey != "" { + return sentinelKey.SentinelKey + } + return "" } diff --git a/configuration/azure/appconfig/appconfig_test.go b/configuration/azure/appconfig/appconfig_test.go index b351f6b232..0bc6910229 100644 --- a/configuration/azure/appconfig/appconfig_test.go +++ b/configuration/azure/appconfig/appconfig_test.go @@ -122,7 +122,7 @@ func Test_subscribeConfigurationWithProvidedKeys(t *testing.T) { s.client = &MockConfigurationStore{} metadata := make(map[string]string) - metadata["sentinelKey"] = "test_sentinel_key" + metadata["sentinelkey"] = "test_sentinel_key" t.Run("call subscribe with sentinel key", func(t *testing.T) { req := configuration.SubscribeRequest{