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

com.aliyun.ros.cdk.polardb.DBClusterEndpoint Maven / Gradle / Ivy

package com.aliyun.ros.cdk.polardb;

/**
 * This class encapsulates and extends the ROS resource type ALIYUN::POLARDB::DBClusterEndpoint, which is used to create a custom endpoint for a PolarDB cluster.
 */
@javax.annotation.Generated(value = "jsii-pacmak/1.85.0 (build 08ee592)", date = "2024-12-13T06:45:10.560Z")
@software.amazon.jsii.Jsii(module = com.aliyun.ros.cdk.polardb.$Module.class, fqn = "@alicloud/ros-cdk-polardb.DBClusterEndpoint")
public class DBClusterEndpoint extends com.aliyun.ros.cdk.core.Resource {

    protected DBClusterEndpoint(final software.amazon.jsii.JsiiObjectRef objRef) {
        super(objRef);
    }

    protected DBClusterEndpoint(final software.amazon.jsii.JsiiObject.InitializationMode initializationMode) {
        super(initializationMode);
    }

    /**
     * Param scope - scope in which this resource is defined Param id    - scoped id of the resource Param props - resource properties.
     * 

* @param scope This parameter is required. * @param id This parameter is required. * @param props This parameter is required. * @param enableResourcePropertyConstraint */ public DBClusterEndpoint(final @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.core.Construct scope, final @org.jetbrains.annotations.NotNull java.lang.String id, final @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.polardb.DBClusterEndpointProps props, final @org.jetbrains.annotations.Nullable java.lang.Boolean enableResourcePropertyConstraint) { super(software.amazon.jsii.JsiiObject.InitializationMode.JSII); software.amazon.jsii.JsiiEngine.getInstance().createNewObject(this, new Object[] { java.util.Objects.requireNonNull(scope, "scope is required"), java.util.Objects.requireNonNull(id, "id is required"), java.util.Objects.requireNonNull(props, "props is required"), enableResourcePropertyConstraint }); } /** * Param scope - scope in which this resource is defined Param id - scoped id of the resource Param props - resource properties. *

* @param scope This parameter is required. * @param id This parameter is required. * @param props This parameter is required. */ public DBClusterEndpoint(final @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.core.Construct scope, final @org.jetbrains.annotations.NotNull java.lang.String id, final @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.polardb.DBClusterEndpointProps props) { super(software.amazon.jsii.JsiiObject.InitializationMode.JSII); software.amazon.jsii.JsiiEngine.getInstance().createNewObject(this, new Object[] { java.util.Objects.requireNonNull(scope, "scope is required"), java.util.Objects.requireNonNull(id, "id is required"), java.util.Objects.requireNonNull(props, "props is required") }); } /** * Attribute Addresses: The address items of the db cluster endpoint. */ public @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.core.IResolvable getAttrAddresses() { return software.amazon.jsii.Kernel.get(this, "attrAddresses", software.amazon.jsii.NativeType.forClass(com.aliyun.ros.cdk.core.IResolvable.class)); } /** * Attribute ConnectionString: The first connection string of the db cluster endpoint. */ public @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.core.IResolvable getAttrConnectionString() { return software.amazon.jsii.Kernel.get(this, "attrConnectionString", software.amazon.jsii.NativeType.forClass(com.aliyun.ros.cdk.core.IResolvable.class)); } /** * Attribute DBEndpointId: DB cluster endpoint ID. *

* E.g. pe-xxxxxxxx. */ public @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.core.IResolvable getAttrDbEndpointId() { return software.amazon.jsii.Kernel.get(this, "attrDbEndpointId", software.amazon.jsii.NativeType.forClass(com.aliyun.ros.cdk.core.IResolvable.class)); } protected @org.jetbrains.annotations.NotNull java.lang.Boolean getEnableResourcePropertyConstraint() { return software.amazon.jsii.Kernel.get(this, "enableResourcePropertyConstraint", software.amazon.jsii.NativeType.forClass(java.lang.Boolean.class)); } protected void setEnableResourcePropertyConstraint(final @org.jetbrains.annotations.NotNull java.lang.Boolean value) { software.amazon.jsii.Kernel.set(this, "enableResourcePropertyConstraint", java.util.Objects.requireNonNull(value, "enableResourcePropertyConstraint is required")); } protected @org.jetbrains.annotations.NotNull java.lang.String getId() { return software.amazon.jsii.Kernel.get(this, "id", software.amazon.jsii.NativeType.forClass(java.lang.String.class)); } protected void setId(final @org.jetbrains.annotations.NotNull java.lang.String value) { software.amazon.jsii.Kernel.set(this, "id", java.util.Objects.requireNonNull(value, "id is required")); } protected @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.polardb.DBClusterEndpointProps getProps() { return software.amazon.jsii.Kernel.get(this, "props", software.amazon.jsii.NativeType.forClass(com.aliyun.ros.cdk.polardb.DBClusterEndpointProps.class)); } protected void setProps(final @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.polardb.DBClusterEndpointProps value) { software.amazon.jsii.Kernel.set(this, "props", java.util.Objects.requireNonNull(value, "props is required")); } protected @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.core.Construct getScope() { return software.amazon.jsii.Kernel.get(this, "scope", software.amazon.jsii.NativeType.forClass(com.aliyun.ros.cdk.core.Construct.class)); } protected void setScope(final @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.core.Construct value) { software.amazon.jsii.Kernel.set(this, "scope", java.util.Objects.requireNonNull(value, "scope is required")); } /** * A fluent builder for {@link com.aliyun.ros.cdk.polardb.DBClusterEndpoint}. */ public static final class Builder implements software.amazon.jsii.Builder { /** * @return a new instance of {@link Builder}. * @param scope This parameter is required. * @param id This parameter is required. * @param enableResourcePropertyConstraint */ public static Builder create(final com.aliyun.ros.cdk.core.Construct scope, final java.lang.String id, final java.lang.Boolean enableResourcePropertyConstraint) { return new Builder(scope, id, enableResourcePropertyConstraint); } /** * @return a new instance of {@link Builder}. * @param scope This parameter is required. * @param id This parameter is required. */ public static Builder create(final com.aliyun.ros.cdk.core.Construct scope, final java.lang.String id) { return new Builder(scope, id, null); } private final com.aliyun.ros.cdk.core.Construct scope; private final java.lang.String id; private final java.lang.Boolean enableResourcePropertyConstraint; private final com.aliyun.ros.cdk.polardb.DBClusterEndpointProps.Builder props; private Builder(final com.aliyun.ros.cdk.core.Construct scope, final java.lang.String id, final java.lang.Boolean enableResourcePropertyConstraint) { this.scope = scope; this.id = id; this.enableResourcePropertyConstraint = enableResourcePropertyConstraint; this.props = new com.aliyun.ros.cdk.polardb.DBClusterEndpointProps.Builder(); } /** * Property dbClusterId: The ID of the ApsaraDB for POLARDB cluster for which a custom connection point is to be created. *

* @return {@code this} * @param dbClusterId Property dbClusterId: The ID of the ApsaraDB for POLARDB cluster for which a custom connection point is to be created. This parameter is required. */ public Builder dbClusterId(final java.lang.String dbClusterId) { this.props.dbClusterId(dbClusterId); return this; } /** * Property dbClusterId: The ID of the ApsaraDB for POLARDB cluster for which a custom connection point is to be created. *

* @return {@code this} * @param dbClusterId Property dbClusterId: The ID of the ApsaraDB for POLARDB cluster for which a custom connection point is to be created. This parameter is required. */ public Builder dbClusterId(final com.aliyun.ros.cdk.core.IResolvable dbClusterId) { this.props.dbClusterId(dbClusterId); return this; } /** * Property autoAddNewNodes: Specifies whether a newly added node is automatically added to this connection point. *

* Valid values: Enable, Disable. * Default value: Disable. *

* @return {@code this} * @param autoAddNewNodes Property autoAddNewNodes: Specifies whether a newly added node is automatically added to this connection point. This parameter is required. */ public Builder autoAddNewNodes(final java.lang.String autoAddNewNodes) { this.props.autoAddNewNodes(autoAddNewNodes); return this; } /** * Property autoAddNewNodes: Specifies whether a newly added node is automatically added to this connection point. *

* Valid values: Enable, Disable. * Default value: Disable. *

* @return {@code this} * @param autoAddNewNodes Property autoAddNewNodes: Specifies whether a newly added node is automatically added to this connection point. This parameter is required. */ public Builder autoAddNewNodes(final com.aliyun.ros.cdk.core.IResolvable autoAddNewNodes) { this.props.autoAddNewNodes(autoAddNewNodes); return this; } /** * Property endpointConfig:. *

* @return {@code this} * @param endpointConfig Property endpointConfig:. This parameter is required. */ public Builder endpointConfig(final com.aliyun.ros.cdk.core.IResolvable endpointConfig) { this.props.endpointConfig(endpointConfig); return this; } /** * Property endpointConfig:. *

* @return {@code this} * @param endpointConfig Property endpointConfig:. This parameter is required. */ public Builder endpointConfig(final com.aliyun.ros.cdk.polardb.RosDBClusterEndpoint.EndpointConfigProperty endpointConfig) { this.props.endpointConfig(endpointConfig); return this; } /** * Property endpointType: The type of the cluster connection point. *

* Set this parameter to Custom. *

* @return {@code this} * @param endpointType Property endpointType: The type of the cluster connection point. This parameter is required. */ public Builder endpointType(final java.lang.String endpointType) { this.props.endpointType(endpointType); return this; } /** * Property endpointType: The type of the cluster connection point. *

* Set this parameter to Custom. *

* @return {@code this} * @param endpointType Property endpointType: The type of the cluster connection point. This parameter is required. */ public Builder endpointType(final com.aliyun.ros.cdk.core.IResolvable endpointType) { this.props.endpointType(endpointType); return this; } /** * Property nodes: The nodes to be added to this connection point to process read requests from this connection point. *

* Add at least two nodes. * If you do not specify this parameter, all nodes of the cluster are added to this connection point by default. *

* @return {@code this} * @param nodes Property nodes: The nodes to be added to this connection point to process read requests from this connection point. This parameter is required. */ public Builder nodes(final java.util.List nodes) { this.props.nodes(nodes); return this; } /** * Property nodes: The nodes to be added to this connection point to process read requests from this connection point. *

* Add at least two nodes. * If you do not specify this parameter, all nodes of the cluster are added to this connection point by default. *

* @return {@code this} * @param nodes Property nodes: The nodes to be added to this connection point to process read requests from this connection point. This parameter is required. */ public Builder nodes(final com.aliyun.ros.cdk.core.IResolvable nodes) { this.props.nodes(nodes); return this; } /** * Property readWriteMode: The read/write mode of the cluster connection point. *

* Valid values: * ReadWrite: receives and forwards read and write requests (automatic read-write splitting). * ReadOnly: receives and forwards only read requests. * Default value: ReadOnly. *

* @return {@code this} * @param readWriteMode Property readWriteMode: The read/write mode of the cluster connection point. This parameter is required. */ public Builder readWriteMode(final java.lang.String readWriteMode) { this.props.readWriteMode(readWriteMode); return this; } /** * Property readWriteMode: The read/write mode of the cluster connection point. *

* Valid values: * ReadWrite: receives and forwards read and write requests (automatic read-write splitting). * ReadOnly: receives and forwards only read requests. * Default value: ReadOnly. *

* @return {@code this} * @param readWriteMode Property readWriteMode: The read/write mode of the cluster connection point. This parameter is required. */ public Builder readWriteMode(final com.aliyun.ros.cdk.core.IResolvable readWriteMode) { this.props.readWriteMode(readWriteMode); return this; } /** * @return a newly built instance of {@link com.aliyun.ros.cdk.polardb.DBClusterEndpoint}. */ @Override public com.aliyun.ros.cdk.polardb.DBClusterEndpoint build() { return new com.aliyun.ros.cdk.polardb.DBClusterEndpoint( this.scope, this.id, this.props.build(), this.enableResourcePropertyConstraint ); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy