All Downloads are FREE. Search and download functionalities are using the official Maven repository.

co.elastic.clients.elasticsearch.rollup.PutJobRequest 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.rollup;

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.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.Integer;
import java.lang.String;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
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: rollup.put_job.Request

/**
 * Creates a rollup job.
 * 
 * @see API
 *      specification
 */
@JsonpDeserializable
public class PutJobRequest extends RequestBase implements JsonpSerializable {
	private final String cron;

	private final Groupings groups;

	private final Map> headers;

	private final String id;

	private final String indexPattern;

	private final List metrics;

	private final int pageSize;

	private final String rollupIndex;

	@Nullable
	private final Time timeout;

	// ---------------------------------------------------------------------------------------------

	private PutJobRequest(Builder builder) {

		this.cron = ApiTypeHelper.requireNonNull(builder.cron, this, "cron");
		this.groups = ApiTypeHelper.requireNonNull(builder.groups, this, "groups");
		this.headers = ApiTypeHelper.unmodifiable(builder.headers);
		this.id = ApiTypeHelper.requireNonNull(builder.id, this, "id");
		this.indexPattern = ApiTypeHelper.requireNonNull(builder.indexPattern, this, "indexPattern");
		this.metrics = ApiTypeHelper.unmodifiable(builder.metrics);
		this.pageSize = ApiTypeHelper.requireNonNull(builder.pageSize, this, "pageSize");
		this.rollupIndex = ApiTypeHelper.requireNonNull(builder.rollupIndex, this, "rollupIndex");
		this.timeout = builder.timeout;

	}

	public static PutJobRequest of(Function> fn) {
		return fn.apply(new Builder()).build();
	}

	/**
	 * Required - A cron string which defines the intervals when the rollup job
	 * should be executed. When the interval triggers, the indexer attempts to
	 * rollup the data in the index pattern. The cron pattern is unrelated to the
	 * time interval of the data being rolled up. For example, you may wish to
	 * create hourly rollups of your document but to only run the indexer on a daily
	 * basis at midnight, as defined by the cron. The cron pattern is defined just
	 * like a Watcher cron schedule.
	 * 

* API name: {@code cron} */ public final String cron() { return this.cron; } /** * Required - Defines the grouping fields and aggregations that are defined for * this rollup job. These fields will then be available later for aggregating * into buckets. These aggs and fields can be used in any combination. Think of * the groups configuration as defining a set of tools that can later be used in * aggregations to partition the data. Unlike raw data, we have to think ahead * to which fields and aggregations might be used. Rollups provide enough * flexibility that you simply need to determine which fields are needed, not in * what order they are needed. *

* API name: {@code groups} */ public final Groupings groups() { return this.groups; } /** * API name: {@code headers} */ public final Map> headers() { return this.headers; } /** * Required - Identifier for the rollup job. This can be any alphanumeric string * and uniquely identifies the data that is associated with the rollup job. The * ID is persistent; it is stored with the rolled up data. If you create a job, * let it run for a while, then delete the job, the data that the job rolled up * is still be associated with this job ID. You cannot create a new job with the * same ID since that could lead to problems with mismatched job configurations. *

* API name: {@code id} */ public final String id() { return this.id; } /** * Required - The index or index pattern to roll up. Supports wildcard-style * patterns (logstash-*). The job attempts to rollup the entire * index or index-pattern. *

* API name: {@code index_pattern} */ public final String indexPattern() { return this.indexPattern; } /** * Defines the metrics to collect for each grouping tuple. By default, only the * doc_counts are collected for each group. To make rollup useful, you will * often add metrics like averages, mins, maxes, etc. Metrics are defined on a * per-field basis and for each field you configure which metric should be * collected. *

* API name: {@code metrics} */ public final List metrics() { return this.metrics; } /** * Required - The number of bucket results that are processed on each iteration * of the rollup indexer. A larger value tends to execute faster, but requires * more memory during processing. This value has no effect on how the data is * rolled up; it is merely used for tweaking the speed or memory cost of the * indexer. *

* API name: {@code page_size} */ public final int pageSize() { return this.pageSize; } /** * Required - The index that contains the rollup results. The index can be * shared with other rollup jobs. The data is stored so that it doesn’t * interfere with unrelated jobs. *

* API name: {@code rollup_index} */ public final String rollupIndex() { return this.rollupIndex; } /** * Time to wait for the request to complete. *

* API name: {@code timeout} */ @Nullable public final Time timeout() { return this.timeout; } /** * 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) { generator.writeKey("cron"); generator.write(this.cron); generator.writeKey("groups"); this.groups.serialize(generator, mapper); if (ApiTypeHelper.isDefined(this.headers)) { generator.writeKey("headers"); generator.writeStartObject(); for (Map.Entry> item0 : this.headers.entrySet()) { generator.writeKey(item0.getKey()); generator.writeStartArray(); if (item0.getValue() != null) { for (String item1 : item0.getValue()) { generator.write(item1); } } generator.writeEnd(); } generator.writeEnd(); } generator.writeKey("index_pattern"); generator.write(this.indexPattern); if (ApiTypeHelper.isDefined(this.metrics)) { generator.writeKey("metrics"); generator.writeStartArray(); for (FieldMetric item0 : this.metrics) { item0.serialize(generator, mapper); } generator.writeEnd(); } generator.writeKey("page_size"); generator.write(this.pageSize); generator.writeKey("rollup_index"); generator.write(this.rollupIndex); if (this.timeout != null) { generator.writeKey("timeout"); this.timeout.serialize(generator, mapper); } } // --------------------------------------------------------------------------------------------- /** * Builder for {@link PutJobRequest}. */ public static class Builder extends RequestBase.AbstractBuilder implements ObjectBuilder { private String cron; private Groupings groups; @Nullable private Map> headers; private String id; private String indexPattern; @Nullable private List metrics; private Integer pageSize; private String rollupIndex; @Nullable private Time timeout; /** * Required - A cron string which defines the intervals when the rollup job * should be executed. When the interval triggers, the indexer attempts to * rollup the data in the index pattern. The cron pattern is unrelated to the * time interval of the data being rolled up. For example, you may wish to * create hourly rollups of your document but to only run the indexer on a daily * basis at midnight, as defined by the cron. The cron pattern is defined just * like a Watcher cron schedule. *

* API name: {@code cron} */ public final Builder cron(String value) { this.cron = value; return this; } /** * Required - Defines the grouping fields and aggregations that are defined for * this rollup job. These fields will then be available later for aggregating * into buckets. These aggs and fields can be used in any combination. Think of * the groups configuration as defining a set of tools that can later be used in * aggregations to partition the data. Unlike raw data, we have to think ahead * to which fields and aggregations might be used. Rollups provide enough * flexibility that you simply need to determine which fields are needed, not in * what order they are needed. *

* API name: {@code groups} */ public final Builder groups(Groupings value) { this.groups = value; return this; } /** * Required - Defines the grouping fields and aggregations that are defined for * this rollup job. These fields will then be available later for aggregating * into buckets. These aggs and fields can be used in any combination. Think of * the groups configuration as defining a set of tools that can later be used in * aggregations to partition the data. Unlike raw data, we have to think ahead * to which fields and aggregations might be used. Rollups provide enough * flexibility that you simply need to determine which fields are needed, not in * what order they are needed. *

* API name: {@code groups} */ public final Builder groups(Function> fn) { return this.groups(fn.apply(new Groupings.Builder()).build()); } /** * API name: {@code headers} *

* Adds all entries of map to headers. */ public final Builder headers(Map> map) { this.headers = _mapPutAll(this.headers, map); return this; } /** * API name: {@code headers} *

* Adds an entry to headers. */ public final Builder headers(String key, List value) { this.headers = _mapPut(this.headers, key, value); return this; } /** * Required - Identifier for the rollup job. This can be any alphanumeric string * and uniquely identifies the data that is associated with the rollup job. The * ID is persistent; it is stored with the rolled up data. If you create a job, * let it run for a while, then delete the job, the data that the job rolled up * is still be associated with this job ID. You cannot create a new job with the * same ID since that could lead to problems with mismatched job configurations. *

* API name: {@code id} */ public final Builder id(String value) { this.id = value; return this; } /** * Required - The index or index pattern to roll up. Supports wildcard-style * patterns (logstash-*). The job attempts to rollup the entire * index or index-pattern. *

* API name: {@code index_pattern} */ public final Builder indexPattern(String value) { this.indexPattern = value; return this; } /** * Defines the metrics to collect for each grouping tuple. By default, only the * doc_counts are collected for each group. To make rollup useful, you will * often add metrics like averages, mins, maxes, etc. Metrics are defined on a * per-field basis and for each field you configure which metric should be * collected. *

* API name: {@code metrics} *

* Adds all elements of list to metrics. */ public final Builder metrics(List list) { this.metrics = _listAddAll(this.metrics, list); return this; } /** * Defines the metrics to collect for each grouping tuple. By default, only the * doc_counts are collected for each group. To make rollup useful, you will * often add metrics like averages, mins, maxes, etc. Metrics are defined on a * per-field basis and for each field you configure which metric should be * collected. *

* API name: {@code metrics} *

* Adds one or more values to metrics. */ public final Builder metrics(FieldMetric value, FieldMetric... values) { this.metrics = _listAdd(this.metrics, value, values); return this; } /** * Defines the metrics to collect for each grouping tuple. By default, only the * doc_counts are collected for each group. To make rollup useful, you will * often add metrics like averages, mins, maxes, etc. Metrics are defined on a * per-field basis and for each field you configure which metric should be * collected. *

* API name: {@code metrics} *

* Adds a value to metrics using a builder lambda. */ public final Builder metrics(Function> fn) { return metrics(fn.apply(new FieldMetric.Builder()).build()); } /** * Required - The number of bucket results that are processed on each iteration * of the rollup indexer. A larger value tends to execute faster, but requires * more memory during processing. This value has no effect on how the data is * rolled up; it is merely used for tweaking the speed or memory cost of the * indexer. *

* API name: {@code page_size} */ public final Builder pageSize(int value) { this.pageSize = value; return this; } /** * Required - The index that contains the rollup results. The index can be * shared with other rollup jobs. The data is stored so that it doesn’t * interfere with unrelated jobs. *

* API name: {@code rollup_index} */ public final Builder rollupIndex(String value) { this.rollupIndex = value; return this; } /** * Time to wait for the request to complete. *

* API name: {@code timeout} */ public final Builder timeout(@Nullable Time value) { this.timeout = value; return this; } /** * Time to wait for the request to complete. *

* API name: {@code timeout} */ public final Builder timeout(Function> fn) { return this.timeout(fn.apply(new Time.Builder()).build()); } @Override protected Builder self() { return this; } /** * Builds a {@link PutJobRequest}. * * @throws NullPointerException * if some of the required fields are null. */ public PutJobRequest build() { _checkSingleUse(); return new PutJobRequest(this); } } // --------------------------------------------------------------------------------------------- /** * Json deserializer for {@link PutJobRequest} */ public static final JsonpDeserializer _DESERIALIZER = ObjectBuilderDeserializer.lazy(Builder::new, PutJobRequest::setupPutJobRequestDeserializer); protected static void setupPutJobRequestDeserializer(ObjectDeserializer op) { op.add(Builder::cron, JsonpDeserializer.stringDeserializer(), "cron"); op.add(Builder::groups, Groupings._DESERIALIZER, "groups"); op.add(Builder::headers, JsonpDeserializer.stringMapDeserializer( JsonpDeserializer.arrayDeserializer(JsonpDeserializer.stringDeserializer())), "headers"); op.add(Builder::indexPattern, JsonpDeserializer.stringDeserializer(), "index_pattern"); op.add(Builder::metrics, JsonpDeserializer.arrayDeserializer(FieldMetric._DESERIALIZER), "metrics"); op.add(Builder::pageSize, JsonpDeserializer.integerDeserializer(), "page_size"); op.add(Builder::rollupIndex, JsonpDeserializer.stringDeserializer(), "rollup_index"); op.add(Builder::timeout, Time._DESERIALIZER, "timeout"); } // --------------------------------------------------------------------------------------------- /** * Endpoint "{@code rollup.put_job}". */ public static final Endpoint _ENDPOINT = new SimpleEndpoint<>( "es/rollup.put_job", // Request method request -> { return "PUT"; }, // Request path request -> { final int _id = 1 << 0; int propsSet = 0; propsSet |= _id; if (propsSet == (_id)) { StringBuilder buf = new StringBuilder(); buf.append("/_rollup"); buf.append("/job"); buf.append("/"); SimpleEndpoint.pathEncode(request.id, buf); return buf.toString(); } throw SimpleEndpoint.noPathTemplateFound("path"); }, // Path parameters request -> { Map params = new HashMap<>(); final int _id = 1 << 0; int propsSet = 0; propsSet |= _id; if (propsSet == (_id)) { params.put("id", request.id); } return params; }, // Request parameters request -> { return Collections.emptyMap(); }, SimpleEndpoint.emptyMap(), true, PutJobResponse._DESERIALIZER); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy