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

co.elastic.clients.elasticsearch.cluster.stats.ClusterNodes 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.
 */

//----------------------------------------------------
// THIS CODE IS GENERATED. MANUAL EDITS WILL BE LOST.
//----------------------------------------------------

package co.elastic.clients.elasticsearch.cluster.stats;

import co.elastic.clients.elasticsearch._types.PluginStats;
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.util.ApiTypeHelper;
import co.elastic.clients.util.ObjectBuilder;
import co.elastic.clients.util.WithJsonObjectBuilderBase;
import jakarta.json.stream.JsonGenerator;
import java.lang.Integer;
import java.lang.String;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.function.Function;
import javax.annotation.Nullable;

// typedef: cluster.stats.ClusterNodes

/**
 *
 * @see API
 *      specification
 */
@JsonpDeserializable
public class ClusterNodes implements JsonpSerializable {
	private final ClusterNodeCount count;

	private final Map discoveryTypes;

	private final ClusterFileSystem fs;

	private final ClusterIngest ingest;

	private final ClusterJvm jvm;

	private final ClusterNetworkTypes networkTypes;

	private final ClusterOperatingSystem os;

	private final List packagingTypes;

	private final List plugins;

	private final ClusterProcess process;

	private final List versions;

	private final IndexingPressure indexingPressure;

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

	private ClusterNodes(Builder builder) {

		this.count = ApiTypeHelper.requireNonNull(builder.count, this, "count");
		this.discoveryTypes = ApiTypeHelper.unmodifiableRequired(builder.discoveryTypes, this, "discoveryTypes");
		this.fs = ApiTypeHelper.requireNonNull(builder.fs, this, "fs");
		this.ingest = ApiTypeHelper.requireNonNull(builder.ingest, this, "ingest");
		this.jvm = ApiTypeHelper.requireNonNull(builder.jvm, this, "jvm");
		this.networkTypes = ApiTypeHelper.requireNonNull(builder.networkTypes, this, "networkTypes");
		this.os = ApiTypeHelper.requireNonNull(builder.os, this, "os");
		this.packagingTypes = ApiTypeHelper.unmodifiableRequired(builder.packagingTypes, this, "packagingTypes");
		this.plugins = ApiTypeHelper.unmodifiableRequired(builder.plugins, this, "plugins");
		this.process = ApiTypeHelper.requireNonNull(builder.process, this, "process");
		this.versions = ApiTypeHelper.unmodifiableRequired(builder.versions, this, "versions");
		this.indexingPressure = ApiTypeHelper.requireNonNull(builder.indexingPressure, this, "indexingPressure");

	}

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

