From b3b1224527b1235d81462e840b66a848a8b3501f Mon Sep 17 00:00:00 2001 From: Urs Keller Date: Sun, 22 Jan 2023 18:18:38 +0100 Subject: [PATCH] Adding wrapper query, requirement for spring reactive Signed-off-by: Urs Keller --- .../opensearch/_types/query_dsl/Query.java | 2 + .../_types/query_dsl/WrapperQuery.java | 148 ++++++++++++++++++ 2 files changed, 150 insertions(+) create mode 100644 java-client/src/main/java/org/opensearch/client/opensearch/_types/query_dsl/WrapperQuery.java diff --git a/java-client/src/main/java/org/opensearch/client/opensearch/_types/query_dsl/Query.java b/java-client/src/main/java/org/opensearch/client/opensearch/_types/query_dsl/Query.java index 6a22bafbfc..7c25bced09 100644 --- a/java-client/src/main/java/org/opensearch/client/opensearch/_types/query_dsl/Query.java +++ b/java-client/src/main/java/org/opensearch/client/opensearch/_types/query_dsl/Query.java @@ -171,6 +171,8 @@ public enum Kind implements JsonEnum { Wildcard("wildcard"), + Wrapper("wrapper"), + Type("type"), ; diff --git a/java-client/src/main/java/org/opensearch/client/opensearch/_types/query_dsl/WrapperQuery.java b/java-client/src/main/java/org/opensearch/client/opensearch/_types/query_dsl/WrapperQuery.java new file mode 100644 index 0000000000..95fe88efa4 --- /dev/null +++ b/java-client/src/main/java/org/opensearch/client/opensearch/_types/query_dsl/WrapperQuery.java @@ -0,0 +1,148 @@ +/* + * SPDX-License-Identifier: Apache-2.0 + * + * The OpenSearch Contributors require contributions made to + * this file be licensed under the Apache-2.0 license or a + * compatible open source license. + */ + +/* + * 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. + */ + +/* + * Modifications Copyright OpenSearch Contributors. See + * GitHub history for details. + */ + +//---------------------------------------------------- +// THIS CODE IS GENERATED. MANUAL EDITS WILL BE LOST. +//---------------------------------------------------- + +package org.opensearch.client.opensearch._types.query_dsl; + +import org.opensearch.client.json.JsonpDeserializable; +import org.opensearch.client.json.JsonpDeserializer; +import org.opensearch.client.json.JsonpMapper; +import org.opensearch.client.json.ObjectBuilderDeserializer; +import org.opensearch.client.json.ObjectDeserializer; +import org.opensearch.client.util.ApiTypeHelper; +import org.opensearch.client.util.ObjectBuilder; +import jakarta.json.stream.JsonGenerator; +import java.lang.String; +import java.util.function.Function; + +// typedef: _types.query_dsl.WrapperQuery + + +@JsonpDeserializable +public class WrapperQuery extends QueryBase implements QueryVariant { + private final String query; + + // --------------------------------------------------------------------------------------------- + + private WrapperQuery(Builder builder) { + super(builder); + + this.query = ApiTypeHelper.requireNonNull(builder.query, this, "query"); + + } + + public static WrapperQuery of(Function> fn) { + return fn.apply(new Builder()).build(); + } + + /** + * Query variant kind. + */ + @Override + public Query.Kind _queryKind() { + return Query.Kind.Wrapper; + } + + /** + * Required - A base64 encoded query. The binary data format can be any of JSON, + * YAML, CBOR or SMILE encodings + *

+ * API name: {@code query} + */ + public final String query() { + return this.query; + } + + protected void serializeInternal(JsonGenerator generator, JsonpMapper mapper) { + + super.serializeInternal(generator, mapper); + generator.writeKey("query"); + generator.write(this.query); + + } + + // --------------------------------------------------------------------------------------------- + + /** + * Builder for {@link WrapperQuery}. + */ + + public static class Builder extends QueryBase.AbstractBuilder implements ObjectBuilder { + private String query; + + /** + * Required - A base64 encoded query. The binary data format can be any of JSON, + * YAML, CBOR or SMILE encodings + *

+ * API name: {@code query} + */ + public final Builder query(String value) { + this.query = value; + return this; + } + + @Override + protected Builder self() { + return this; + } + + /** + * Builds a {@link WrapperQuery}. + * + * @throws NullPointerException + * if some of the required fields are null. + */ + public WrapperQuery build() { + _checkSingleUse(); + + return new WrapperQuery(this); + } + } + + // --------------------------------------------------------------------------------------------- + + /** + * Json deserializer for {@link WrapperQuery} + */ + public static final JsonpDeserializer _DESERIALIZER = ObjectBuilderDeserializer.lazy(Builder::new, + WrapperQuery::setupWrapperQueryDeserializer); + + protected static void setupWrapperQueryDeserializer(ObjectDeserializer op) { + QueryBase.setupQueryBaseDeserializer(op); + op.add(Builder::query, JsonpDeserializer.stringDeserializer(), "query"); + + } + +}