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

software.amazon.awssdk.services.dax.model.IncreaseReplicationFactorRequest Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Amazon DynamoDB Accelerator (DAX) module holds the client classes that are used for communicating with Amazon DynamoDB Accelerator (DAX).

There is a newer version: 2.30.1
Show newest version
/*
 * 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.dax.model;

import java.util.Arrays;
import java.util.Collection;
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.ListTrait;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructList;
import software.amazon.awssdk.core.util.SdkAutoConstructList;
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 IncreaseReplicationFactorRequest extends DaxRequest implements
        ToCopyableBuilder {
    private static final SdkField CLUSTER_NAME_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("ClusterName").getter(getter(IncreaseReplicationFactorRequest::clusterName))
            .setter(setter(Builder::clusterName))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ClusterName").build()).build();

    private static final SdkField NEW_REPLICATION_FACTOR_FIELD = SdkField. builder(MarshallingType.INTEGER)
            .memberName("NewReplicationFactor").getter(getter(IncreaseReplicationFactorRequest::newReplicationFactor))
            .setter(setter(Builder::newReplicationFactor))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("NewReplicationFactor").build())
            .build();

    private static final SdkField> AVAILABILITY_ZONES_FIELD = SdkField
            .> builder(MarshallingType.LIST)
            .memberName("AvailabilityZones")
            .getter(getter(IncreaseReplicationFactorRequest::availabilityZones))
            .setter(setter(Builder::availabilityZones))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("AvailabilityZones").build(),
                    ListTrait
                            .builder()
                            .memberLocationName(null)
                            .memberFieldInfo(
                                    SdkField. builder(MarshallingType.STRING)
                                            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD)
                                                    .locationName("member").build()).build()).build()).build();

    private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(CLUSTER_NAME_FIELD,
            NEW_REPLICATION_FACTOR_FIELD, AVAILABILITY_ZONES_FIELD));

    private final String clusterName;

    private final Integer newReplicationFactor;

    private final List availabilityZones;

    private IncreaseReplicationFactorRequest(BuilderImpl builder) {
        super(builder);
        this.clusterName = builder.clusterName;
        this.newReplicationFactor = builder.newReplicationFactor;
        this.availabilityZones = builder.availabilityZones;
    }

    /**
     * 

* The name of the DAX cluster that will receive additional nodes. *

* * @return The name of the DAX cluster that will receive additional nodes. */ public final String clusterName() { return clusterName; } /** *

* The new number of nodes for the DAX cluster. *

* * @return The new number of nodes for the DAX cluster. */ public final Integer newReplicationFactor() { return newReplicationFactor; } /** * For responses, this returns true if the service returned a value for the AvailabilityZones property. This DOES * NOT check that the value is non-empty (for which, you should check the {@code isEmpty()} method on the property). * This is useful because the SDK will never return a null collection or map, but you may need to differentiate * between the service returning nothing (or null) and the service returning an empty collection or map. For * requests, this returns true if a value for the property was specified in the request builder, and false if a * value was not specified. */ public final boolean hasAvailabilityZones() { return availabilityZones != null && !(availabilityZones instanceof SdkAutoConstructList); } /** *

* The Availability Zones (AZs) in which the cluster nodes will be created. All nodes belonging to the cluster are * placed in these Availability Zones. Use this parameter if you want to distribute the nodes across multiple AZs. *

*

* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException. *

*

* This method will never return null. If you would like to know whether the service returned this field (so that * you can differentiate between null and empty), you can use the {@link #hasAvailabilityZones} method. *

* * @return The Availability Zones (AZs) in which the cluster nodes will be created. All nodes belonging to the * cluster are placed in these Availability Zones. Use this parameter if you want to distribute the nodes * across multiple AZs. */ public final List availabilityZones() { return availabilityZones; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public final int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + super.hashCode(); hashCode = 31 * hashCode + Objects.hashCode(clusterName()); hashCode = 31 * hashCode + Objects.hashCode(newReplicationFactor()); hashCode = 31 * hashCode + Objects.hashCode(hasAvailabilityZones() ? availabilityZones() : null); 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 IncreaseReplicationFactorRequest)) { return false; } IncreaseReplicationFactorRequest other = (IncreaseReplicationFactorRequest) obj; return Objects.equals(clusterName(), other.clusterName()) && Objects.equals(newReplicationFactor(), other.newReplicationFactor()) && hasAvailabilityZones() == other.hasAvailabilityZones() && Objects.equals(availabilityZones(), other.availabilityZones()); } /** * 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("IncreaseReplicationFactorRequest").add("ClusterName", clusterName()) .add("NewReplicationFactor", newReplicationFactor()) .add("AvailabilityZones", hasAvailabilityZones() ? availabilityZones() : null).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "ClusterName": return Optional.ofNullable(clazz.cast(clusterName())); case "NewReplicationFactor": return Optional.ofNullable(clazz.cast(newReplicationFactor())); case "AvailabilityZones": return Optional.ofNullable(clazz.cast(availabilityZones())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((IncreaseReplicationFactorRequest) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends DaxRequest.Builder, SdkPojo, CopyableBuilder { /** *

* The name of the DAX cluster that will receive additional nodes. *

* * @param clusterName * The name of the DAX cluster that will receive additional nodes. * @return Returns a reference to this object so that method calls can be chained together. */ Builder clusterName(String clusterName); /** *

* The new number of nodes for the DAX cluster. *

* * @param newReplicationFactor * The new number of nodes for the DAX cluster. * @return Returns a reference to this object so that method calls can be chained together. */ Builder newReplicationFactor(Integer newReplicationFactor); /** *

* The Availability Zones (AZs) in which the cluster nodes will be created. All nodes belonging to the cluster * are placed in these Availability Zones. Use this parameter if you want to distribute the nodes across * multiple AZs. *

* * @param availabilityZones * The Availability Zones (AZs) in which the cluster nodes will be created. All nodes belonging to the * cluster are placed in these Availability Zones. Use this parameter if you want to distribute the nodes * across multiple AZs. * @return Returns a reference to this object so that method calls can be chained together. */ Builder availabilityZones(Collection availabilityZones); /** *

* The Availability Zones (AZs) in which the cluster nodes will be created. All nodes belonging to the cluster * are placed in these Availability Zones. Use this parameter if you want to distribute the nodes across * multiple AZs. *

* * @param availabilityZones * The Availability Zones (AZs) in which the cluster nodes will be created. All nodes belonging to the * cluster are placed in these Availability Zones. Use this parameter if you want to distribute the nodes * across multiple AZs. * @return Returns a reference to this object so that method calls can be chained together. */ Builder availabilityZones(String... availabilityZones); @Override Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration); @Override Builder overrideConfiguration(Consumer builderConsumer); } static final class BuilderImpl extends DaxRequest.BuilderImpl implements Builder { private String clusterName; private Integer newReplicationFactor; private List availabilityZones = DefaultSdkAutoConstructList.getInstance(); private BuilderImpl() { } private BuilderImpl(IncreaseReplicationFactorRequest model) { super(model); clusterName(model.clusterName); newReplicationFactor(model.newReplicationFactor); availabilityZones(model.availabilityZones); } public final String getClusterName() { return clusterName; } public final void setClusterName(String clusterName) { this.clusterName = clusterName; } @Override public final Builder clusterName(String clusterName) { this.clusterName = clusterName; return this; } public final Integer getNewReplicationFactor() { return newReplicationFactor; } public final void setNewReplicationFactor(Integer newReplicationFactor) { this.newReplicationFactor = newReplicationFactor; } @Override public final Builder newReplicationFactor(Integer newReplicationFactor) { this.newReplicationFactor = newReplicationFactor; return this; } public final Collection getAvailabilityZones() { if (availabilityZones instanceof SdkAutoConstructList) { return null; } return availabilityZones; } public final void setAvailabilityZones(Collection availabilityZones) { this.availabilityZones = AvailabilityZoneListCopier.copy(availabilityZones); } @Override public final Builder availabilityZones(Collection availabilityZones) { this.availabilityZones = AvailabilityZoneListCopier.copy(availabilityZones); return this; } @Override @SafeVarargs public final Builder availabilityZones(String... availabilityZones) { availabilityZones(Arrays.asList(availabilityZones)); return this; } @Override public Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration) { super.overrideConfiguration(overrideConfiguration); return this; } @Override public Builder overrideConfiguration(Consumer builderConsumer) { super.overrideConfiguration(builderConsumer); return this; } @Override public IncreaseReplicationFactorRequest build() { return new IncreaseReplicationFactorRequest(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy