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

software.amazon.awssdk.services.dynamodb.model.ReplicationGroupUpdate Maven / Gradle / Ivy

Go to download

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

There is a newer version: 2.28.3
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.dynamodb.model;

import java.io.Serializable;
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.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;

/**
 * 

* Represents one of the following: *

*
    *
  • *

    * A new replica to be added to an existing regional table or global table. This request invokes the * CreateTableReplica action in the destination Region. *

    *
  • *
  • *

    * New parameters for an existing replica. This request invokes the UpdateTable action in the destination * Region. *

    *
  • *
  • *

    * An existing replica to be deleted. The request invokes the DeleteTableReplica action in the destination * Region, deleting the replica and all if its items in the destination Region. *

    *
  • *
* *

* When you manually remove a table or global table replica, you do not automatically remove any associated scalable * targets, scaling policies, or CloudWatch alarms. *

*
*/ @Generated("software.amazon.awssdk:codegen") public final class ReplicationGroupUpdate implements SdkPojo, Serializable, ToCopyableBuilder { private static final SdkField CREATE_FIELD = SdkField . builder(MarshallingType.SDK_POJO).memberName("Create") .getter(getter(ReplicationGroupUpdate::create)).setter(setter(Builder::create)) .constructor(CreateReplicationGroupMemberAction::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Create").build()).build(); private static final SdkField UPDATE_FIELD = SdkField . builder(MarshallingType.SDK_POJO).memberName("Update") .getter(getter(ReplicationGroupUpdate::update)).setter(setter(Builder::update)) .constructor(UpdateReplicationGroupMemberAction::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Update").build()).build(); private static final SdkField DELETE_FIELD = SdkField . builder(MarshallingType.SDK_POJO).memberName("Delete") .getter(getter(ReplicationGroupUpdate::delete)).setter(setter(Builder::delete)) .constructor(DeleteReplicationGroupMemberAction::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Delete").build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(CREATE_FIELD, UPDATE_FIELD, DELETE_FIELD)); private static final long serialVersionUID = 1L; private final CreateReplicationGroupMemberAction create; private final UpdateReplicationGroupMemberAction update; private final DeleteReplicationGroupMemberAction delete; private ReplicationGroupUpdate(BuilderImpl builder) { this.create = builder.create; this.update = builder.update; this.delete = builder.delete; } /** *

* The parameters required for creating a replica for the table. *

* * @return The parameters required for creating a replica for the table. */ public final CreateReplicationGroupMemberAction create() { return create; } /** *

* The parameters required for updating a replica for the table. *

* * @return The parameters required for updating a replica for the table. */ public final UpdateReplicationGroupMemberAction update() { return update; } /** *

* The parameters required for deleting a replica for the table. *

* * @return The parameters required for deleting a replica for the table. */ public final DeleteReplicationGroupMemberAction delete() { return delete; } @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 + Objects.hashCode(create()); hashCode = 31 * hashCode + Objects.hashCode(update()); hashCode = 31 * hashCode + Objects.hashCode(delete()); return hashCode; } @Override public final boolean equals(Object obj) { return equalsBySdkFields(obj); } @Override public final boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof ReplicationGroupUpdate)) { return false; } ReplicationGroupUpdate other = (ReplicationGroupUpdate) obj; return Objects.equals(create(), other.create()) && Objects.equals(update(), other.update()) && Objects.equals(delete(), other.delete()); } /** * 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("ReplicationGroupUpdate").add("Create", create()).add("Update", update()).add("Delete", delete()) .build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "Create": return Optional.ofNullable(clazz.cast(create())); case "Update": return Optional.ofNullable(clazz.cast(update())); case "Delete": return Optional.ofNullable(clazz.cast(delete())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((ReplicationGroupUpdate) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** *

* The parameters required for creating a replica for the table. *

* * @param create * The parameters required for creating a replica for the table. * @return Returns a reference to this object so that method calls can be chained together. */ Builder create(CreateReplicationGroupMemberAction create); /** *

* The parameters required for creating a replica for the table. *

* This is a convenience method that creates an instance of the * {@link CreateReplicationGroupMemberAction.Builder} avoiding the need to create one manually via * {@link CreateReplicationGroupMemberAction#builder()}. * *

* When the {@link Consumer} completes, {@link CreateReplicationGroupMemberAction.Builder#build()} is called * immediately and its result is passed to {@link #create(CreateReplicationGroupMemberAction)}. * * @param create * a consumer that will call methods on {@link CreateReplicationGroupMemberAction.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #create(CreateReplicationGroupMemberAction) */ default Builder create(Consumer create) { return create(CreateReplicationGroupMemberAction.builder().applyMutation(create).build()); } /** *

* The parameters required for updating a replica for the table. *

* * @param update * The parameters required for updating a replica for the table. * @return Returns a reference to this object so that method calls can be chained together. */ Builder update(UpdateReplicationGroupMemberAction update); /** *

* The parameters required for updating a replica for the table. *

* This is a convenience method that creates an instance of the * {@link UpdateReplicationGroupMemberAction.Builder} avoiding the need to create one manually via * {@link UpdateReplicationGroupMemberAction#builder()}. * *

* When the {@link Consumer} completes, {@link UpdateReplicationGroupMemberAction.Builder#build()} is called * immediately and its result is passed to {@link #update(UpdateReplicationGroupMemberAction)}. * * @param update * a consumer that will call methods on {@link UpdateReplicationGroupMemberAction.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #update(UpdateReplicationGroupMemberAction) */ default Builder update(Consumer update) { return update(UpdateReplicationGroupMemberAction.builder().applyMutation(update).build()); } /** *

* The parameters required for deleting a replica for the table. *

* * @param delete * The parameters required for deleting a replica for the table. * @return Returns a reference to this object so that method calls can be chained together. */ Builder delete(DeleteReplicationGroupMemberAction delete); /** *

* The parameters required for deleting a replica for the table. *

* This is a convenience method that creates an instance of the * {@link DeleteReplicationGroupMemberAction.Builder} avoiding the need to create one manually via * {@link DeleteReplicationGroupMemberAction#builder()}. * *

* When the {@link Consumer} completes, {@link DeleteReplicationGroupMemberAction.Builder#build()} is called * immediately and its result is passed to {@link #delete(DeleteReplicationGroupMemberAction)}. * * @param delete * a consumer that will call methods on {@link DeleteReplicationGroupMemberAction.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #delete(DeleteReplicationGroupMemberAction) */ default Builder delete(Consumer delete) { return delete(DeleteReplicationGroupMemberAction.builder().applyMutation(delete).build()); } } static final class BuilderImpl implements Builder { private CreateReplicationGroupMemberAction create; private UpdateReplicationGroupMemberAction update; private DeleteReplicationGroupMemberAction delete; private BuilderImpl() { } private BuilderImpl(ReplicationGroupUpdate model) { create(model.create); update(model.update); delete(model.delete); } public final CreateReplicationGroupMemberAction.Builder getCreate() { return create != null ? create.toBuilder() : null; } public final void setCreate(CreateReplicationGroupMemberAction.BuilderImpl create) { this.create = create != null ? create.build() : null; } @Override public final Builder create(CreateReplicationGroupMemberAction create) { this.create = create; return this; } public final UpdateReplicationGroupMemberAction.Builder getUpdate() { return update != null ? update.toBuilder() : null; } public final void setUpdate(UpdateReplicationGroupMemberAction.BuilderImpl update) { this.update = update != null ? update.build() : null; } @Override public final Builder update(UpdateReplicationGroupMemberAction update) { this.update = update; return this; } public final DeleteReplicationGroupMemberAction.Builder getDelete() { return delete != null ? delete.toBuilder() : null; } public final void setDelete(DeleteReplicationGroupMemberAction.BuilderImpl delete) { this.delete = delete != null ? delete.build() : null; } @Override public final Builder delete(DeleteReplicationGroupMemberAction delete) { this.delete = delete; return this; } @Override public ReplicationGroupUpdate build() { return new ReplicationGroupUpdate(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy