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

software.amazon.awssdk.services.neptune.model.DeleteDbClusterRequest Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Neptune module holds the client classes that are used for communicating with Neptune.

There is a newer version: 2.29.39
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.neptune.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 DeleteDbClusterRequest extends NeptuneRequest implements
        ToCopyableBuilder {
    private static final SdkField DB_CLUSTER_IDENTIFIER_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("DBClusterIdentifier").getter(getter(DeleteDbClusterRequest::dbClusterIdentifier))
            .setter(setter(Builder::dbClusterIdentifier))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("DBClusterIdentifier").build())
            .build();

    private static final SdkField SKIP_FINAL_SNAPSHOT_FIELD = SdkField. builder(MarshallingType.BOOLEAN)
            .memberName("SkipFinalSnapshot").getter(getter(DeleteDbClusterRequest::skipFinalSnapshot))
            .setter(setter(Builder::skipFinalSnapshot))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("SkipFinalSnapshot").build()).build();

    private static final SdkField FINAL_DB_SNAPSHOT_IDENTIFIER_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("FinalDBSnapshotIdentifier").getter(getter(DeleteDbClusterRequest::finalDBSnapshotIdentifier))
            .setter(setter(Builder::finalDBSnapshotIdentifier))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("FinalDBSnapshotIdentifier").build())
            .build();

    private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(DB_CLUSTER_IDENTIFIER_FIELD,
            SKIP_FINAL_SNAPSHOT_FIELD, FINAL_DB_SNAPSHOT_IDENTIFIER_FIELD));

    private final String dbClusterIdentifier;

    private final Boolean skipFinalSnapshot;

    private final String finalDBSnapshotIdentifier;

    private DeleteDbClusterRequest(BuilderImpl builder) {
        super(builder);
        this.dbClusterIdentifier = builder.dbClusterIdentifier;
        this.skipFinalSnapshot = builder.skipFinalSnapshot;
        this.finalDBSnapshotIdentifier = builder.finalDBSnapshotIdentifier;
    }

    /**
     * 

* The DB cluster identifier for the DB cluster to be deleted. This parameter isn't case-sensitive. *

*

* Constraints: *

*
    *
  • *

    * Must match an existing DBClusterIdentifier. *

    *
  • *
* * @return The DB cluster identifier for the DB cluster to be deleted. This parameter isn't case-sensitive.

*

* Constraints: *

*
    *
  • *

    * Must match an existing DBClusterIdentifier. *

    *
  • */ public final String dbClusterIdentifier() { return dbClusterIdentifier; } /** *

    * Determines whether a final DB cluster snapshot is created before the DB cluster is deleted. If true * is specified, no DB cluster snapshot is created. If false is specified, a DB cluster snapshot is * created before the DB cluster is deleted. *

    * *

    * You must specify a FinalDBSnapshotIdentifier parameter if SkipFinalSnapshot is * false. *

    *
    *

    * Default: false *

    * * @return Determines whether a final DB cluster snapshot is created before the DB cluster is deleted. If * true is specified, no DB cluster snapshot is created. If false is specified, a * DB cluster snapshot is created before the DB cluster is deleted.

    *

    * You must specify a FinalDBSnapshotIdentifier parameter if SkipFinalSnapshot is * false. *

    *
    *

    * Default: false */ public final Boolean skipFinalSnapshot() { return skipFinalSnapshot; } /** *

    * The DB cluster snapshot identifier of the new DB cluster snapshot created when SkipFinalSnapshot is * set to false. *

    * *

    * Specifying this parameter and also setting the SkipFinalShapshot parameter to true results in an * error. *

    *
    *

    * Constraints: *

    *
      *
    • *

      * Must be 1 to 255 letters, numbers, or hyphens. *

      *
    • *
    • *

      * First character must be a letter *

      *
    • *
    • *

      * Cannot end with a hyphen or contain two consecutive hyphens *

      *
    • *
    * * @return The DB cluster snapshot identifier of the new DB cluster snapshot created when * SkipFinalSnapshot is set to false.

    *

    * Specifying this parameter and also setting the SkipFinalShapshot parameter to true results * in an error. *

    *
    *

    * Constraints: *

    *
      *
    • *

      * Must be 1 to 255 letters, numbers, or hyphens. *

      *
    • *
    • *

      * First character must be a letter *

      *
    • *
    • *

      * Cannot end with a hyphen or contain two consecutive hyphens *

      *
    • */ public final String finalDBSnapshotIdentifier() { return finalDBSnapshotIdentifier; } @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(dbClusterIdentifier()); hashCode = 31 * hashCode + Objects.hashCode(skipFinalSnapshot()); hashCode = 31 * hashCode + Objects.hashCode(finalDBSnapshotIdentifier()); 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 DeleteDbClusterRequest)) { return false; } DeleteDbClusterRequest other = (DeleteDbClusterRequest) obj; return Objects.equals(dbClusterIdentifier(), other.dbClusterIdentifier()) && Objects.equals(skipFinalSnapshot(), other.skipFinalSnapshot()) && Objects.equals(finalDBSnapshotIdentifier(), other.finalDBSnapshotIdentifier()); } /** * 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("DeleteDbClusterRequest").add("DBClusterIdentifier", dbClusterIdentifier()) .add("SkipFinalSnapshot", skipFinalSnapshot()).add("FinalDBSnapshotIdentifier", finalDBSnapshotIdentifier()) .build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "DBClusterIdentifier": return Optional.ofNullable(clazz.cast(dbClusterIdentifier())); case "SkipFinalSnapshot": return Optional.ofNullable(clazz.cast(skipFinalSnapshot())); case "FinalDBSnapshotIdentifier": return Optional.ofNullable(clazz.cast(finalDBSnapshotIdentifier())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((DeleteDbClusterRequest) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends NeptuneRequest.Builder, SdkPojo, CopyableBuilder { /** *

      * The DB cluster identifier for the DB cluster to be deleted. This parameter isn't case-sensitive. *

      *

      * Constraints: *

      *
        *
      • *

        * Must match an existing DBClusterIdentifier. *

        *
      • *
      * * @param dbClusterIdentifier * The DB cluster identifier for the DB cluster to be deleted. This parameter isn't case-sensitive.

      *

      * Constraints: *

      *
        *
      • *

        * Must match an existing DBClusterIdentifier. *

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

        * Determines whether a final DB cluster snapshot is created before the DB cluster is deleted. If * true is specified, no DB cluster snapshot is created. If false is specified, a DB * cluster snapshot is created before the DB cluster is deleted. *

        * *

        * You must specify a FinalDBSnapshotIdentifier parameter if SkipFinalSnapshot is * false. *

        *
        *

        * Default: false *

        * * @param skipFinalSnapshot * Determines whether a final DB cluster snapshot is created before the DB cluster is deleted. If * true is specified, no DB cluster snapshot is created. If false is specified, * a DB cluster snapshot is created before the DB cluster is deleted.

        *

        * You must specify a FinalDBSnapshotIdentifier parameter if SkipFinalSnapshot * is false. *

        *
        *

        * Default: false * @return Returns a reference to this object so that method calls can be chained together. */ Builder skipFinalSnapshot(Boolean skipFinalSnapshot); /** *

        * The DB cluster snapshot identifier of the new DB cluster snapshot created when SkipFinalSnapshot * is set to false. *

        * *

        * Specifying this parameter and also setting the SkipFinalShapshot parameter to true results in an * error. *

        *
        *

        * Constraints: *

        *
          *
        • *

          * Must be 1 to 255 letters, numbers, or hyphens. *

          *
        • *
        • *

          * First character must be a letter *

          *
        • *
        • *

          * Cannot end with a hyphen or contain two consecutive hyphens *

          *
        • *
        * * @param finalDBSnapshotIdentifier * The DB cluster snapshot identifier of the new DB cluster snapshot created when * SkipFinalSnapshot is set to false.

        *

        * Specifying this parameter and also setting the SkipFinalShapshot parameter to true * results in an error. *

        *
        *

        * Constraints: *

        *
          *
        • *

          * Must be 1 to 255 letters, numbers, or hyphens. *

          *
        • *
        • *

          * First character must be a letter *

          *
        • *
        • *

          * Cannot end with a hyphen or contain two consecutive hyphens *

          *
        • * @return Returns a reference to this object so that method calls can be chained together. */ Builder finalDBSnapshotIdentifier(String finalDBSnapshotIdentifier); @Override Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration); @Override Builder overrideConfiguration(Consumer builderConsumer); } static final class BuilderImpl extends NeptuneRequest.BuilderImpl implements Builder { private String dbClusterIdentifier; private Boolean skipFinalSnapshot; private String finalDBSnapshotIdentifier; private BuilderImpl() { } private BuilderImpl(DeleteDbClusterRequest model) { super(model); dbClusterIdentifier(model.dbClusterIdentifier); skipFinalSnapshot(model.skipFinalSnapshot); finalDBSnapshotIdentifier(model.finalDBSnapshotIdentifier); } public final String getDbClusterIdentifier() { return dbClusterIdentifier; } public final void setDbClusterIdentifier(String dbClusterIdentifier) { this.dbClusterIdentifier = dbClusterIdentifier; } @Override public final Builder dbClusterIdentifier(String dbClusterIdentifier) { this.dbClusterIdentifier = dbClusterIdentifier; return this; } public final Boolean getSkipFinalSnapshot() { return skipFinalSnapshot; } public final void setSkipFinalSnapshot(Boolean skipFinalSnapshot) { this.skipFinalSnapshot = skipFinalSnapshot; } @Override public final Builder skipFinalSnapshot(Boolean skipFinalSnapshot) { this.skipFinalSnapshot = skipFinalSnapshot; return this; } public final String getFinalDBSnapshotIdentifier() { return finalDBSnapshotIdentifier; } public final void setFinalDBSnapshotIdentifier(String finalDBSnapshotIdentifier) { this.finalDBSnapshotIdentifier = finalDBSnapshotIdentifier; } @Override public final Builder finalDBSnapshotIdentifier(String finalDBSnapshotIdentifier) { this.finalDBSnapshotIdentifier = finalDBSnapshotIdentifier; 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 DeleteDbClusterRequest build() { return new DeleteDbClusterRequest(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy