From fd3c686528cc1b517be6c92da8bd7e65625118ad Mon Sep 17 00:00:00 2001 From: Oliver Lockwood Date: Tue, 28 May 2024 13:40:44 +0100 Subject: [PATCH] Apply code review feedback Signed-off-by: Oliver Lockwood --- .../rest/src/main/java/org/opensearch/client/Request.java | 8 +++++++- .../main/java/org/opensearch/client/RequestOptions.java | 6 ++++-- .../src/main/java/org/opensearch/client/RestClient.java | 1 - 3 files changed, 11 insertions(+), 4 deletions(-) diff --git a/client/rest/src/main/java/org/opensearch/client/Request.java b/client/rest/src/main/java/org/opensearch/client/Request.java index df81ca7f717ae..9bf8cce3e70e7 100644 --- a/client/rest/src/main/java/org/opensearch/client/Request.java +++ b/client/rest/src/main/java/org/opensearch/client/Request.java @@ -110,7 +110,13 @@ public void addParameters(Map paramSource) { * will change it. */ public Map getParameters() { - return unmodifiableMap(parameters); + if (options.getParameters().isEmpty()) { + return unmodifiableMap(parameters); + } else { + Map combinedParameters = new HashMap<>(parameters); + combinedParameters.putAll(options.getParameters()); + return unmodifiableMap(combinedParameters); + } } /** diff --git a/client/rest/src/main/java/org/opensearch/client/RequestOptions.java b/client/rest/src/main/java/org/opensearch/client/RequestOptions.java index 1c5ec56c1c62e..13a14b9e4da12 100644 --- a/client/rest/src/main/java/org/opensearch/client/RequestOptions.java +++ b/client/rest/src/main/java/org/opensearch/client/RequestOptions.java @@ -91,7 +91,8 @@ public List
getHeaders() { } /** - * Query parameters to attach to the request. + * Query parameters to attach to the request. Any parameters present here + * will override matching parameters in the {@link Request}, if they exist. */ public Map getParameters() { return parameters; @@ -240,7 +241,8 @@ public Builder addHeader(String name, String value) { } /** - * Add the provided query parameter to the request. + * Add the provided query parameter to the request. Any parameters added here + * will override matching parameters in the {@link Request}, if they exist. * * @param name the query parameter name * @param value the query parameter value diff --git a/client/rest/src/main/java/org/opensearch/client/RestClient.java b/client/rest/src/main/java/org/opensearch/client/RestClient.java index dcedaf0cf598d..3e07365f4f80e 100644 --- a/client/rest/src/main/java/org/opensearch/client/RestClient.java +++ b/client/rest/src/main/java/org/opensearch/client/RestClient.java @@ -810,7 +810,6 @@ private class InternalRequest { InternalRequest(Request request) { this.request = request; Map params = new HashMap<>(request.getParameters()); - params.putAll(request.getOptions().getParameters()); // ignore is a special parameter supported by the clients, shouldn't be sent to es String ignoreString = params.remove("ignore"); this.ignoreErrorCodes = getIgnoreErrorCodes(ignoreString, request.getMethod());