REST high-level client: move to POST when calling API to retrieve which support request body (#28342)
It has been pointed out that GET with body may cause problems to some proxies. We are then switching to POST the API that retrieve info and support a request body. Closes #28326
This commit is contained in:
parent
9db23e48cd
commit
45e1fe8bfc
|
@ -358,7 +358,7 @@ public final class Request {
|
||||||
parameters.withRealtime(multiGetRequest.realtime());
|
parameters.withRealtime(multiGetRequest.realtime());
|
||||||
parameters.withRefresh(multiGetRequest.refresh());
|
parameters.withRefresh(multiGetRequest.refresh());
|
||||||
HttpEntity entity = createEntity(multiGetRequest, REQUEST_BODY_CONTENT_TYPE);
|
HttpEntity entity = createEntity(multiGetRequest, REQUEST_BODY_CONTENT_TYPE);
|
||||||
return new Request(HttpGet.METHOD_NAME, "/_mget", parameters.getParams(), entity);
|
return new Request(HttpPost.METHOD_NAME, "/_mget", parameters.getParams(), entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Request index(IndexRequest indexRequest) {
|
static Request index(IndexRequest indexRequest) {
|
||||||
|
@ -447,17 +447,17 @@ public final class Request {
|
||||||
if (searchRequest.source() != null) {
|
if (searchRequest.source() != null) {
|
||||||
entity = createEntity(searchRequest.source(), REQUEST_BODY_CONTENT_TYPE);
|
entity = createEntity(searchRequest.source(), REQUEST_BODY_CONTENT_TYPE);
|
||||||
}
|
}
|
||||||
return new Request(HttpGet.METHOD_NAME, endpoint, params.getParams(), entity);
|
return new Request(HttpPost.METHOD_NAME, endpoint, params.getParams(), entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Request searchScroll(SearchScrollRequest searchScrollRequest) throws IOException {
|
static Request searchScroll(SearchScrollRequest searchScrollRequest) throws IOException {
|
||||||
HttpEntity entity = createEntity(searchScrollRequest, REQUEST_BODY_CONTENT_TYPE);
|
HttpEntity entity = createEntity(searchScrollRequest, REQUEST_BODY_CONTENT_TYPE);
|
||||||
return new Request("GET", "/_search/scroll", Collections.emptyMap(), entity);
|
return new Request(HttpPost.METHOD_NAME, "/_search/scroll", Collections.emptyMap(), entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Request clearScroll(ClearScrollRequest clearScrollRequest) throws IOException {
|
static Request clearScroll(ClearScrollRequest clearScrollRequest) throws IOException {
|
||||||
HttpEntity entity = createEntity(clearScrollRequest, REQUEST_BODY_CONTENT_TYPE);
|
HttpEntity entity = createEntity(clearScrollRequest, REQUEST_BODY_CONTENT_TYPE);
|
||||||
return new Request("DELETE", "/_search/scroll", Collections.emptyMap(), entity);
|
return new Request(HttpDelete.METHOD_NAME, "/_search/scroll", Collections.emptyMap(), entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Request multiSearch(MultiSearchRequest multiSearchRequest) throws IOException {
|
static Request multiSearch(MultiSearchRequest multiSearchRequest) throws IOException {
|
||||||
|
@ -469,7 +469,7 @@ public final class Request {
|
||||||
XContent xContent = REQUEST_BODY_CONTENT_TYPE.xContent();
|
XContent xContent = REQUEST_BODY_CONTENT_TYPE.xContent();
|
||||||
byte[] source = MultiSearchRequest.writeMultiLineFormat(multiSearchRequest, xContent);
|
byte[] source = MultiSearchRequest.writeMultiLineFormat(multiSearchRequest, xContent);
|
||||||
HttpEntity entity = new ByteArrayEntity(source, createContentType(xContent.type()));
|
HttpEntity entity = new ByteArrayEntity(source, createContentType(xContent.type()));
|
||||||
return new Request("GET", "/_msearch", params.getParams(), entity);
|
return new Request(HttpPost.METHOD_NAME, "/_msearch", params.getParams(), entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static HttpEntity createEntity(ToXContent toXContent, XContentType xContentType) throws IOException {
|
private static HttpEntity createEntity(ToXContent toXContent, XContentType xContentType) throws IOException {
|
||||||
|
|
|
@ -20,6 +20,11 @@
|
||||||
package org.elasticsearch.client;
|
package org.elasticsearch.client;
|
||||||
|
|
||||||
import org.apache.http.HttpEntity;
|
import org.apache.http.HttpEntity;
|
||||||
|
import org.apache.http.client.methods.HttpDelete;
|
||||||
|
import org.apache.http.client.methods.HttpGet;
|
||||||
|
import org.apache.http.client.methods.HttpHead;
|
||||||
|
import org.apache.http.client.methods.HttpPost;
|
||||||
|
import org.apache.http.client.methods.HttpPut;
|
||||||
import org.apache.http.entity.ByteArrayEntity;
|
import org.apache.http.entity.ByteArrayEntity;
|
||||||
import org.apache.http.entity.ContentType;
|
import org.apache.http.entity.ContentType;
|
||||||
import org.apache.http.entity.StringEntity;
|
import org.apache.http.entity.StringEntity;
|
||||||
|
@ -138,7 +143,7 @@ public class RequestTests extends ESTestCase {
|
||||||
assertEquals("/", request.getEndpoint());
|
assertEquals("/", request.getEndpoint());
|
||||||
assertEquals(0, request.getParameters().size());
|
assertEquals(0, request.getParameters().size());
|
||||||
assertNull(request.getEntity());
|
assertNull(request.getEntity());
|
||||||
assertEquals("HEAD", request.getMethod());
|
assertEquals(HttpHead.METHOD_NAME, request.getMethod());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testInfo() {
|
public void testInfo() {
|
||||||
|
@ -146,11 +151,11 @@ public class RequestTests extends ESTestCase {
|
||||||
assertEquals("/", request.getEndpoint());
|
assertEquals("/", request.getEndpoint());
|
||||||
assertEquals(0, request.getParameters().size());
|
assertEquals(0, request.getParameters().size());
|
||||||
assertNull(request.getEntity());
|
assertNull(request.getEntity());
|
||||||
assertEquals("GET", request.getMethod());
|
assertEquals(HttpGet.METHOD_NAME, request.getMethod());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testGet() {
|
public void testGet() {
|
||||||
getAndExistsTest(Request::get, "GET");
|
getAndExistsTest(Request::get, HttpGet.METHOD_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testMultiGet() throws IOException {
|
public void testMultiGet() throws IOException {
|
||||||
|
@ -200,7 +205,7 @@ public class RequestTests extends ESTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
Request request = Request.multiGet(multiGetRequest);
|
Request request = Request.multiGet(multiGetRequest);
|
||||||
assertEquals("GET", request.getMethod());
|
assertEquals(HttpPost.METHOD_NAME, request.getMethod());
|
||||||
assertEquals("/_mget", request.getEndpoint());
|
assertEquals("/_mget", request.getEndpoint());
|
||||||
assertEquals(expectedParams, request.getParameters());
|
assertEquals(expectedParams, request.getParameters());
|
||||||
assertToXContentBody(multiGetRequest, request.getEntity());
|
assertToXContentBody(multiGetRequest, request.getEntity());
|
||||||
|
@ -240,7 +245,7 @@ public class RequestTests extends ESTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testExists() {
|
public void testExists() {
|
||||||
getAndExistsTest(Request::exists, "HEAD");
|
getAndExistsTest(Request::exists, HttpHead.METHOD_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void getAndExistsTest(Function<GetRequest, Request> requestConverter, String method) {
|
private static void getAndExistsTest(Function<GetRequest, Request> requestConverter, String method) {
|
||||||
|
@ -317,7 +322,7 @@ public class RequestTests extends ESTestCase {
|
||||||
Request request = Request.createIndex(createIndexRequest);
|
Request request = Request.createIndex(createIndexRequest);
|
||||||
assertEquals("/" + indexName, request.getEndpoint());
|
assertEquals("/" + indexName, request.getEndpoint());
|
||||||
assertEquals(expectedParams, request.getParameters());
|
assertEquals(expectedParams, request.getParameters());
|
||||||
assertEquals("PUT", request.getMethod());
|
assertEquals(HttpPut.METHOD_NAME, request.getMethod());
|
||||||
assertToXContentBody(createIndexRequest, request.getEntity());
|
assertToXContentBody(createIndexRequest, request.getEntity());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -365,7 +370,7 @@ public class RequestTests extends ESTestCase {
|
||||||
assertEquals(endpoint.toString(), request.getEndpoint());
|
assertEquals(endpoint.toString(), request.getEndpoint());
|
||||||
|
|
||||||
assertEquals(expectedParams, request.getParameters());
|
assertEquals(expectedParams, request.getParameters());
|
||||||
assertEquals("PUT", request.getMethod());
|
assertEquals(HttpPut.METHOD_NAME, request.getMethod());
|
||||||
assertToXContentBody(putMappingRequest, request.getEntity());
|
assertToXContentBody(putMappingRequest, request.getEntity());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -382,7 +387,7 @@ public class RequestTests extends ESTestCase {
|
||||||
Request request = Request.deleteIndex(deleteIndexRequest);
|
Request request = Request.deleteIndex(deleteIndexRequest);
|
||||||
assertEquals("/" + String.join(",", indices), request.getEndpoint());
|
assertEquals("/" + String.join(",", indices), request.getEndpoint());
|
||||||
assertEquals(expectedParams, request.getParameters());
|
assertEquals(expectedParams, request.getParameters());
|
||||||
assertEquals("DELETE", request.getMethod());
|
assertEquals(HttpDelete.METHOD_NAME, request.getMethod());
|
||||||
assertNull(request.getEntity());
|
assertNull(request.getEntity());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -401,7 +406,7 @@ public class RequestTests extends ESTestCase {
|
||||||
StringJoiner endpoint = new StringJoiner("/", "/", "").add(String.join(",", indices)).add("_open");
|
StringJoiner endpoint = new StringJoiner("/", "/", "").add(String.join(",", indices)).add("_open");
|
||||||
assertThat(endpoint.toString(), equalTo(request.getEndpoint()));
|
assertThat(endpoint.toString(), equalTo(request.getEndpoint()));
|
||||||
assertThat(expectedParams, equalTo(request.getParameters()));
|
assertThat(expectedParams, equalTo(request.getParameters()));
|
||||||
assertThat(request.getMethod(), equalTo("POST"));
|
assertThat(request.getMethod(), equalTo(HttpPost.METHOD_NAME));
|
||||||
assertThat(request.getEntity(), nullValue());
|
assertThat(request.getEntity(), nullValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -418,7 +423,7 @@ public class RequestTests extends ESTestCase {
|
||||||
StringJoiner endpoint = new StringJoiner("/", "/", "").add(String.join(",", indices)).add("_close");
|
StringJoiner endpoint = new StringJoiner("/", "/", "").add(String.join(",", indices)).add("_close");
|
||||||
assertThat(endpoint.toString(), equalTo(request.getEndpoint()));
|
assertThat(endpoint.toString(), equalTo(request.getEndpoint()));
|
||||||
assertThat(expectedParams, equalTo(request.getParameters()));
|
assertThat(expectedParams, equalTo(request.getParameters()));
|
||||||
assertThat(request.getMethod(), equalTo("POST"));
|
assertThat(request.getMethod(), equalTo(HttpPost.METHOD_NAME));
|
||||||
assertThat(request.getEntity(), nullValue());
|
assertThat(request.getEntity(), nullValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -432,9 +437,9 @@ public class RequestTests extends ESTestCase {
|
||||||
|
|
||||||
Map<String, String> expectedParams = new HashMap<>();
|
Map<String, String> expectedParams = new HashMap<>();
|
||||||
|
|
||||||
String method = "POST";
|
String method = HttpPost.METHOD_NAME;
|
||||||
if (id != null) {
|
if (id != null) {
|
||||||
method = "PUT";
|
method = HttpPut.METHOD_NAME;
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
indexRequest.opType(DocWriteRequest.OpType.CREATE);
|
indexRequest.opType(DocWriteRequest.OpType.CREATE);
|
||||||
}
|
}
|
||||||
|
@ -569,7 +574,7 @@ public class RequestTests extends ESTestCase {
|
||||||
Request request = Request.update(updateRequest);
|
Request request = Request.update(updateRequest);
|
||||||
assertEquals("/" + index + "/" + type + "/" + id + "/_update", request.getEndpoint());
|
assertEquals("/" + index + "/" + type + "/" + id + "/_update", request.getEndpoint());
|
||||||
assertEquals(expectedParams, request.getParameters());
|
assertEquals(expectedParams, request.getParameters());
|
||||||
assertEquals("POST", request.getMethod());
|
assertEquals(HttpPost.METHOD_NAME, request.getMethod());
|
||||||
|
|
||||||
HttpEntity entity = request.getEntity();
|
HttpEntity entity = request.getEntity();
|
||||||
assertTrue(entity instanceof ByteArrayEntity);
|
assertTrue(entity instanceof ByteArrayEntity);
|
||||||
|
@ -683,7 +688,7 @@ public class RequestTests extends ESTestCase {
|
||||||
Request request = Request.bulk(bulkRequest);
|
Request request = Request.bulk(bulkRequest);
|
||||||
assertEquals("/_bulk", request.getEndpoint());
|
assertEquals("/_bulk", request.getEndpoint());
|
||||||
assertEquals(expectedParams, request.getParameters());
|
assertEquals(expectedParams, request.getParameters());
|
||||||
assertEquals("POST", request.getMethod());
|
assertEquals(HttpPost.METHOD_NAME, request.getMethod());
|
||||||
assertEquals(xContentType.mediaTypeWithoutParameters(), request.getEntity().getContentType().getValue());
|
assertEquals(xContentType.mediaTypeWithoutParameters(), request.getEntity().getContentType().getValue());
|
||||||
byte[] content = new byte[(int) request.getEntity().getContentLength()];
|
byte[] content = new byte[(int) request.getEntity().getContentLength()];
|
||||||
try (InputStream inputStream = request.getEntity().getContent()) {
|
try (InputStream inputStream = request.getEntity().getContent()) {
|
||||||
|
@ -894,6 +899,7 @@ public class RequestTests extends ESTestCase {
|
||||||
endpoint.add(type);
|
endpoint.add(type);
|
||||||
}
|
}
|
||||||
endpoint.add("_search");
|
endpoint.add("_search");
|
||||||
|
assertEquals(HttpPost.METHOD_NAME, request.getMethod());
|
||||||
assertEquals(endpoint.toString(), request.getEndpoint());
|
assertEquals(endpoint.toString(), request.getEndpoint());
|
||||||
assertEquals(expectedParams, request.getParameters());
|
assertEquals(expectedParams, request.getParameters());
|
||||||
assertToXContentBody(searchSourceBuilder, request.getEntity());
|
assertToXContentBody(searchSourceBuilder, request.getEntity());
|
||||||
|
@ -932,6 +938,7 @@ public class RequestTests extends ESTestCase {
|
||||||
|
|
||||||
Request request = Request.multiSearch(multiSearchRequest);
|
Request request = Request.multiSearch(multiSearchRequest);
|
||||||
assertEquals("/_msearch", request.getEndpoint());
|
assertEquals("/_msearch", request.getEndpoint());
|
||||||
|
assertEquals(HttpPost.METHOD_NAME, request.getMethod());
|
||||||
assertEquals(expectedParams, request.getParameters());
|
assertEquals(expectedParams, request.getParameters());
|
||||||
|
|
||||||
List<SearchRequest> requests = new ArrayList<>();
|
List<SearchRequest> requests = new ArrayList<>();
|
||||||
|
@ -955,7 +962,7 @@ public class RequestTests extends ESTestCase {
|
||||||
searchScrollRequest.scroll(randomPositiveTimeValue());
|
searchScrollRequest.scroll(randomPositiveTimeValue());
|
||||||
}
|
}
|
||||||
Request request = Request.searchScroll(searchScrollRequest);
|
Request request = Request.searchScroll(searchScrollRequest);
|
||||||
assertEquals("GET", request.getMethod());
|
assertEquals(HttpPost.METHOD_NAME, request.getMethod());
|
||||||
assertEquals("/_search/scroll", request.getEndpoint());
|
assertEquals("/_search/scroll", request.getEndpoint());
|
||||||
assertEquals(0, request.getParameters().size());
|
assertEquals(0, request.getParameters().size());
|
||||||
assertToXContentBody(searchScrollRequest, request.getEntity());
|
assertToXContentBody(searchScrollRequest, request.getEntity());
|
||||||
|
@ -969,7 +976,7 @@ public class RequestTests extends ESTestCase {
|
||||||
clearScrollRequest.addScrollId(randomAlphaOfLengthBetween(5, 10));
|
clearScrollRequest.addScrollId(randomAlphaOfLengthBetween(5, 10));
|
||||||
}
|
}
|
||||||
Request request = Request.clearScroll(clearScrollRequest);
|
Request request = Request.clearScroll(clearScrollRequest);
|
||||||
assertEquals("DELETE", request.getMethod());
|
assertEquals(HttpDelete.METHOD_NAME, request.getMethod());
|
||||||
assertEquals("/_search/scroll", request.getEndpoint());
|
assertEquals("/_search/scroll", request.getEndpoint());
|
||||||
assertEquals(0, request.getParameters().size());
|
assertEquals(0, request.getParameters().size());
|
||||||
assertToXContentBody(clearScrollRequest, request.getEntity());
|
assertToXContentBody(clearScrollRequest, request.getEntity());
|
||||||
|
|
|
@ -179,7 +179,7 @@ public class RestHighLevelClientTests extends ESTestCase {
|
||||||
assertEquals(5, searchResponse.getTotalShards());
|
assertEquals(5, searchResponse.getTotalShards());
|
||||||
assertEquals(5, searchResponse.getSuccessfulShards());
|
assertEquals(5, searchResponse.getSuccessfulShards());
|
||||||
assertEquals(100, searchResponse.getTook().getMillis());
|
assertEquals(100, searchResponse.getTook().getMillis());
|
||||||
verify(restClient).performRequest(eq("GET"), eq("/_search/scroll"), eq(Collections.emptyMap()),
|
verify(restClient).performRequest(eq("POST"), eq("/_search/scroll"), eq(Collections.emptyMap()),
|
||||||
isNotNull(HttpEntity.class), argThat(new HeadersVarargMatcher(headers)));
|
isNotNull(HttpEntity.class), argThat(new HeadersVarargMatcher(headers)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue