software.amazon.awssdk.services.kafka.model.UpdateClusterKafkaVersionRequest Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kafka Show documentation
Show all versions of kafka Show documentation
The AWS Java SDK for Kafka module holds the client classes that are used for
communicating with Kafka.
/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
* the License. A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file 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 software.amazon.awssdk.services.kafka.model;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.awscore.AwsRequestOverrideConfiguration;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
*/
@Generated("software.amazon.awssdk:codegen")
public final class UpdateClusterKafkaVersionRequest extends KafkaRequest implements
ToCopyableBuilder {
private static final SdkField CLUSTER_ARN_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("ClusterArn").getter(getter(UpdateClusterKafkaVersionRequest::clusterArn))
.setter(setter(Builder::clusterArn))
.traits(LocationTrait.builder().location(MarshallLocation.PATH).locationName("clusterArn").build()).build();
private static final SdkField CONFIGURATION_INFO_FIELD = SdkField
. builder(MarshallingType.SDK_POJO).memberName("ConfigurationInfo")
.getter(getter(UpdateClusterKafkaVersionRequest::configurationInfo)).setter(setter(Builder::configurationInfo))
.constructor(ConfigurationInfo::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("configurationInfo").build()).build();
private static final SdkField CURRENT_VERSION_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("CurrentVersion").getter(getter(UpdateClusterKafkaVersionRequest::currentVersion))
.setter(setter(Builder::currentVersion))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("currentVersion").build()).build();
private static final SdkField TARGET_KAFKA_VERSION_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("TargetKafkaVersion").getter(getter(UpdateClusterKafkaVersionRequest::targetKafkaVersion))
.setter(setter(Builder::targetKafkaVersion))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("targetKafkaVersion").build())
.build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(CLUSTER_ARN_FIELD,
CONFIGURATION_INFO_FIELD, CURRENT_VERSION_FIELD, TARGET_KAFKA_VERSION_FIELD));
private final String clusterArn;
private final ConfigurationInfo configurationInfo;
private final String currentVersion;
private final String targetKafkaVersion;
private UpdateClusterKafkaVersionRequest(BuilderImpl builder) {
super(builder);
this.clusterArn = builder.clusterArn;
this.configurationInfo = builder.configurationInfo;
this.currentVersion = builder.currentVersion;
this.targetKafkaVersion = builder.targetKafkaVersion;
}
/**
*
*
* The Amazon Resource Name (ARN) of the cluster to be updated.
*
*
* @return
* The Amazon Resource Name (ARN) of the cluster to be updated.
*
*/
public final String clusterArn() {
return clusterArn;
}
/**
*
*
* The custom configuration that should be applied on the new version of cluster.
*
*
* @return
* The custom configuration that should be applied on the new version of cluster.
*
*/
public final ConfigurationInfo configurationInfo() {
return configurationInfo;
}
/**
*
*
* Current cluster version.
*
*
* @return
* Current cluster version.
*
*/
public final String currentVersion() {
return currentVersion;
}
/**
*
*
* Target Kafka version.
*
*
* @return
* Target Kafka version.
*
*/
public final String targetKafkaVersion() {
return targetKafkaVersion;
}
@Override
public Builder toBuilder() {
return new BuilderImpl(this);
}
public static Builder builder() {
return new BuilderImpl();
}
public static Class extends Builder> serializableBuilderClass() {
return BuilderImpl.class;
}
@Override
public final int hashCode() {
int hashCode = 1;
hashCode = 31 * hashCode + super.hashCode();
hashCode = 31 * hashCode + Objects.hashCode(clusterArn());
hashCode = 31 * hashCode + Objects.hashCode(configurationInfo());
hashCode = 31 * hashCode + Objects.hashCode(currentVersion());
hashCode = 31 * hashCode + Objects.hashCode(targetKafkaVersion());
return hashCode;
}
@Override
public final boolean equals(Object obj) {
return super.equals(obj) && equalsBySdkFields(obj);
}
@Override
public final boolean equalsBySdkFields(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof UpdateClusterKafkaVersionRequest)) {
return false;
}
UpdateClusterKafkaVersionRequest other = (UpdateClusterKafkaVersionRequest) obj;
return Objects.equals(clusterArn(), other.clusterArn()) && Objects.equals(configurationInfo(), other.configurationInfo())
&& Objects.equals(currentVersion(), other.currentVersion())
&& Objects.equals(targetKafkaVersion(), other.targetKafkaVersion());
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*/
@Override
public final String toString() {
return ToString.builder("UpdateClusterKafkaVersionRequest").add("ClusterArn", clusterArn())
.add("ConfigurationInfo", configurationInfo()).add("CurrentVersion", currentVersion())
.add("TargetKafkaVersion", targetKafkaVersion()).build();
}
public final Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "ClusterArn":
return Optional.ofNullable(clazz.cast(clusterArn()));
case "ConfigurationInfo":
return Optional.ofNullable(clazz.cast(configurationInfo()));
case "CurrentVersion":
return Optional.ofNullable(clazz.cast(currentVersion()));
case "TargetKafkaVersion":
return Optional.ofNullable(clazz.cast(targetKafkaVersion()));
default:
return Optional.empty();
}
}
@Override
public final List> sdkFields() {
return SDK_FIELDS;
}
private static Function