co.elastic.clients.elasticsearch.sql.QueryRequest Maven / Gradle / Ivy
/*
* Licensed to Elasticsearch B.V. under one or more contributor
* license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright
* ownership. Elasticsearch B.V. licenses this file to you under
* the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package co.elastic.clients.elasticsearch.sql;
import co.elastic.clients.elasticsearch._types.ErrorResponse;
import co.elastic.clients.elasticsearch._types.RequestBase;
import co.elastic.clients.elasticsearch._types.Time;
import co.elastic.clients.elasticsearch._types.mapping.RuntimeField;
import co.elastic.clients.elasticsearch._types.query_dsl.Query;
import co.elastic.clients.elasticsearch.sql.query.SqlFormat;
import co.elastic.clients.json.JsonData;
import co.elastic.clients.json.JsonpDeserializable;
import co.elastic.clients.json.JsonpDeserializer;
import co.elastic.clients.json.JsonpMapper;
import co.elastic.clients.json.JsonpSerializable;
import co.elastic.clients.json.ObjectBuilderDeserializer;
import co.elastic.clients.json.ObjectDeserializer;
import co.elastic.clients.transport.Endpoint;
import co.elastic.clients.transport.endpoints.SimpleEndpoint;
import co.elastic.clients.util.ApiTypeHelper;
import co.elastic.clients.util.ObjectBuilder;
import jakarta.json.stream.JsonGenerator;
import java.lang.Boolean;
import java.lang.Integer;
import java.lang.String;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.Objects;
import java.util.function.Function;
import javax.annotation.Nullable;
//----------------------------------------------------------------
// THIS CODE IS GENERATED. MANUAL EDITS WILL BE LOST.
//----------------------------------------------------------------
//
// This code is generated from the Elasticsearch API specification
// at https://github.com/elastic/elasticsearch-specification
//
// Manual updates to this file will be lost when the code is
// re-generated.
//
// If you find a property that is missing or wrongly typed, please
// open an issue or a PR on the API specification repository.
//
//----------------------------------------------------------------
// typedef: sql.query.Request
/**
* Executes a SQL request
*
* @see API
* specification
*/
@JsonpDeserializable
public class QueryRequest extends RequestBase implements JsonpSerializable {
@Nullable
private final String catalog;
@Nullable
private final Boolean columnar;
@Nullable
private final String cursor;
@Nullable
private final Integer fetchSize;
@Nullable
private final Boolean fieldMultiValueLeniency;
@Nullable
private final Query filter;
@Nullable
private final SqlFormat format;
@Nullable
private final Boolean indexUsingFrozen;
@Nullable
private final Time keepAlive;
@Nullable
private final Boolean keepOnCompletion;
@Nullable
private final Time pageTimeout;
private final Map params;
@Nullable
private final String query;
@Nullable
private final Time requestTimeout;
private final Map runtimeMappings;
@Nullable
private final String timeZone;
@Nullable
private final Time waitForCompletionTimeout;
// ---------------------------------------------------------------------------------------------
private QueryRequest(Builder builder) {
this.catalog = builder.catalog;
this.columnar = builder.columnar;
this.cursor = builder.cursor;
this.fetchSize = builder.fetchSize;
this.fieldMultiValueLeniency = builder.fieldMultiValueLeniency;
this.filter = builder.filter;
this.format = builder.format;
this.indexUsingFrozen = builder.indexUsingFrozen;
this.keepAlive = builder.keepAlive;
this.keepOnCompletion = builder.keepOnCompletion;
this.pageTimeout = builder.pageTimeout;
this.params = ApiTypeHelper.unmodifiable(builder.params);
this.query = builder.query;
this.requestTimeout = builder.requestTimeout;
this.runtimeMappings = ApiTypeHelper.unmodifiable(builder.runtimeMappings);
this.timeZone = builder.timeZone;
this.waitForCompletionTimeout = builder.waitForCompletionTimeout;
}
public static QueryRequest of(Function> fn) {
return fn.apply(new Builder()).build();
}
/**
* Default catalog (cluster) for queries. If unspecified, the queries execute on
* the data in the local cluster only.
*
* API name: {@code catalog}
*/
@Nullable
public final String catalog() {
return this.catalog;
}
/**
* If true, the results in a columnar fashion: one row represents all the values
* of a certain column from the current page of results.
*
* API name: {@code columnar}
*/
@Nullable
public final Boolean columnar() {
return this.columnar;
}
/**
* Cursor used to retrieve a set of paginated results. If you specify a cursor,
* the API only uses the columnar
and time_zone
* request body parameters. It ignores other request body parameters.
*
* API name: {@code cursor}
*/
@Nullable
public final String cursor() {
return this.cursor;
}
/**
* The maximum number of rows (or entries) to return in one response
*
* API name: {@code fetch_size}
*/
@Nullable
public final Integer fetchSize() {
return this.fetchSize;
}
/**
* Throw an exception when encountering multiple values for a field (default) or
* be lenient and return the first value from the list (without any guarantees
* of what that will be - typically the first in natural ascending order).
*
* API name: {@code field_multi_value_leniency}
*/
@Nullable
public final Boolean fieldMultiValueLeniency() {
return this.fieldMultiValueLeniency;
}
/**
* Elasticsearch query DSL for additional filtering.
*
* API name: {@code filter}
*/
@Nullable
public final Query filter() {
return this.filter;
}
/**
* Format for the response.
*
* API name: {@code format}
*/
@Nullable
public final SqlFormat format() {
return this.format;
}
/**
* If true, the search can run on frozen indices. Defaults to false.
*
* API name: {@code index_using_frozen}
*/
@Nullable
public final Boolean indexUsingFrozen() {
return this.indexUsingFrozen;
}
/**
* Retention period for an async or saved synchronous search.
*
* API name: {@code keep_alive}
*/
@Nullable
public final Time keepAlive() {
return this.keepAlive;
}
/**
* If true, Elasticsearch stores synchronous searches if you also specify the
* wait_for_completion_timeout parameter. If false, Elasticsearch only stores
* async searches that don’t finish before the wait_for_completion_timeout.
*
* API name: {@code keep_on_completion}
*/
@Nullable
public final Boolean keepOnCompletion() {
return this.keepOnCompletion;
}
/**
* The timeout before a pagination request fails.
*
* API name: {@code page_timeout}
*/
@Nullable
public final Time pageTimeout() {
return this.pageTimeout;
}
/**
* Values for parameters in the query.
*
* API name: {@code params}
*/
public final Map params() {
return this.params;
}
/**
* SQL query to run.
*
* API name: {@code query}
*/
@Nullable
public final String query() {
return this.query;
}
/**
* The timeout before the request fails.
*
* API name: {@code request_timeout}
*/
@Nullable
public final Time requestTimeout() {
return this.requestTimeout;
}
/**
* Defines one or more runtime fields in the search request. These fields take
* precedence over mapped fields with the same name.
*
* API name: {@code runtime_mappings}
*/
public final Map runtimeMappings() {
return this.runtimeMappings;
}
/**
* ISO-8601 time zone ID for the search.
*
* API name: {@code time_zone}
*/
@Nullable
public final String timeZone() {
return this.timeZone;
}
/**
* Period to wait for complete results. Defaults to no timeout, meaning the
* request waits for complete search results. If the search doesn’t finish
* within this period, the search becomes async.
*
* API name: {@code wait_for_completion_timeout}
*/
@Nullable
public final Time waitForCompletionTimeout() {
return this.waitForCompletionTimeout;
}
/**
* Serialize this object to JSON.
*/
public void serialize(JsonGenerator generator, JsonpMapper mapper) {
generator.writeStartObject();
serializeInternal(generator, mapper);
generator.writeEnd();
}
protected void serializeInternal(JsonGenerator generator, JsonpMapper mapper) {
if (this.catalog != null) {
generator.writeKey("catalog");
generator.write(this.catalog);
}
if (this.columnar != null) {
generator.writeKey("columnar");
generator.write(this.columnar);
}
if (this.cursor != null) {
generator.writeKey("cursor");
generator.write(this.cursor);
}
if (this.fetchSize != null) {
generator.writeKey("fetch_size");
generator.write(this.fetchSize);
}
if (this.fieldMultiValueLeniency != null) {
generator.writeKey("field_multi_value_leniency");
generator.write(this.fieldMultiValueLeniency);
}
if (this.filter != null) {
generator.writeKey("filter");
this.filter.serialize(generator, mapper);
}
if (this.indexUsingFrozen != null) {
generator.writeKey("index_using_frozen");
generator.write(this.indexUsingFrozen);
}
if (this.keepAlive != null) {
generator.writeKey("keep_alive");
this.keepAlive.serialize(generator, mapper);
}
if (this.keepOnCompletion != null) {
generator.writeKey("keep_on_completion");
generator.write(this.keepOnCompletion);
}
if (this.pageTimeout != null) {
generator.writeKey("page_timeout");
this.pageTimeout.serialize(generator, mapper);
}
if (ApiTypeHelper.isDefined(this.params)) {
generator.writeKey("params");
generator.writeStartObject();
for (Map.Entry item0 : this.params.entrySet()) {
generator.writeKey(item0.getKey());
item0.getValue().serialize(generator, mapper);
}
generator.writeEnd();
}
if (this.query != null) {
generator.writeKey("query");
generator.write(this.query);
}
if (this.requestTimeout != null) {
generator.writeKey("request_timeout");
this.requestTimeout.serialize(generator, mapper);
}
if (ApiTypeHelper.isDefined(this.runtimeMappings)) {
generator.writeKey("runtime_mappings");
generator.writeStartObject();
for (Map.Entry item0 : this.runtimeMappings.entrySet()) {
generator.writeKey(item0.getKey());
item0.getValue().serialize(generator, mapper);
}
generator.writeEnd();
}
if (this.timeZone != null) {
generator.writeKey("time_zone");
generator.write(this.timeZone);
}
if (this.waitForCompletionTimeout != null) {
generator.writeKey("wait_for_completion_timeout");
this.waitForCompletionTimeout.serialize(generator, mapper);
}
}
// ---------------------------------------------------------------------------------------------
/**
* Builder for {@link QueryRequest}.
*/
public static class Builder extends RequestBase.AbstractBuilder implements ObjectBuilder {
@Nullable
private String catalog;
@Nullable
private Boolean columnar;
@Nullable
private String cursor;
@Nullable
private Integer fetchSize;
@Nullable
private Boolean fieldMultiValueLeniency;
@Nullable
private Query filter;
@Nullable
private SqlFormat format;
@Nullable
private Boolean indexUsingFrozen;
@Nullable
private Time keepAlive;
@Nullable
private Boolean keepOnCompletion;
@Nullable
private Time pageTimeout;
@Nullable
private Map params;
@Nullable
private String query;
@Nullable
private Time requestTimeout;
@Nullable
private Map runtimeMappings;
@Nullable
private String timeZone;
@Nullable
private Time waitForCompletionTimeout;
/**
* Default catalog (cluster) for queries. If unspecified, the queries execute on
* the data in the local cluster only.
*
* API name: {@code catalog}
*/
public final Builder catalog(@Nullable String value) {
this.catalog = value;
return this;
}
/**
* If true, the results in a columnar fashion: one row represents all the values
* of a certain column from the current page of results.
*
* API name: {@code columnar}
*/
public final Builder columnar(@Nullable Boolean value) {
this.columnar = value;
return this;
}
/**
* Cursor used to retrieve a set of paginated results. If you specify a cursor,
* the API only uses the columnar
and time_zone
* request body parameters. It ignores other request body parameters.
*
* API name: {@code cursor}
*/
public final Builder cursor(@Nullable String value) {
this.cursor = value;
return this;
}
/**
* The maximum number of rows (or entries) to return in one response
*
* API name: {@code fetch_size}
*/
public final Builder fetchSize(@Nullable Integer value) {
this.fetchSize = value;
return this;
}
/**
* Throw an exception when encountering multiple values for a field (default) or
* be lenient and return the first value from the list (without any guarantees
* of what that will be - typically the first in natural ascending order).
*
* API name: {@code field_multi_value_leniency}
*/
public final Builder fieldMultiValueLeniency(@Nullable Boolean value) {
this.fieldMultiValueLeniency = value;
return this;
}
/**
* Elasticsearch query DSL for additional filtering.
*
* API name: {@code filter}
*/
public final Builder filter(@Nullable Query value) {
this.filter = value;
return this;
}
/**
* Elasticsearch query DSL for additional filtering.
*
* API name: {@code filter}
*/
public final Builder filter(Function> fn) {
return this.filter(fn.apply(new Query.Builder()).build());
}
/**
* Format for the response.
*
* API name: {@code format}
*/
public final Builder format(@Nullable SqlFormat value) {
this.format = value;
return this;
}
/**
* If true, the search can run on frozen indices. Defaults to false.
*
* API name: {@code index_using_frozen}
*/
public final Builder indexUsingFrozen(@Nullable Boolean value) {
this.indexUsingFrozen = value;
return this;
}
/**
* Retention period for an async or saved synchronous search.
*
* API name: {@code keep_alive}
*/
public final Builder keepAlive(@Nullable Time value) {
this.keepAlive = value;
return this;
}
/**
* Retention period for an async or saved synchronous search.
*
* API name: {@code keep_alive}
*/
public final Builder keepAlive(Function> fn) {
return this.keepAlive(fn.apply(new Time.Builder()).build());
}
/**
* If true, Elasticsearch stores synchronous searches if you also specify the
* wait_for_completion_timeout parameter. If false, Elasticsearch only stores
* async searches that don’t finish before the wait_for_completion_timeout.
*
* API name: {@code keep_on_completion}
*/
public final Builder keepOnCompletion(@Nullable Boolean value) {
this.keepOnCompletion = value;
return this;
}
/**
* The timeout before a pagination request fails.
*
* API name: {@code page_timeout}
*/
public final Builder pageTimeout(@Nullable Time value) {
this.pageTimeout = value;
return this;
}
/**
* The timeout before a pagination request fails.
*
* API name: {@code page_timeout}
*/
public final Builder pageTimeout(Function> fn) {
return this.pageTimeout(fn.apply(new Time.Builder()).build());
}
/**
* Values for parameters in the query.
*
* API name: {@code params}
*
* Adds all entries of map
to params
.
*/
public final Builder params(Map map) {
this.params = _mapPutAll(this.params, map);
return this;
}
/**
* Values for parameters in the query.
*
* API name: {@code params}
*
* Adds an entry to params
.
*/
public final Builder params(String key, JsonData value) {
this.params = _mapPut(this.params, key, value);
return this;
}
/**
* SQL query to run.
*
* API name: {@code query}
*/
public final Builder query(@Nullable String value) {
this.query = value;
return this;
}
/**
* The timeout before the request fails.
*
* API name: {@code request_timeout}
*/
public final Builder requestTimeout(@Nullable Time value) {
this.requestTimeout = value;
return this;
}
/**
* The timeout before the request fails.
*
* API name: {@code request_timeout}
*/
public final Builder requestTimeout(Function> fn) {
return this.requestTimeout(fn.apply(new Time.Builder()).build());
}
/**
* Defines one or more runtime fields in the search request. These fields take
* precedence over mapped fields with the same name.
*
* API name: {@code runtime_mappings}
*
* Adds all entries of map
to runtimeMappings
.
*/
public final Builder runtimeMappings(Map map) {
this.runtimeMappings = _mapPutAll(this.runtimeMappings, map);
return this;
}
/**
* Defines one or more runtime fields in the search request. These fields take
* precedence over mapped fields with the same name.
*
* API name: {@code runtime_mappings}
*
* Adds an entry to runtimeMappings
.
*/
public final Builder runtimeMappings(String key, RuntimeField value) {
this.runtimeMappings = _mapPut(this.runtimeMappings, key, value);
return this;
}
/**
* Defines one or more runtime fields in the search request. These fields take
* precedence over mapped fields with the same name.
*
* API name: {@code runtime_mappings}
*
* Adds an entry to runtimeMappings
using a builder lambda.
*/
public final Builder runtimeMappings(String key,
Function> fn) {
return runtimeMappings(key, fn.apply(new RuntimeField.Builder()).build());
}
/**
* ISO-8601 time zone ID for the search.
*
* API name: {@code time_zone}
*/
public final Builder timeZone(@Nullable String value) {
this.timeZone = value;
return this;
}
/**
* Period to wait for complete results. Defaults to no timeout, meaning the
* request waits for complete search results. If the search doesn’t finish
* within this period, the search becomes async.
*
* API name: {@code wait_for_completion_timeout}
*/
public final Builder waitForCompletionTimeout(@Nullable Time value) {
this.waitForCompletionTimeout = value;
return this;
}
/**
* Period to wait for complete results. Defaults to no timeout, meaning the
* request waits for complete search results. If the search doesn’t finish
* within this period, the search becomes async.
*
* API name: {@code wait_for_completion_timeout}
*/
public final Builder waitForCompletionTimeout(Function> fn) {
return this.waitForCompletionTimeout(fn.apply(new Time.Builder()).build());
}
@Override
protected Builder self() {
return this;
}
/**
* Builds a {@link QueryRequest}.
*
* @throws NullPointerException
* if some of the required fields are null.
*/
public QueryRequest build() {
_checkSingleUse();
return new QueryRequest(this);
}
}
// ---------------------------------------------------------------------------------------------
/**
* Json deserializer for {@link QueryRequest}
*/
public static final JsonpDeserializer _DESERIALIZER = ObjectBuilderDeserializer.lazy(Builder::new,
QueryRequest::setupQueryRequestDeserializer);
protected static void setupQueryRequestDeserializer(ObjectDeserializer op) {
op.add(Builder::catalog, JsonpDeserializer.stringDeserializer(), "catalog");
op.add(Builder::columnar, JsonpDeserializer.booleanDeserializer(), "columnar");
op.add(Builder::cursor, JsonpDeserializer.stringDeserializer(), "cursor");
op.add(Builder::fetchSize, JsonpDeserializer.integerDeserializer(), "fetch_size");
op.add(Builder::fieldMultiValueLeniency, JsonpDeserializer.booleanDeserializer(), "field_multi_value_leniency");
op.add(Builder::filter, Query._DESERIALIZER, "filter");
op.add(Builder::indexUsingFrozen, JsonpDeserializer.booleanDeserializer(), "index_using_frozen");
op.add(Builder::keepAlive, Time._DESERIALIZER, "keep_alive");
op.add(Builder::keepOnCompletion, JsonpDeserializer.booleanDeserializer(), "keep_on_completion");
op.add(Builder::pageTimeout, Time._DESERIALIZER, "page_timeout");
op.add(Builder::params, JsonpDeserializer.stringMapDeserializer(JsonData._DESERIALIZER), "params");
op.add(Builder::query, JsonpDeserializer.stringDeserializer(), "query");
op.add(Builder::requestTimeout, Time._DESERIALIZER, "request_timeout");
op.add(Builder::runtimeMappings, JsonpDeserializer.stringMapDeserializer(RuntimeField._DESERIALIZER),
"runtime_mappings");
op.add(Builder::timeZone, JsonpDeserializer.stringDeserializer(), "time_zone");
op.add(Builder::waitForCompletionTimeout, Time._DESERIALIZER, "wait_for_completion_timeout");
}
// ---------------------------------------------------------------------------------------------
/**
* Endpoint "{@code sql.query}".
*/
public static final Endpoint _ENDPOINT = new SimpleEndpoint<>(
"es/sql.query",
// Request method
request -> {
return "POST";
},
// Request path
request -> {
return "/_sql";
},
// Path parameters
request -> {
return Collections.emptyMap();
},
// Request parameters
request -> {
Map params = new HashMap<>();
if (request.format != null) {
params.put("format", request.format.jsonValue());
}
return params;
}, SimpleEndpoint.emptyMap(), true, QueryResponse._DESERIALIZER);
}