org.mongodb.awscdk.resources.mongodbatlas.AtlasEncryptionAtRestProps Maven / Gradle / Ivy
Show all versions of awscdk-resources-mongodbatlas Show documentation
package org.mongodb.awscdk.resources.mongodbatlas;
/**
*/
@javax.annotation.Generated(value = "jsii-pacmak/1.101.0 (build b95fe5d)", date = "2024-07-30T09:54:28.876Z")
@software.amazon.jsii.Jsii(module = org.mongodb.awscdk.resources.mongodbatlas.$Module.class, fqn = "awscdk-resources-mongodbatlas.AtlasEncryptionAtRestProps")
@software.amazon.jsii.Jsii.Proxy(AtlasEncryptionAtRestProps.Jsii$Proxy.class)
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public interface AtlasEncryptionAtRestProps extends software.amazon.jsii.JsiiSerializable {
/**
* The AWS customer master key used to encrypt and decrypt the MongoDB master keys.
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
@org.jetbrains.annotations.NotNull java.lang.String getCustomerMasterKeyId();
/**
* Unique identifier of the Atlas project to which the user belongs.
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
@org.jetbrains.annotations.NotNull java.lang.String getProjectId();
/**
* ID of an AWS IAM role authorized to manage an AWS customer master key.
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
@org.jetbrains.annotations.NotNull java.lang.String getRoleId();
/**
* Specifies whether Encryption at Rest is enabled for an Atlas project.
*
* To disable Encryption at Rest, pass only this parameter with a value of false. When you disable Encryption at Rest, Atlas also removes the configuration details.
* Default Value: true
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
default @org.jetbrains.annotations.Nullable java.lang.Boolean getEnabled() {
return null;
}
/**
* The profile is defined in AWS Secret manager.
*
* See Secret Manager Profile setup.
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
default @org.jetbrains.annotations.Nullable java.lang.String getProfile() {
return null;
}
/**
* The AWS region in which the AWS customer master key exists.
*
* Default Value: US_EAST_1
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
default @org.jetbrains.annotations.Nullable java.lang.String getRegion() {
return null;
}
/**
* @return a {@link Builder} of {@link AtlasEncryptionAtRestProps}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
static Builder builder() {
return new Builder();
}
/**
* A builder for {@link AtlasEncryptionAtRestProps}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public static final class Builder implements software.amazon.jsii.Builder {
java.lang.String customerMasterKeyId;
java.lang.String projectId;
java.lang.String roleId;
java.lang.Boolean enabled;
java.lang.String profile;
java.lang.String region;
/**
* Sets the value of {@link AtlasEncryptionAtRestProps#getCustomerMasterKeyId}
* @param customerMasterKeyId The AWS customer master key used to encrypt and decrypt the MongoDB master keys. This parameter is required.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder customerMasterKeyId(java.lang.String customerMasterKeyId) {
this.customerMasterKeyId = customerMasterKeyId;
return this;
}
/**
* Sets the value of {@link AtlasEncryptionAtRestProps#getProjectId}
* @param projectId Unique identifier of the Atlas project to which the user belongs. This parameter is required.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder projectId(java.lang.String projectId) {
this.projectId = projectId;
return this;
}
/**
* Sets the value of {@link AtlasEncryptionAtRestProps#getRoleId}
* @param roleId ID of an AWS IAM role authorized to manage an AWS customer master key. This parameter is required.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder roleId(java.lang.String roleId) {
this.roleId = roleId;
return this;
}
/**
* Sets the value of {@link AtlasEncryptionAtRestProps#getEnabled}
* @param enabled Specifies whether Encryption at Rest is enabled for an Atlas project.
* To disable Encryption at Rest, pass only this parameter with a value of false. When you disable Encryption at Rest, Atlas also removes the configuration details.
* Default Value: true
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder enabled(java.lang.Boolean enabled) {
this.enabled = enabled;
return this;
}
/**
* Sets the value of {@link AtlasEncryptionAtRestProps#getProfile}
* @param profile The profile is defined in AWS Secret manager.
* See Secret Manager Profile setup.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder profile(java.lang.String profile) {
this.profile = profile;
return this;
}
/**
* Sets the value of {@link AtlasEncryptionAtRestProps#getRegion}
* @param region The AWS region in which the AWS customer master key exists.
* Default Value: US_EAST_1
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder region(java.lang.String region) {
this.region = region;
return this;
}
/**
* Builds the configured instance.
* @return a new instance of {@link AtlasEncryptionAtRestProps}
* @throws NullPointerException if any required attribute was not provided
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
@Override
public AtlasEncryptionAtRestProps build() {
return new Jsii$Proxy(this);
}
}
/**
* An implementation for {@link AtlasEncryptionAtRestProps}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
@software.amazon.jsii.Internal
final class Jsii$Proxy extends software.amazon.jsii.JsiiObject implements AtlasEncryptionAtRestProps {
private final java.lang.String customerMasterKeyId;
private final java.lang.String projectId;
private final java.lang.String roleId;
private final java.lang.Boolean enabled;
private final java.lang.String profile;
private final java.lang.String region;
/**
* Constructor that initializes the object based on values retrieved from the JsiiObject.
* @param objRef Reference to the JSII managed object.
*/
protected Jsii$Proxy(final software.amazon.jsii.JsiiObjectRef objRef) {
super(objRef);
this.customerMasterKeyId = software.amazon.jsii.Kernel.get(this, "customerMasterKeyId", software.amazon.jsii.NativeType.forClass(java.lang.String.class));
this.projectId = software.amazon.jsii.Kernel.get(this, "projectId", software.amazon.jsii.NativeType.forClass(java.lang.String.class));
this.roleId = software.amazon.jsii.Kernel.get(this, "roleId", software.amazon.jsii.NativeType.forClass(java.lang.String.class));
this.enabled = software.amazon.jsii.Kernel.get(this, "enabled", software.amazon.jsii.NativeType.forClass(java.lang.Boolean.class));
this.profile = software.amazon.jsii.Kernel.get(this, "profile", software.amazon.jsii.NativeType.forClass(java.lang.String.class));
this.region = software.amazon.jsii.Kernel.get(this, "region", software.amazon.jsii.NativeType.forClass(java.lang.String.class));
}
/**
* Constructor that initializes the object based on literal property values passed by the {@link Builder}.
*/
protected Jsii$Proxy(final Builder builder) {
super(software.amazon.jsii.JsiiObject.InitializationMode.JSII);
this.customerMasterKeyId = java.util.Objects.requireNonNull(builder.customerMasterKeyId, "customerMasterKeyId is required");
this.projectId = java.util.Objects.requireNonNull(builder.projectId, "projectId is required");
this.roleId = java.util.Objects.requireNonNull(builder.roleId, "roleId is required");
this.enabled = builder.enabled;
this.profile = builder.profile;
this.region = builder.region;
}
@Override
public final java.lang.String getCustomerMasterKeyId() {
return this.customerMasterKeyId;
}
@Override
public final java.lang.String getProjectId() {
return this.projectId;
}
@Override
public final java.lang.String getRoleId() {
return this.roleId;
}
@Override
public final java.lang.Boolean getEnabled() {
return this.enabled;
}
@Override
public final java.lang.String getProfile() {
return this.profile;
}
@Override
public final java.lang.String getRegion() {
return this.region;
}
@Override
@software.amazon.jsii.Internal
public com.fasterxml.jackson.databind.JsonNode $jsii$toJson() {
final com.fasterxml.jackson.databind.ObjectMapper om = software.amazon.jsii.JsiiObjectMapper.INSTANCE;
final com.fasterxml.jackson.databind.node.ObjectNode data = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode();
data.set("customerMasterKeyId", om.valueToTree(this.getCustomerMasterKeyId()));
data.set("projectId", om.valueToTree(this.getProjectId()));
data.set("roleId", om.valueToTree(this.getRoleId()));
if (this.getEnabled() != null) {
data.set("enabled", om.valueToTree(this.getEnabled()));
}
if (this.getProfile() != null) {
data.set("profile", om.valueToTree(this.getProfile()));
}
if (this.getRegion() != null) {
data.set("region", om.valueToTree(this.getRegion()));
}
final com.fasterxml.jackson.databind.node.ObjectNode struct = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode();
struct.set("fqn", om.valueToTree("awscdk-resources-mongodbatlas.AtlasEncryptionAtRestProps"));
struct.set("data", data);
final com.fasterxml.jackson.databind.node.ObjectNode obj = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode();
obj.set("$jsii.struct", struct);
return obj;
}
@Override
public final boolean equals(final Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
AtlasEncryptionAtRestProps.Jsii$Proxy that = (AtlasEncryptionAtRestProps.Jsii$Proxy) o;
if (!customerMasterKeyId.equals(that.customerMasterKeyId)) return false;
if (!projectId.equals(that.projectId)) return false;
if (!roleId.equals(that.roleId)) return false;
if (this.enabled != null ? !this.enabled.equals(that.enabled) : that.enabled != null) return false;
if (this.profile != null ? !this.profile.equals(that.profile) : that.profile != null) return false;
return this.region != null ? this.region.equals(that.region) : that.region == null;
}
@Override
public final int hashCode() {
int result = this.customerMasterKeyId.hashCode();
result = 31 * result + (this.projectId.hashCode());
result = 31 * result + (this.roleId.hashCode());
result = 31 * result + (this.enabled != null ? this.enabled.hashCode() : 0);
result = 31 * result + (this.profile != null ? this.profile.hashCode() : 0);
result = 31 * result + (this.region != null ? this.region.hashCode() : 0);
return result;
}
}
}