com.aliyun.ros.cdk.cloudfw.VpcFirewallControlPolicy Maven / Gradle / Ivy
package com.aliyun.ros.cdk.cloudfw;
/**
* This class encapsulates and extends the ROS resource type ALIYUN::CLOUDFW::VpcFirewallControlPolicy
, which is used to add an access control policy to a specified policy group for a Virtual Private Cloud (VPC) firewall.
*/
@javax.annotation.Generated(value = "jsii-pacmak/1.85.0 (build 08ee592)", date = "2024-03-01T09:16:50.546Z")
@software.amazon.jsii.Jsii(module = com.aliyun.ros.cdk.cloudfw.$Module.class, fqn = "@alicloud/ros-cdk-cloudfw.VpcFirewallControlPolicy")
public class VpcFirewallControlPolicy extends com.aliyun.ros.cdk.core.Resource {
protected VpcFirewallControlPolicy(final software.amazon.jsii.JsiiObjectRef objRef) {
super(objRef);
}
protected VpcFirewallControlPolicy(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 VpcFirewallControlPolicy(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.cloudfw.VpcFirewallControlPolicyProps 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 VpcFirewallControlPolicy(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.cloudfw.VpcFirewallControlPolicyProps 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 AclUuid: The unique ID of the access control policy.
*/
public @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.core.IResolvable getAttrAclUuid() {
return software.amazon.jsii.Kernel.get(this, "attrAclUuid", 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.cloudfw.VpcFirewallControlPolicyProps getProps() {
return software.amazon.jsii.Kernel.get(this, "props", software.amazon.jsii.NativeType.forClass(com.aliyun.ros.cdk.cloudfw.VpcFirewallControlPolicyProps.class));
}
protected void setProps(final @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.cloudfw.VpcFirewallControlPolicyProps 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.cloudfw.VpcFirewallControlPolicy}.
*/
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.cloudfw.VpcFirewallControlPolicyProps.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.cloudfw.VpcFirewallControlPolicyProps.Builder();
}
/**
* Property aclAction: The action that Cloud Firewall performs on the traffic.
*
* Valid values:
* accept: allows the traffic.
* drop: denies the traffic.
* log: monitors the traffic.
*
* @return {@code this}
* @param aclAction Property aclAction: The action that Cloud Firewall performs on the traffic. This parameter is required.
*/
public Builder aclAction(final java.lang.String aclAction) {
this.props.aclAction(aclAction);
return this;
}
/**
* Property aclAction: The action that Cloud Firewall performs on the traffic.
*
* Valid values:
* accept: allows the traffic.
* drop: denies the traffic.
* log: monitors the traffic.
*
* @return {@code this}
* @param aclAction Property aclAction: The action that Cloud Firewall performs on the traffic. This parameter is required.
*/
public Builder aclAction(final com.aliyun.ros.cdk.core.IResolvable aclAction) {
this.props.aclAction(aclAction);
return this;
}
/**
* Property applicationName: The application type that the access control policy supports.
*
* Valid values:
* ANY (indicates that all application types are supported)
* FTP
* HTTP
* HTTPS
* MySQL
* SMTP
* SMTPS
* RDP
* VNC
* SSH
* Redis
* MQTT
* MongoDB
* Memcache
* SSL
*
* @return {@code this}
* @param applicationName Property applicationName: The application type that the access control policy supports. This parameter is required.
*/
public Builder applicationName(final java.lang.String applicationName) {
this.props.applicationName(applicationName);
return this;
}
/**
* Property applicationName: The application type that the access control policy supports.
*
* Valid values:
* ANY (indicates that all application types are supported)
* FTP
* HTTP
* HTTPS
* MySQL
* SMTP
* SMTPS
* RDP
* VNC
* SSH
* Redis
* MQTT
* MongoDB
* Memcache
* SSL
*
* @return {@code this}
* @param applicationName Property applicationName: The application type that the access control policy supports. This parameter is required.
*/
public Builder applicationName(final com.aliyun.ros.cdk.core.IResolvable applicationName) {
this.props.applicationName(applicationName);
return this;
}
/**
* Property description: The description of the access control policy.
*
* @return {@code this}
* @param description Property description: The description of the access control policy. This parameter is required.
*/
public Builder description(final java.lang.String description) {
this.props.description(description);
return this;
}
/**
* Property description: The description of the access control policy.
*
* @return {@code this}
* @param description Property description: The description of the access control policy. This parameter is required.
*/
public Builder description(final com.aliyun.ros.cdk.core.IResolvable description) {
this.props.description(description);
return this;
}
/**
* Property destination: The destination address in the access control policy.
*
* Set this parameter in the following way:
* If the DestinationType parameter is set to net, set the value to a Classless Inter-Domain Routing (CIDR) block.
* Example: 10.2.3.0/24.
* If the DestinationType parameter is set to group, set the value to the name of an address book.
* Example: db_group.
* If the DestinationType parameter is set to domain, set the value to a domain name.
* Example: *.aliyuncs.com.
*
* @return {@code this}
* @param destination Property destination: The destination address in the access control policy. This parameter is required.
*/
public Builder destination(final java.lang.String destination) {
this.props.destination(destination);
return this;
}
/**
* Property destination: The destination address in the access control policy.
*
* Set this parameter in the following way:
* If the DestinationType parameter is set to net, set the value to a Classless Inter-Domain Routing (CIDR) block.
* Example: 10.2.3.0/24.
* If the DestinationType parameter is set to group, set the value to the name of an address book.
* Example: db_group.
* If the DestinationType parameter is set to domain, set the value to a domain name.
* Example: *.aliyuncs.com.
*
* @return {@code this}
* @param destination Property destination: The destination address in the access control policy. This parameter is required.
*/
public Builder destination(final com.aliyun.ros.cdk.core.IResolvable destination) {
this.props.destination(destination);
return this;
}
/**
* Property destinationType: The type of the destination address in the access control policy.
*
* Valid values:
* net: CIDR block
* group: address book
* domain: domain name
*
* @return {@code this}
* @param destinationType Property destinationType: The type of the destination address in the access control policy. This parameter is required.
*/
public Builder destinationType(final java.lang.String destinationType) {
this.props.destinationType(destinationType);
return this;
}
/**
* Property destinationType: The type of the destination address in the access control policy.
*
* Valid values:
* net: CIDR block
* group: address book
* domain: domain name
*
* @return {@code this}
* @param destinationType Property destinationType: The type of the destination address in the access control policy. This parameter is required.
*/
public Builder destinationType(final com.aliyun.ros.cdk.core.IResolvable destinationType) {
this.props.destinationType(destinationType);
return this;
}
/**
* Property newOrder: The priority of the access control policy.
*
* The priority value starts from 1. A smaller priority value indicates a higher priority.
* Note The value of -1 indicates the lowest priority.
*
* @return {@code this}
* @param newOrder Property newOrder: The priority of the access control policy. This parameter is required.
*/
public Builder newOrder(final java.lang.String newOrder) {
this.props.newOrder(newOrder);
return this;
}
/**
* Property newOrder: The priority of the access control policy.
*
* The priority value starts from 1. A smaller priority value indicates a higher priority.
* Note The value of -1 indicates the lowest priority.
*
* @return {@code this}
* @param newOrder Property newOrder: The priority of the access control policy. This parameter is required.
*/
public Builder newOrder(final com.aliyun.ros.cdk.core.IResolvable newOrder) {
this.props.newOrder(newOrder);
return this;
}
/**
* Property proto: The type of the security protocol in the access control policy.
*
* @return {@code this}
* @param proto Property proto: The type of the security protocol in the access control policy. This parameter is required.
*/
public Builder proto(final java.lang.String proto) {
this.props.proto(proto);
return this;
}
/**
* Property proto: The type of the security protocol in the access control policy.
*
* @return {@code this}
* @param proto Property proto: The type of the security protocol in the access control policy. This parameter is required.
*/
public Builder proto(final com.aliyun.ros.cdk.core.IResolvable proto) {
this.props.proto(proto);
return this;
}
/**
* Property source: The source address in the access control policy.
*
* If the SourceType parameter is set to net, set the value to a CIDR block. Example: 10.2.3.0/24.
* If the SourceType parameter is set to group, set the value to the name of an address book. Example: db_group.
*
* @return {@code this}
* @param source Property source: The source address in the access control policy. This parameter is required.
*/
public Builder source(final java.lang.String source) {
this.props.source(source);
return this;
}
/**
* Property source: The source address in the access control policy.
*
* If the SourceType parameter is set to net, set the value to a CIDR block. Example: 10.2.3.0/24.
* If the SourceType parameter is set to group, set the value to the name of an address book. Example: db_group.
*
* @return {@code this}
* @param source Property source: The source address in the access control policy. This parameter is required.
*/
public Builder source(final com.aliyun.ros.cdk.core.IResolvable source) {
this.props.source(source);
return this;
}
/**
* Property sourceType: The type of the source address in the access control policy.
*
* Valid values:
* net: CIDR block
* group: address book
*
* @return {@code this}
* @param sourceType Property sourceType: The type of the source address in the access control policy. This parameter is required.
*/
public Builder sourceType(final java.lang.String sourceType) {
this.props.sourceType(sourceType);
return this;
}
/**
* Property sourceType: The type of the source address in the access control policy.
*
* Valid values:
* net: CIDR block
* group: address book
*
* @return {@code this}
* @param sourceType Property sourceType: The type of the source address in the access control policy. This parameter is required.
*/
public Builder sourceType(final com.aliyun.ros.cdk.core.IResolvable sourceType) {
this.props.sourceType(sourceType);
return this;
}
/**
* Property vpcFirewallId: The ID of the policy group to which you want to add the access control policy.
*
* If the VPC firewall is used to protect CEN, set the value to the ID of the CEN instance
* that the VPC firewall protects. Example: cen-ervw5jbw1234*****.
* If the VPC firewall is used to protect Express Connect, set the value to the ID of
* the VPC firewall instance. Example: vfw-a42bbb748c91234*****.
* Note You can call the DescribeVpcFirewallAclGroupList operation to query the ID of the policy group.
*
* @return {@code this}
* @param vpcFirewallId Property vpcFirewallId: The ID of the policy group to which you want to add the access control policy. This parameter is required.
*/
public Builder vpcFirewallId(final java.lang.String vpcFirewallId) {
this.props.vpcFirewallId(vpcFirewallId);
return this;
}
/**
* Property vpcFirewallId: The ID of the policy group to which you want to add the access control policy.
*
* If the VPC firewall is used to protect CEN, set the value to the ID of the CEN instance
* that the VPC firewall protects. Example: cen-ervw5jbw1234*****.
* If the VPC firewall is used to protect Express Connect, set the value to the ID of
* the VPC firewall instance. Example: vfw-a42bbb748c91234*****.
* Note You can call the DescribeVpcFirewallAclGroupList operation to query the ID of the policy group.
*
* @return {@code this}
* @param vpcFirewallId Property vpcFirewallId: The ID of the policy group to which you want to add the access control policy. This parameter is required.
*/
public Builder vpcFirewallId(final com.aliyun.ros.cdk.core.IResolvable vpcFirewallId) {
this.props.vpcFirewallId(vpcFirewallId);
return this;
}
/**
* Property destPort: The destination port in the access control policy.
*
* Note This parameter must be specified if the DestPortType parameter is set to port.
*
* @return {@code this}
* @param destPort Property destPort: The destination port in the access control policy. This parameter is required.
*/
public Builder destPort(final java.lang.String destPort) {
this.props.destPort(destPort);
return this;
}
/**
* Property destPort: The destination port in the access control policy.
*
* Note This parameter must be specified if the DestPortType parameter is set to port.
*
* @return {@code this}
* @param destPort Property destPort: The destination port in the access control policy. This parameter is required.
*/
public Builder destPort(final com.aliyun.ros.cdk.core.IResolvable destPort) {
this.props.destPort(destPort);
return this;
}
/**
* Property destPortGroup: The address book of destination ports in the access control policy.
*
* Note This parameter must be specified if the DestPortType parameter is set to group.
*
* @return {@code this}
* @param destPortGroup Property destPortGroup: The address book of destination ports in the access control policy. This parameter is required.
*/
public Builder destPortGroup(final java.lang.String destPortGroup) {
this.props.destPortGroup(destPortGroup);
return this;
}
/**
* Property destPortGroup: The address book of destination ports in the access control policy.
*
* Note This parameter must be specified if the DestPortType parameter is set to group.
*
* @return {@code this}
* @param destPortGroup Property destPortGroup: The address book of destination ports in the access control policy. This parameter is required.
*/
public Builder destPortGroup(final com.aliyun.ros.cdk.core.IResolvable destPortGroup) {
this.props.destPortGroup(destPortGroup);
return this;
}
/**
* Property destPortType: The type of the destination port in the access control policy.
*
* Valid values:
* port: port
* group: address book
*
* @return {@code this}
* @param destPortType Property destPortType: The type of the destination port in the access control policy. This parameter is required.
*/
public Builder destPortType(final java.lang.String destPortType) {
this.props.destPortType(destPortType);
return this;
}
/**
* Property destPortType: The type of the destination port in the access control policy.
*
* Valid values:
* port: port
* group: address book
*
* @return {@code this}
* @param destPortType Property destPortType: The type of the destination port in the access control policy. This parameter is required.
*/
public Builder destPortType(final com.aliyun.ros.cdk.core.IResolvable destPortType) {
this.props.destPortType(destPortType);
return this;
}
/**
* Property lang: The natural language of the request and response.
*
* Valid values:
* zh: Chinese
* en: English
*
* @return {@code this}
* @param lang Property lang: The natural language of the request and response. This parameter is required.
*/
public Builder lang(final java.lang.String lang) {
this.props.lang(lang);
return this;
}
/**
* Property lang: The natural language of the request and response.
*
* Valid values:
* zh: Chinese
* en: English
*
* @return {@code this}
* @param lang Property lang: The natural language of the request and response. This parameter is required.
*/
public Builder lang(final com.aliyun.ros.cdk.core.IResolvable lang) {
this.props.lang(lang);
return this;
}
/**
* Property regionId: Region ID.
*
* Default to cn-hangzhou.
*
* @return {@code this}
* @param regionId Property regionId: Region ID. This parameter is required.
*/
public Builder regionId(final java.lang.String regionId) {
this.props.regionId(regionId);
return this;
}
/**
* Property regionId: Region ID.
*
* Default to cn-hangzhou.
*
* @return {@code this}
* @param regionId Property regionId: Region ID. This parameter is required.
*/
public Builder regionId(final com.aliyun.ros.cdk.core.IResolvable regionId) {
this.props.regionId(regionId);
return this;
}
/**
* @return a newly built instance of {@link com.aliyun.ros.cdk.cloudfw.VpcFirewallControlPolicy}.
*/
@Override
public com.aliyun.ros.cdk.cloudfw.VpcFirewallControlPolicy build() {
return new com.aliyun.ros.cdk.cloudfw.VpcFirewallControlPolicy(
this.scope,
this.id,
this.props.build(),
this.enableResourcePropertyConstraint
);
}
}
}