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

software.amazon.awssdk.services.kinesis.model.UpdateShardCountRequest Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Amazon Kinesis module holds the client classes that are used for communicating with Amazon Kinesis Service

The 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.kinesis.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 UpdateShardCountRequest extends KinesisRequest implements
        ToCopyableBuilder {
    private static final SdkField STREAM_NAME_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("StreamName").getter(getter(UpdateShardCountRequest::streamName)).setter(setter(Builder::streamName))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("StreamName").build()).build();

    private static final SdkField TARGET_SHARD_COUNT_FIELD = SdkField. builder(MarshallingType.INTEGER)
            .memberName("TargetShardCount").getter(getter(UpdateShardCountRequest::targetShardCount))
            .setter(setter(Builder::targetShardCount))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("TargetShardCount").build()).build();

    private static final SdkField SCALING_TYPE_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("ScalingType").getter(getter(UpdateShardCountRequest::scalingTypeAsString))
            .setter(setter(Builder::scalingType))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ScalingType").build()).build();

    private static final SdkField STREAM_ARN_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("StreamARN").getter(getter(UpdateShardCountRequest::streamARN)).setter(setter(Builder::streamARN))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("StreamARN").build()).build();

    private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(STREAM_NAME_FIELD,
            TARGET_SHARD_COUNT_FIELD, SCALING_TYPE_FIELD, STREAM_ARN_FIELD));

    private final String streamName;

    private final Integer targetShardCount;

    private final String scalingType;

    private final String streamARN;

    private UpdateShardCountRequest(BuilderImpl builder) {
        super(builder);
        this.streamName = builder.streamName;
        this.targetShardCount = builder.targetShardCount;
        this.scalingType = builder.scalingType;
        this.streamARN = builder.streamARN;
    }

    /**
     * 

* The name of the stream. *

* * @return The name of the stream. */ public final String streamName() { return streamName; } /** *

* The new number of shards. This value has the following default limits. By default, you cannot do the following: *

*
    *
  • *

    * Set this value to more than double your current shard count for a stream. *

    *
  • *
  • *

    * Set this value below half your current shard count for a stream. *

    *
  • *
  • *

    * Set this value to more than 10000 shards in a stream (the default limit for shard count per stream is 10000 per * account per region), unless you request a limit increase. *

    *
  • *
  • *

    * Scale a stream with more than 10000 shards down unless you set this value to less than 10000 shards. *

    *
  • *
* * @return The new number of shards. This value has the following default limits. By default, you cannot do the * following:

*
    *
  • *

    * Set this value to more than double your current shard count for a stream. *

    *
  • *
  • *

    * Set this value below half your current shard count for a stream. *

    *
  • *
  • *

    * Set this value to more than 10000 shards in a stream (the default limit for shard count per stream is * 10000 per account per region), unless you request a limit increase. *

    *
  • *
  • *

    * Scale a stream with more than 10000 shards down unless you set this value to less than 10000 shards. *

    *
  • */ public final Integer targetShardCount() { return targetShardCount; } /** *

    * The scaling type. Uniform scaling creates shards of equal size. *

    *

    * If the service returns an enum value that is not available in the current SDK version, {@link #scalingType} will * return {@link ScalingType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from * {@link #scalingTypeAsString}. *

    * * @return The scaling type. Uniform scaling creates shards of equal size. * @see ScalingType */ public final ScalingType scalingType() { return ScalingType.fromValue(scalingType); } /** *

    * The scaling type. Uniform scaling creates shards of equal size. *

    *

    * If the service returns an enum value that is not available in the current SDK version, {@link #scalingType} will * return {@link ScalingType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from * {@link #scalingTypeAsString}. *

    * * @return The scaling type. Uniform scaling creates shards of equal size. * @see ScalingType */ public final String scalingTypeAsString() { return scalingType; } /** *

    * The ARN of the stream. *

    * * @return The ARN of the stream. */ public final String streamARN() { return streamARN; } @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(streamName()); hashCode = 31 * hashCode + Objects.hashCode(targetShardCount()); hashCode = 31 * hashCode + Objects.hashCode(scalingTypeAsString()); hashCode = 31 * hashCode + Objects.hashCode(streamARN()); 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 UpdateShardCountRequest)) { return false; } UpdateShardCountRequest other = (UpdateShardCountRequest) obj; return Objects.equals(streamName(), other.streamName()) && Objects.equals(targetShardCount(), other.targetShardCount()) && Objects.equals(scalingTypeAsString(), other.scalingTypeAsString()) && Objects.equals(streamARN(), other.streamARN()); } /** * 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("UpdateShardCountRequest").add("StreamName", streamName()) .add("TargetShardCount", targetShardCount()).add("ScalingType", scalingTypeAsString()) .add("StreamARN", streamARN()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "StreamName": return Optional.ofNullable(clazz.cast(streamName())); case "TargetShardCount": return Optional.ofNullable(clazz.cast(targetShardCount())); case "ScalingType": return Optional.ofNullable(clazz.cast(scalingTypeAsString())); case "StreamARN": return Optional.ofNullable(clazz.cast(streamARN())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((UpdateShardCountRequest) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends KinesisRequest.Builder, SdkPojo, CopyableBuilder { /** *

    * The name of the stream. *

    * * @param streamName * The name of the stream. * @return Returns a reference to this object so that method calls can be chained together. */ Builder streamName(String streamName); /** *

    * The new number of shards. This value has the following default limits. By default, you cannot do the * following: *

    *
      *
    • *

      * Set this value to more than double your current shard count for a stream. *

      *
    • *
    • *

      * Set this value below half your current shard count for a stream. *

      *
    • *
    • *

      * Set this value to more than 10000 shards in a stream (the default limit for shard count per stream is 10000 * per account per region), unless you request a limit increase. *

      *
    • *
    • *

      * Scale a stream with more than 10000 shards down unless you set this value to less than 10000 shards. *

      *
    • *
    * * @param targetShardCount * The new number of shards. This value has the following default limits. By default, you cannot do the * following:

    *
      *
    • *

      * Set this value to more than double your current shard count for a stream. *

      *
    • *
    • *

      * Set this value below half your current shard count for a stream. *

      *
    • *
    • *

      * Set this value to more than 10000 shards in a stream (the default limit for shard count per stream is * 10000 per account per region), unless you request a limit increase. *

      *
    • *
    • *

      * Scale a stream with more than 10000 shards down unless you set this value to less than 10000 shards. *

      *
    • * @return Returns a reference to this object so that method calls can be chained together. */ Builder targetShardCount(Integer targetShardCount); /** *

      * The scaling type. Uniform scaling creates shards of equal size. *

      * * @param scalingType * The scaling type. Uniform scaling creates shards of equal size. * @see ScalingType * @return Returns a reference to this object so that method calls can be chained together. * @see ScalingType */ Builder scalingType(String scalingType); /** *

      * The scaling type. Uniform scaling creates shards of equal size. *

      * * @param scalingType * The scaling type. Uniform scaling creates shards of equal size. * @see ScalingType * @return Returns a reference to this object so that method calls can be chained together. * @see ScalingType */ Builder scalingType(ScalingType scalingType); /** *

      * The ARN of the stream. *

      * * @param streamARN * The ARN of the stream. * @return Returns a reference to this object so that method calls can be chained together. */ Builder streamARN(String streamARN); @Override Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration); @Override Builder overrideConfiguration(Consumer builderConsumer); } static final class BuilderImpl extends KinesisRequest.BuilderImpl implements Builder { private String streamName; private Integer targetShardCount; private String scalingType; private String streamARN; private BuilderImpl() { } private BuilderImpl(UpdateShardCountRequest model) { super(model); streamName(model.streamName); targetShardCount(model.targetShardCount); scalingType(model.scalingType); streamARN(model.streamARN); } public final String getStreamName() { return streamName; } public final void setStreamName(String streamName) { this.streamName = streamName; } @Override public final Builder streamName(String streamName) { this.streamName = streamName; return this; } public final Integer getTargetShardCount() { return targetShardCount; } public final void setTargetShardCount(Integer targetShardCount) { this.targetShardCount = targetShardCount; } @Override public final Builder targetShardCount(Integer targetShardCount) { this.targetShardCount = targetShardCount; return this; } public final String getScalingType() { return scalingType; } public final void setScalingType(String scalingType) { this.scalingType = scalingType; } @Override public final Builder scalingType(String scalingType) { this.scalingType = scalingType; return this; } @Override public final Builder scalingType(ScalingType scalingType) { this.scalingType(scalingType == null ? null : scalingType.toString()); return this; } public final String getStreamARN() { return streamARN; } public final void setStreamARN(String streamARN) { this.streamARN = streamARN; } @Override public final Builder streamARN(String streamARN) { this.streamARN = streamARN; 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 UpdateShardCountRequest build() { return new UpdateShardCountRequest(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy