software.amazon.awssdk.services.kms.model.CloudHsmClusterInvalidConfigurationException Maven / Gradle / Ivy
Show all versions of kms Show documentation
/*
* 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.kms.model;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.awscore.exception.AwsErrorDetails;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
*
* The request was rejected because the associated AWS CloudHSM cluster did not meet the configuration requirements for
* a custom key store.
*
*
* -
*
* The cluster must be configured with private subnets in at least two different Availability Zones in the Region.
*
*
* -
*
* The security group for the
* cluster (cloudhsm-cluster-<cluster-id>-sg) must include inbound rules and outbound rules that allow
* TCP traffic on ports 2223-2225. The Source in the inbound rules and the Destination in the outbound
* rules must match the security group ID. These rules are set by default when you create the cluster. Do not delete or
* change them. To get information about a particular security group, use the DescribeSecurityGroups operation.
*
*
* -
*
* The cluster must contain at least as many HSMs as the operation requires. To add HSMs, use the AWS CloudHSM CreateHsm operation.
*
*
* For the CreateCustomKeyStore, UpdateCustomKeyStore, and CreateKey operations, the AWS CloudHSM
* cluster must have at least two active HSMs, each in a different Availability Zone. For the
* ConnectCustomKeyStore operation, the AWS CloudHSM must contain at least one active HSM.
*
*
*
*
* For information about the requirements for an AWS CloudHSM cluster that is associated with a custom key store, see Assemble the
* Prerequisites in the AWS Key Management Service Developer Guide. For information about creating a private
* subnet for an AWS CloudHSM cluster, see Create a Private Subnet in the
* AWS CloudHSM User Guide. For information about cluster security groups, see Configure a Default Security Group
* in the AWS CloudHSM User Guide .
*
*/
@Generated("software.amazon.awssdk:codegen")
public final class CloudHsmClusterInvalidConfigurationException extends KmsException implements
ToCopyableBuilder {
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList());
private static final long serialVersionUID = 1L;
private CloudHsmClusterInvalidConfigurationException(BuilderImpl builder) {
super(builder);
}
@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 List> sdkFields() {
return SDK_FIELDS;
}
public interface Builder extends SdkPojo, CopyableBuilder,
KmsException.Builder {
@Override
Builder awsErrorDetails(AwsErrorDetails awsErrorDetails);
@Override
Builder message(String message);
@Override
Builder requestId(String requestId);
@Override
Builder statusCode(int statusCode);
@Override
Builder cause(Throwable cause);
}
static final class BuilderImpl extends KmsException.BuilderImpl implements Builder {
private BuilderImpl() {
}
private BuilderImpl(CloudHsmClusterInvalidConfigurationException model) {
super(model);
}
@Override
public BuilderImpl awsErrorDetails(AwsErrorDetails awsErrorDetails) {
this.awsErrorDetails = awsErrorDetails;
return this;
}
@Override
public BuilderImpl message(String message) {
this.message = message;
return this;
}
@Override
public BuilderImpl requestId(String requestId) {
this.requestId = requestId;
return this;
}
@Override
public BuilderImpl statusCode(int statusCode) {
this.statusCode = statusCode;
return this;
}
@Override
public BuilderImpl cause(Throwable cause) {
this.cause = cause;
return this;
}
@Override
public CloudHsmClusterInvalidConfigurationException build() {
return new CloudHsmClusterInvalidConfigurationException(this);
}
@Override
public List> sdkFields() {
return SDK_FIELDS;
}
}
}