software.amazon.awssdk.services.kafka.model.UpdateReplicationInfoRequest 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;
/**
*
* Update information relating to replication between a given source and target Kafka cluster.
*
*/
@Generated("software.amazon.awssdk:codegen")
public final class UpdateReplicationInfoRequest extends KafkaRequest implements
ToCopyableBuilder {
private static final SdkField CONSUMER_GROUP_REPLICATION_FIELD = SdkField
. builder(MarshallingType.SDK_POJO).memberName("ConsumerGroupReplication")
.getter(getter(UpdateReplicationInfoRequest::consumerGroupReplication))
.setter(setter(Builder::consumerGroupReplication)).constructor(ConsumerGroupReplicationUpdate::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("consumerGroupReplication").build())
.build();
private static final SdkField CURRENT_VERSION_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("CurrentVersion").getter(getter(UpdateReplicationInfoRequest::currentVersion))
.setter(setter(Builder::currentVersion))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("currentVersion").build()).build();
private static final SdkField REPLICATOR_ARN_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("ReplicatorArn").getter(getter(UpdateReplicationInfoRequest::replicatorArn))
.setter(setter(Builder::replicatorArn))
.traits(LocationTrait.builder().location(MarshallLocation.PATH).locationName("replicatorArn").build()).build();
private static final SdkField SOURCE_KAFKA_CLUSTER_ARN_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("SourceKafkaClusterArn").getter(getter(UpdateReplicationInfoRequest::sourceKafkaClusterArn))
.setter(setter(Builder::sourceKafkaClusterArn))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("sourceKafkaClusterArn").build())
.build();
private static final SdkField TARGET_KAFKA_CLUSTER_ARN_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("TargetKafkaClusterArn").getter(getter(UpdateReplicationInfoRequest::targetKafkaClusterArn))
.setter(setter(Builder::targetKafkaClusterArn))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("targetKafkaClusterArn").build())
.build();
private static final SdkField TOPIC_REPLICATION_FIELD = SdkField
. builder(MarshallingType.SDK_POJO).memberName("TopicReplication")
.getter(getter(UpdateReplicationInfoRequest::topicReplication)).setter(setter(Builder::topicReplication))
.constructor(TopicReplicationUpdate::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("topicReplication").build()).build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(
CONSUMER_GROUP_REPLICATION_FIELD, CURRENT_VERSION_FIELD, REPLICATOR_ARN_FIELD, SOURCE_KAFKA_CLUSTER_ARN_FIELD,
TARGET_KAFKA_CLUSTER_ARN_FIELD, TOPIC_REPLICATION_FIELD));
private final ConsumerGroupReplicationUpdate consumerGroupReplication;
private final String currentVersion;
private final String replicatorArn;
private final String sourceKafkaClusterArn;
private final String targetKafkaClusterArn;
private final TopicReplicationUpdate topicReplication;
private UpdateReplicationInfoRequest(BuilderImpl builder) {
super(builder);
this.consumerGroupReplication = builder.consumerGroupReplication;
this.currentVersion = builder.currentVersion;
this.replicatorArn = builder.replicatorArn;
this.sourceKafkaClusterArn = builder.sourceKafkaClusterArn;
this.targetKafkaClusterArn = builder.targetKafkaClusterArn;
this.topicReplication = builder.topicReplication;
}
/**
*
* Updated consumer group replication information.
*
*
* @return Updated consumer group replication information.
*/
public final ConsumerGroupReplicationUpdate consumerGroupReplication() {
return consumerGroupReplication;
}
/**
*
* Current replicator version.
*
*
* @return Current replicator version.
*/
public final String currentVersion() {
return currentVersion;
}
/**
*
* The Amazon Resource Name (ARN) of the replicator to be updated.
*
*
* @return The Amazon Resource Name (ARN) of the replicator to be updated.
*/
public final String replicatorArn() {
return replicatorArn;
}
/**
*
* The ARN of the source Kafka cluster.
*
*
* @return The ARN of the source Kafka cluster.
*/
public final String sourceKafkaClusterArn() {
return sourceKafkaClusterArn;
}
/**
*
* The ARN of the target Kafka cluster.
*
*
* @return The ARN of the target Kafka cluster.
*/
public final String targetKafkaClusterArn() {
return targetKafkaClusterArn;
}
/**
*
* Updated topic replication information.
*
*
* @return Updated topic replication information.
*/
public final TopicReplicationUpdate topicReplication() {
return topicReplication;
}
@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(consumerGroupReplication());
hashCode = 31 * hashCode + Objects.hashCode(currentVersion());
hashCode = 31 * hashCode + Objects.hashCode(replicatorArn());
hashCode = 31 * hashCode + Objects.hashCode(sourceKafkaClusterArn());
hashCode = 31 * hashCode + Objects.hashCode(targetKafkaClusterArn());
hashCode = 31 * hashCode + Objects.hashCode(topicReplication());
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 UpdateReplicationInfoRequest)) {
return false;
}
UpdateReplicationInfoRequest other = (UpdateReplicationInfoRequest) obj;
return Objects.equals(consumerGroupReplication(), other.consumerGroupReplication())
&& Objects.equals(currentVersion(), other.currentVersion())
&& Objects.equals(replicatorArn(), other.replicatorArn())
&& Objects.equals(sourceKafkaClusterArn(), other.sourceKafkaClusterArn())
&& Objects.equals(targetKafkaClusterArn(), other.targetKafkaClusterArn())
&& Objects.equals(topicReplication(), other.topicReplication());
}
/**
* 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("UpdateReplicationInfoRequest").add("ConsumerGroupReplication", consumerGroupReplication())
.add("CurrentVersion", currentVersion()).add("ReplicatorArn", replicatorArn())
.add("SourceKafkaClusterArn", sourceKafkaClusterArn()).add("TargetKafkaClusterArn", targetKafkaClusterArn())
.add("TopicReplication", topicReplication()).build();
}
public final Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "ConsumerGroupReplication":
return Optional.ofNullable(clazz.cast(consumerGroupReplication()));
case "CurrentVersion":
return Optional.ofNullable(clazz.cast(currentVersion()));
case "ReplicatorArn":
return Optional.ofNullable(clazz.cast(replicatorArn()));
case "SourceKafkaClusterArn":
return Optional.ofNullable(clazz.cast(sourceKafkaClusterArn()));
case "TargetKafkaClusterArn":
return Optional.ofNullable(clazz.cast(targetKafkaClusterArn()));
case "TopicReplication":
return Optional.ofNullable(clazz.cast(topicReplication()));
default:
return Optional.empty();
}
}
@Override
public final List> sdkFields() {
return SDK_FIELDS;
}
private static Function