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

software.amazon.awscdk.services.elasticbeanstalk.CfnApplicationProps Maven / Gradle / Ivy

There is a newer version: 1.204.0
Show newest version
package software.amazon.awscdk.services.elasticbeanstalk;

/**
 * Properties for defining a `CfnApplication`.
 * 

* Example: *

*

 * // The code below shows an example of how to instantiate this type.
 * // The values are placeholders you should change.
 * import software.amazon.awscdk.services.elasticbeanstalk.*;
 * CfnApplicationProps cfnApplicationProps = CfnApplicationProps.builder()
 *         .applicationName("applicationName")
 *         .description("description")
 *         .resourceLifecycleConfig(ApplicationResourceLifecycleConfigProperty.builder()
 *                 .serviceRole("serviceRole")
 *                 .versionLifecycleConfig(ApplicationVersionLifecycleConfigProperty.builder()
 *                         .maxAgeRule(MaxAgeRuleProperty.builder()
 *                                 .deleteSourceFromS3(false)
 *                                 .enabled(false)
 *                                 .maxAgeInDays(123)
 *                                 .build())
 *                         .maxCountRule(MaxCountRuleProperty.builder()
 *                                 .deleteSourceFromS3(false)
 *                                 .enabled(false)
 *                                 .maxCount(123)
 *                                 .build())
 *                         .build())
 *                 .build())
 *         .build();
 * 
*/ @javax.annotation.Generated(value = "jsii-pacmak/1.74.0 (build 6d08790)", date = "2023-05-19T23:08:45.287Z") @software.amazon.jsii.Jsii(module = software.amazon.awscdk.services.elasticbeanstalk.$Module.class, fqn = "@aws-cdk/aws-elasticbeanstalk.CfnApplicationProps") @software.amazon.jsii.Jsii.Proxy(CfnApplicationProps.Jsii$Proxy.class) @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) public interface CfnApplicationProps extends software.amazon.jsii.JsiiSerializable { /** * A name for the Elastic Beanstalk application. *

* If you don't specify a name, AWS CloudFormation generates a unique physical ID and uses that ID for the application name. For more information, see Name Type . *

*

*

* If you specify a name, you cannot perform updates that require replacement of this resource. You can perform updates that require no or some interruption. If you must replace the resource, specify a new name. *

*

*/ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) default @org.jetbrains.annotations.Nullable java.lang.String getApplicationName() { return null; } /** * Your description of the application. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) default @org.jetbrains.annotations.Nullable java.lang.String getDescription() { return null; } /** * Specifies an application resource lifecycle configuration to prevent your application from accumulating too many versions. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) default @org.jetbrains.annotations.Nullable java.lang.Object getResourceLifecycleConfig() { return null; } /** * @return a {@link Builder} of {@link CfnApplicationProps} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) static Builder builder() { return new Builder(); } /** * A builder for {@link CfnApplicationProps} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) public static final class Builder implements software.amazon.jsii.Builder { java.lang.String applicationName; java.lang.String description; java.lang.Object resourceLifecycleConfig; /** * Sets the value of {@link CfnApplicationProps#getApplicationName} * @param applicationName A name for the Elastic Beanstalk application. * If you don't specify a name, AWS CloudFormation generates a unique physical ID and uses that ID for the application name. For more information, see Name Type . *

*

*

* If you specify a name, you cannot perform updates that require replacement of this resource. You can perform updates that require no or some interruption. If you must replace the resource, specify a new name. *

*

* @return {@code this} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) public Builder applicationName(java.lang.String applicationName) { this.applicationName = applicationName; return this; } /** * Sets the value of {@link CfnApplicationProps#getDescription} * @param description Your description of the application. * @return {@code this} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) public Builder description(java.lang.String description) { this.description = description; return this; } /** * Sets the value of {@link CfnApplicationProps#getResourceLifecycleConfig} * @param resourceLifecycleConfig Specifies an application resource lifecycle configuration to prevent your application from accumulating too many versions. * @return {@code this} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) public Builder resourceLifecycleConfig(software.amazon.awscdk.services.elasticbeanstalk.CfnApplication.ApplicationResourceLifecycleConfigProperty resourceLifecycleConfig) { this.resourceLifecycleConfig = resourceLifecycleConfig; return this; } /** * Sets the value of {@link CfnApplicationProps#getResourceLifecycleConfig} * @param resourceLifecycleConfig Specifies an application resource lifecycle configuration to prevent your application from accumulating too many versions. * @return {@code this} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) public Builder resourceLifecycleConfig(software.amazon.awscdk.core.IResolvable resourceLifecycleConfig) { this.resourceLifecycleConfig = resourceLifecycleConfig; return this; } /** * Builds the configured instance. * @return a new instance of {@link CfnApplicationProps} * @throws NullPointerException if any required attribute was not provided */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) @Override public CfnApplicationProps build() { return new Jsii$Proxy(this); } } /** * An implementation for {@link CfnApplicationProps} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) @software.amazon.jsii.Internal final class Jsii$Proxy extends software.amazon.jsii.JsiiObject implements CfnApplicationProps { private final java.lang.String applicationName; private final java.lang.String description; private final java.lang.Object resourceLifecycleConfig; /** * 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.applicationName = software.amazon.jsii.Kernel.get(this, "applicationName", software.amazon.jsii.NativeType.forClass(java.lang.String.class)); this.description = software.amazon.jsii.Kernel.get(this, "description", software.amazon.jsii.NativeType.forClass(java.lang.String.class)); this.resourceLifecycleConfig = software.amazon.jsii.Kernel.get(this, "resourceLifecycleConfig", software.amazon.jsii.NativeType.forClass(java.lang.Object.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.applicationName = builder.applicationName; this.description = builder.description; this.resourceLifecycleConfig = builder.resourceLifecycleConfig; } @Override public final java.lang.String getApplicationName() { return this.applicationName; } @Override public final java.lang.String getDescription() { return this.description; } @Override public final java.lang.Object getResourceLifecycleConfig() { return this.resourceLifecycleConfig; } @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(); if (this.getApplicationName() != null) { data.set("applicationName", om.valueToTree(this.getApplicationName())); } if (this.getDescription() != null) { data.set("description", om.valueToTree(this.getDescription())); } if (this.getResourceLifecycleConfig() != null) { data.set("resourceLifecycleConfig", om.valueToTree(this.getResourceLifecycleConfig())); } final com.fasterxml.jackson.databind.node.ObjectNode struct = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode(); struct.set("fqn", om.valueToTree("@aws-cdk/aws-elasticbeanstalk.CfnApplicationProps")); 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; CfnApplicationProps.Jsii$Proxy that = (CfnApplicationProps.Jsii$Proxy) o; if (this.applicationName != null ? !this.applicationName.equals(that.applicationName) : that.applicationName != null) return false; if (this.description != null ? !this.description.equals(that.description) : that.description != null) return false; return this.resourceLifecycleConfig != null ? this.resourceLifecycleConfig.equals(that.resourceLifecycleConfig) : that.resourceLifecycleConfig == null; } @Override public final int hashCode() { int result = this.applicationName != null ? this.applicationName.hashCode() : 0; result = 31 * result + (this.description != null ? this.description.hashCode() : 0); result = 31 * result + (this.resourceLifecycleConfig != null ? this.resourceLifecycleConfig.hashCode() : 0); return result; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy