From b28922ce30ae339005181fb650a98b61ad21afc6 Mon Sep 17 00:00:00 2001 From: Nicolas Bigler Date: Mon, 21 Mar 2022 17:21:16 +0100 Subject: [PATCH] Set correct instance_id in metrics endpoint URL The URL holds the name of the db cluster instance and not the database object itself Signed-off-by: Nicolas Bigler --- pkg/brokerapi/brokerapi_test.go | 6 +++--- pkg/crossplane/service_mariadb_database.go | 12 ++++++------ 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/pkg/brokerapi/brokerapi_test.go b/pkg/brokerapi/brokerapi_test.go index 6c31fd9..d492839 100644 --- a/pkg/brokerapi/brokerapi_test.go +++ b/pkg/brokerapi/brokerapi_test.go @@ -1082,9 +1082,9 @@ func (ts *EnvTestSuite) TestBrokerAPI_Bind() { "jdbcUrl": "***", "jdbcUrlMariaDb": "***", "metricsEndpoints": []string{ - "http://1-2-1-mariadb-0.dbaas-test-cluster.metrics.example.tld", - "http://1-2-1-mariadb-1.dbaas-test-cluster.metrics.example.tld", - "http://1-2-1-mariadb-2.dbaas-test-cluster.metrics.example.tld", + "http://1-1-1-mariadb-0.dbaas-test-cluster.metrics.example.tld", + "http://1-1-1-mariadb-1.dbaas-test-cluster.metrics.example.tld", + "http://1-1-1-mariadb-2.dbaas-test-cluster.metrics.example.tld", }, }, }, diff --git a/pkg/crossplane/service_mariadb_database.go b/pkg/crossplane/service_mariadb_database.go index b86c6e5..b51cf9d 100644 --- a/pkg/crossplane/service_mariadb_database.go +++ b/pkg/crossplane/service_mariadb_database.go @@ -101,7 +101,7 @@ func (msb MariadbDatabaseServiceBinder) Bind(ctx context.Context, bindingID stri return nil, fmt.Errorf("Could not get parent instance: %w", err) } cn := parent.GetLabels()["service.syn.tools/cluster"] - creds := createCredentials(endpoint, bindingID, pw, msb.instance.ID(), cn, msb.cp.config.EnableMetrics, msb.cp.config.MetricsDomain) + creds := createCredentials(endpoint, bindingID, pw, msb.instance.ID(), msb.instance.Labels.ParentID, cn, msb.cp.config.EnableMetrics, msb.cp.config.MetricsDomain) return creds, nil } @@ -166,7 +166,7 @@ func (msb MariadbDatabaseServiceBinder) GetBinding(ctx context.Context, bindingI } cn := parent.GetLabels()["service.syn.tools/cluster"] pw := string(secret.Data[xrv1.ResourceCredentialsSecretPasswordKey]) - creds := createCredentials(endpoint, bindingID, pw, msb.instance.ID(), cn, msb.cp.config.EnableMetrics, msb.cp.config.MetricsDomain) + creds := createCredentials(endpoint, bindingID, pw, msb.instance.ID(), msb.instance.Labels.ParentID, cn, msb.cp.config.EnableMetrics, msb.cp.config.MetricsDomain) return creds, nil } @@ -250,7 +250,7 @@ func mapMariadbEndpoint(data map[string][]byte) (*Endpoint, error) { }, nil } -func createCredentials(endpoint *Endpoint, username, password, database, clusterName string, metricsEnabled bool, metricsDomain string) Credentials { +func createCredentials(endpoint *Endpoint, username, password, database, databaseParent string, clusterName string, metricsEnabled bool, metricsDomain string) Credentials { uri := fmt.Sprintf("mysql://%s:%s@%s:%d/%s?reconnect=true", username, password, endpoint.Host, endpoint.Port, database) creds := Credentials{ @@ -268,9 +268,9 @@ func createCredentials(endpoint *Endpoint, username, password, database, cluster } if metricsEnabled { creds["metricsEndpoints"] = []string{ - fmt.Sprintf("http://%s-mariadb-0.%s.%s", database, clusterName, metricsDomain), - fmt.Sprintf("http://%s-mariadb-1.%s.%s", database, clusterName, metricsDomain), - fmt.Sprintf("http://%s-mariadb-2.%s.%s", database, clusterName, metricsDomain), + fmt.Sprintf("http://%s-mariadb-0.%s.%s", databaseParent, clusterName, metricsDomain), + fmt.Sprintf("http://%s-mariadb-1.%s.%s", databaseParent, clusterName, metricsDomain), + fmt.Sprintf("http://%s-mariadb-2.%s.%s", databaseParent, clusterName, metricsDomain), } }