	/**
	 * Required - Contains counts for nodes selected by the request’s node filters.
	 * 

* API name: {@code count} */ public final ClusterNodeCount count() { return this.count; } /** * Required - Contains statistics about the discovery types used by selected * nodes. *

* API name: {@code discovery_types} */ public final Map discoveryTypes() { return this.discoveryTypes; } /** * Required - Contains statistics about file stores by selected nodes. *

* API name: {@code fs} */ public final ClusterFileSystem fs() { return this.fs; } /** * Required - API name: {@code ingest} */ public final ClusterIngest ingest() { return this.ingest; } /** * Required - Contains statistics about the Java Virtual Machines (JVMs) used by * selected nodes. *

* API name: {@code jvm} */ public final ClusterJvm jvm() { return this.jvm; } /** * Required - Contains statistics about the transport and HTTP networks used by * selected nodes. *

* API name: {@code network_types} */ public final ClusterNetworkTypes networkTypes() { return this.networkTypes; } /** * Required - Contains statistics about the operating systems used by selected * nodes. *

* API name: {@code os} */ public final ClusterOperatingSystem os() { return this.os; } /** * Required - Contains statistics about Elasticsearch distributions installed on * selected nodes. *

* API name: {@code packaging_types} */ public final List packagingTypes() { return this.packagingTypes; } /** * Required - Contains statistics about installed plugins and modules by * selected nodes. *

* API name: {@code plugins} */ public final List plugins() { return this.plugins; } /** * Required - Contains statistics about processes used by selected nodes. *

* API name: {@code process} */ public final ClusterProcess process() { return this.process; } /** * Required - Array of Elasticsearch versions used on selected nodes. *

* API name: {@code versions} */ public final List versions() { return this.versions; } /** * Required - API name: {@code indexing_pressure} */ public final IndexingPressure indexingPressure() { return this.indexingPressure; } /** * 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("count"); this.count.serialize(generator, mapper); if (ApiTypeHelper.isDefined(this.discoveryTypes)) { generator.writeKey("discovery_types"); generator.writeStartObject(); for (Map.Entry item0 : this.discoveryTypes.entrySet()) { generator.writeKey(item0.getKey()); generator.write(item0.getValue()); } generator.writeEnd(); } generator.writeKey("fs"); this.fs.serialize(generator, mapper); generator.writeKey("ingest"); this.ingest.serialize(generator, mapper); generator.writeKey("jvm"); this.jvm.serialize(generator, mapper); generator.writeKey("network_types"); this.networkTypes.serialize(generator, mapper); generator.writeKey("os"); this.os.serialize(generator, mapper); if (ApiTypeHelper.isDefined(this.packagingTypes)) { generator.writeKey("packaging_types"); generator.writeStartArray(); for (NodePackagingType item0 : this.packagingTypes) { item0.serialize(generator, mapper); } generator.writeEnd(); } if (ApiTypeHelper.isDefined(this.plugins)) { generator.writeKey("plugins"); generator.writeStartArray(); for (PluginStats item0 : this.plugins) { item0.serialize(generator, mapper); } generator.writeEnd(); } generator.writeKey("process"); this.process.serialize(generator, mapper); if (ApiTypeHelper.isDefined(this.versions)) { generator.writeKey("versions"); generator.writeStartArray(); for (String item0 : this.versions) { generator.write(item0); } generator.writeEnd(); } generator.writeKey("indexing_pressure"); this.indexingPressure.serialize(generator, mapper); } // --------------------------------------------------------------------------------------------- /** * Builder for {@link ClusterNodes}. */ public static class Builder extends WithJsonObjectBuilderBase implements ObjectBuilder { private ClusterNodeCount count; private Map discoveryTypes; private ClusterFileSystem fs; private ClusterIngest ingest; private ClusterJvm jvm; private ClusterNetworkTypes networkTypes; private ClusterOperatingSystem os; private List packagingTypes; private List plugins; private ClusterProcess process; private List versions; private IndexingPressure indexingPressure; /** * Required - Contains counts for nodes selected by the request’s node filters. *

* API name: {@code count} */ public final Builder count(ClusterNodeCount value) { this.count = value; return this; } /** * Required - Contains counts for nodes selected by the request’s node filters. *

* API name: {@code count} */ public final Builder count(Function> fn) { return this.count(fn.apply(new ClusterNodeCount.Builder()).build()); } /** * Required - Contains statistics about the discovery types used by selected * nodes. *

* API name: {@code discovery_types} *

* Adds all entries of map to discoveryTypes. */ public final Builder discoveryTypes(Map map) { this.discoveryTypes = _mapPutAll(this.discoveryTypes, map); return this; } /** * Required - Contains statistics about the discovery types used by selected * nodes. *

* API name: {@code discovery_types} *

* Adds an entry to discoveryTypes. */ public final Builder discoveryTypes(String key, Integer value) { this.discoveryTypes = _mapPut(this.discoveryTypes, key, value); return this; } /** * Required - Contains statistics about file stores by selected nodes. *

* API name: {@code fs} */ public final Builder fs(ClusterFileSystem value) { this.fs = value; return this; } /** * Required - Contains statistics about file stores by selected nodes. *

* API name: {@code fs} */ public final Builder fs(Function> fn) { return this.fs(fn.apply(new ClusterFileSystem.Builder()).build()); } /** * Required - API name: {@code ingest} */ public final Builder ingest(ClusterIngest value) { this.ingest = value; return this; } /** * Required - API name: {@code ingest} */ public final Builder ingest(Function> fn) { return this.ingest(fn.apply(new ClusterIngest.Builder()).build()); } /** * Required - Contains statistics about the Java Virtual Machines (JVMs) used by * selected nodes. *

* API name: {@code jvm} */ public final Builder jvm(ClusterJvm value) { this.jvm = value; return this; } /** * Required - Contains statistics about the Java Virtual Machines (JVMs) used by * selected nodes. *

* API name: {@code jvm} */ public final Builder jvm(Function> fn) { return this.jvm(fn.apply(new ClusterJvm.Builder()).build()); } /** * Required - Contains statistics about the transport and HTTP networks used by * selected nodes. *

* API name: {@code network_types} */ public final Builder networkTypes(ClusterNetworkTypes value) { this.networkTypes = value; return this; } /** * Required - Contains statistics about the transport and HTTP networks used by * selected nodes. *

* API name: {@code network_types} */ public final Builder networkTypes( Function> fn) { return this.networkTypes(fn.apply(new ClusterNetworkTypes.Builder()).build()); } /** * Required - Contains statistics about the operating systems used by selected * nodes. *

* API name: {@code os} */ public final Builder os(ClusterOperatingSystem value) { this.os = value; return this; } /** * Required - Contains statistics about the operating systems used by selected * nodes. *

* API name: {@code os} */ public final Builder os(Function> fn) { return this.os(fn.apply(new ClusterOperatingSystem.Builder()).build()); } /** * Required - Contains statistics about Elasticsearch distributions installed on * selected nodes. *

* API name: {@code packaging_types} *

* Adds all elements of list to packagingTypes. */ public final Builder packagingTypes(List list) { this.packagingTypes = _listAddAll(this.packagingTypes, list); return this; } /** * Required - Contains statistics about Elasticsearch distributions installed on * selected nodes. *

* API name: {@code packaging_types} *

* Adds one or more values to packagingTypes. */ public final Builder packagingTypes(NodePackagingType value, NodePackagingType... values) { this.packagingTypes = _listAdd(this.packagingTypes, value, values); return this; } /** * Required - Contains statistics about Elasticsearch distributions installed on * selected nodes. *

* API name: {@code packaging_types} *

* Adds a value to packagingTypes using a builder lambda. */ public final Builder packagingTypes(Function> fn) { return packagingTypes(fn.apply(new NodePackagingType.Builder()).build()); } /** * Required - Contains statistics about installed plugins and modules by * selected nodes. *

* API name: {@code plugins} *

* Adds all elements of list to plugins. */ public final Builder plugins(List list) { this.plugins = _listAddAll(this.plugins, list); return this; } /** * Required - Contains statistics about installed plugins and modules by * selected nodes. *

* API name: {@code plugins} *

* Adds one or more values to plugins. */ public final Builder plugins(PluginStats value, PluginStats... values) { this.plugins = _listAdd(this.plugins, value, values); return this; } /** * Required - Contains statistics about installed plugins and modules by * selected nodes. *

* API name: {@code plugins} *

* Adds a value to plugins using a builder lambda. */ public final Builder plugins(Function> fn) { return plugins(fn.apply(new PluginStats.Builder()).build()); } /** * Required - Contains statistics about processes used by selected nodes. *

* API name: {@code process} */ public final Builder process(ClusterProcess value) { this.process = value; return this; } /** * Required - Contains statistics about processes used by selected nodes. *

* API name: {@code process} */ public final Builder process(Function> fn) { return this.process(fn.apply(new ClusterProcess.Builder()).build()); } /** * Required - Array of Elasticsearch versions used on selected nodes. *

* API name: {@code versions} *

* Adds all elements of list to versions. */ public final Builder versions(List list) { this.versions = _listAddAll(this.versions, list); return this; } /** * Required - Array of Elasticsearch versions used on selected nodes. *

* API name: {@code versions} *

* Adds one or more values to versions. */ public final Builder versions(String value, String... values) { this.versions = _listAdd(this.versions, value, values); return this; } /** * Required - API name: {@code indexing_pressure} */ public final Builder indexingPressure(IndexingPressure value) { this.indexingPressure = value; return this; } /** * Required - API name: {@code indexing_pressure} */ public final Builder indexingPressure(Function> fn) { return this.indexingPressure(fn.apply(new IndexingPressure.Builder()).build()); } @Override protected Builder self() { return this; } /** * Builds a {@link ClusterNodes}. * * @throws NullPointerException * if some of the required fields are null. */ public ClusterNodes build() { _checkSingleUse(); return new ClusterNodes(this); } } // --------------------------------------------------------------------------------------------- /** * Json deserializer for {@link ClusterNodes} */ public static final JsonpDeserializer _DESERIALIZER = ObjectBuilderDeserializer.lazy(Builder::new, ClusterNodes::setupClusterNodesDeserializer); protected static void setupClusterNodesDeserializer(ObjectDeserializer op) { op.add(Builder::count, ClusterNodeCount._DESERIALIZER, "count"); op.add(Builder::discoveryTypes, JsonpDeserializer.stringMapDeserializer(JsonpDeserializer.integerDeserializer()), "discovery_types"); op.add(Builder::fs, ClusterFileSystem._DESERIALIZER, "fs"); op.add(Builder::ingest, ClusterIngest._DESERIALIZER, "ingest"); op.add(Builder::jvm, ClusterJvm._DESERIALIZER, "jvm"); op.add(Builder::networkTypes, ClusterNetworkTypes._DESERIALIZER, "network_types"); op.add(Builder::os, ClusterOperatingSystem._DESERIALIZER, "os"); op.add(Builder::packagingTypes, JsonpDeserializer.arrayDeserializer(NodePackagingType._DESERIALIZER), "packaging_types"); op.add(Builder::plugins, JsonpDeserializer.arrayDeserializer(PluginStats._DESERIALIZER), "plugins"); op.add(Builder::process, ClusterProcess._DESERIALIZER, "process"); op.add(Builder::versions, JsonpDeserializer.arrayDeserializer(JsonpDeserializer.stringDeserializer()), "versions"); op.add(Builder::indexingPressure, IndexingPressure._DESERIALIZER, "indexing_pressure"); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy