From cb8fbc6a685d450aaa31fca827ebf166ceaf9a11 Mon Sep 17 00:00:00 2001 From: Raphael 'kena' Poss Date: Tue, 4 Jul 2023 17:38:13 +0000 Subject: [PATCH] server: use HTTP query parameter `cluster` for manual selection Prior to this patch, there was a debug-only way to manually force a HTTP request to be routed to a particular virtual cluster through the server controller. This was achieved via the query parameter `tenant_name`. This patch renames the paramater to `cluster`, for a better UX coherence with the option of the same name in `cockroach sql`. Release note: None --- pkg/cli/democluster/demo_cluster.go | 6 +++--- pkg/cli/interactive_tests/test_demo_cli_integration.tcl | 4 ++-- pkg/server/server_controller_http.go | 7 ++++--- pkg/server/testserver_http.go | 2 +- 4 files changed, 10 insertions(+), 9 deletions(-) diff --git a/pkg/cli/democluster/demo_cluster.go b/pkg/cli/democluster/demo_cluster.go index 365458fe0900..3d55147124bc 100644 --- a/pkg/cli/democluster/demo_cluster.go +++ b/pkg/cli/democluster/demo_cluster.go @@ -1928,8 +1928,8 @@ func (c *transientCluster) ListDemoNodes(w, ew io.Writer, justOne, verbose bool) if !c.demoCtx.Multitenant || verbose { // Connection parameters for the system tenant follow. uiURL := s.Cfg.AdminURL() - if q := uiURL.Query(); c.demoCtx.Multitenant && !c.demoCtx.DisableServerController && !q.Has(server.TenantNameParamInQueryURL) { - q.Add(server.TenantNameParamInQueryURL, catconstants.SystemTenantName) + if q := uiURL.Query(); c.demoCtx.Multitenant && !c.demoCtx.DisableServerController && !q.Has(server.ClusterNameParamInQueryURL) { + q.Add(server.ClusterNameParamInQueryURL, catconstants.SystemTenantName) uiURL.RawQuery = q.Encode() } @@ -2011,7 +2011,7 @@ func (c *transientCluster) addDemoLoginToURL(uiURL *url.URL, includeTenantName b } if !includeTenantName { - q.Del(server.TenantNameParamInQueryURL) + q.Del(server.ClusterNameParamInQueryURL) } uiURL.RawQuery = q.Encode() diff --git a/pkg/cli/interactive_tests/test_demo_cli_integration.tcl b/pkg/cli/interactive_tests/test_demo_cli_integration.tcl index 11d5a41f371f..b28d7adebe22 100644 --- a/pkg/cli/interactive_tests/test_demo_cli_integration.tcl +++ b/pkg/cli/interactive_tests/test_demo_cli_integration.tcl @@ -167,7 +167,7 @@ eexpect ":/# " # Check that the cookies work. set pyfile [file join [file dirname $argv0] test_auth_cookie.py] -send "$python $pyfile cookie_system.txt 'http://localhost:8080/_admin/v1/users?tenant_name=system'\r" +send "$python $pyfile cookie_system.txt 'http://localhost:8080/_admin/v1/users?cluster=system'\r" eexpect "username" eexpect "demo" # No tenant name specified -> use default tenant. @@ -190,7 +190,7 @@ eexpect "defaultdb>" set spawn_id $shell_spawn_id -send "$python $pyfile cookie_system.txt 'http://localhost:8080/_admin/v1/users?tenant_name=system'\r" +send "$python $pyfile cookie_system.txt 'http://localhost:8080/_admin/v1/users?cluster=system'\r" eexpect "username" eexpect "demo" # No tenant name specified -> use default tenant. diff --git a/pkg/server/server_controller_http.go b/pkg/server/server_controller_http.go index 2e0439aee12a..59a1f088d94d 100644 --- a/pkg/server/server_controller_http.go +++ b/pkg/server/server_controller_http.go @@ -28,8 +28,9 @@ const ( // TenantSelectHeader is the HTTP header used to select a particular tenant. TenantSelectHeader = `X-Cockroach-Tenant` - // TenantNameParamInQueryURL is the HTTP query URL parameter used to select a particular tenant. - TenantNameParamInQueryURL = "tenant_name" + // ClusterNameParamInQueryURL is the HTTP query URL parameter used + // to select a particular virtual cluster. + ClusterNameParamInQueryURL = "cluster" // TenantSelectCookieName is the name of the HTTP cookie used to select a particular tenant, // if the custom header is not specified. @@ -109,7 +110,7 @@ func (c *serverController) httpMux(w http.ResponseWriter, r *http.Request) { func getTenantNameFromHTTPRequest(st *cluster.Settings, r *http.Request) roachpb.TenantName { // Highest priority is manual override on the URL query parameters. - if tenantName := r.URL.Query().Get(TenantNameParamInQueryURL); tenantName != "" { + if tenantName := r.URL.Query().Get(ClusterNameParamInQueryURL); tenantName != "" { return roachpb.TenantName(tenantName) } diff --git a/pkg/server/testserver_http.go b/pkg/server/testserver_http.go index d560de7318a7..b4c53329578f 100644 --- a/pkg/server/testserver_http.go +++ b/pkg/server/testserver_http.go @@ -68,7 +68,7 @@ func (ts *httpTestServer) AdminURL() string { u := ts.t.sqlServer.execCfg.RPCContext.Config.AdminURL() if ts.t.tenantName != "" { q := u.Query() - q.Add(TenantNameParamInQueryURL, string(ts.t.tenantName)) + q.Add(ClusterNameParamInQueryURL, string(ts.t.tenantName)) u.RawQuery = q.Encode() } return u.String()