software.amazon.awssdk.services.dynamodb.model.DeleteResourcePolicyRequest Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dynamodb Show documentation
Show all versions of dynamodb Show documentation
The AWS Java SDK for Amazon DynamoDB module holds the client classes that are used for communicating
with Amazon DynamoDB
Service
/*
* 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.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 DeleteResourcePolicyRequest extends DynamoDbRequest implements
ToCopyableBuilder {
private static final SdkField RESOURCE_ARN_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("ResourceArn").getter(getter(DeleteResourcePolicyRequest::resourceArn))
.setter(setter(Builder::resourceArn))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ResourceArn").build()).build();
private static final SdkField EXPECTED_REVISION_ID_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("ExpectedRevisionId").getter(getter(DeleteResourcePolicyRequest::expectedRevisionId))
.setter(setter(Builder::expectedRevisionId))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ExpectedRevisionId").build())
.build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(RESOURCE_ARN_FIELD,
EXPECTED_REVISION_ID_FIELD));
private final String resourceArn;
private final String expectedRevisionId;
private DeleteResourcePolicyRequest(BuilderImpl builder) {
super(builder);
this.resourceArn = builder.resourceArn;
this.expectedRevisionId = builder.expectedRevisionId;
}
/**
*
* The Amazon Resource Name (ARN) of the DynamoDB resource from which the policy will be removed. The resources you
* can specify include tables and streams. If you remove the policy of a table, it will also remove the permissions
* for the table's indexes defined in that policy document. This is because index permissions are defined in the
* table's policy.
*
*
* @return The Amazon Resource Name (ARN) of the DynamoDB resource from which the policy will be removed. The
* resources you can specify include tables and streams. If you remove the policy of a table, it will also
* remove the permissions for the table's indexes defined in that policy document. This is because index
* permissions are defined in the table's policy.
*/
public final String resourceArn() {
return resourceArn;
}
/**
*
* A string value that you can use to conditionally delete your policy. When you provide an expected revision ID, if
* the revision ID of the existing policy on the resource doesn't match or if there's no policy attached to the
* resource, the request will fail and return a PolicyNotFoundException
.
*
*
* @return A string value that you can use to conditionally delete your policy. When you provide an expected
* revision ID, if the revision ID of the existing policy on the resource doesn't match or if there's no
* policy attached to the resource, the request will fail and return a PolicyNotFoundException
.
*/
public final String expectedRevisionId() {
return expectedRevisionId;
}
@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(resourceArn());
hashCode = 31 * hashCode + Objects.hashCode(expectedRevisionId());
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 DeleteResourcePolicyRequest)) {
return false;
}
DeleteResourcePolicyRequest other = (DeleteResourcePolicyRequest) obj;
return Objects.equals(resourceArn(), other.resourceArn())
&& Objects.equals(expectedRevisionId(), other.expectedRevisionId());
}
/**
* 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("DeleteResourcePolicyRequest").add("ResourceArn", resourceArn())
.add("ExpectedRevisionId", expectedRevisionId()).build();
}
public final Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "ResourceArn":
return Optional.ofNullable(clazz.cast(resourceArn()));
case "ExpectedRevisionId":
return Optional.ofNullable(clazz.cast(expectedRevisionId()));
default:
return Optional.empty();
}
}
@Override
public final List> sdkFields() {
return SDK_FIELDS;
}
private static Function