com.aliyun.ros.cdk.ecs.SecurityGroupIngressesProps Maven / Gradle / Ivy
package com.aliyun.ros.cdk.ecs;
/**
* Properties for defining a SecurityGroupIngresses
.
*
* See https://www.alibabacloud.com/help/ros/developer-reference/aliyun-ecs-securitygroupingresses
*/
@javax.annotation.Generated(value = "jsii-pacmak/1.85.0 (build 08ee592)", date = "2024-08-22T08:56:20.391Z")
@software.amazon.jsii.Jsii(module = com.aliyun.ros.cdk.ecs.$Module.class, fqn = "@alicloud/ros-cdk-ecs.SecurityGroupIngressesProps")
@software.amazon.jsii.Jsii.Proxy(SecurityGroupIngressesProps.Jsii$Proxy.class)
public interface SecurityGroupIngressesProps extends software.amazon.jsii.JsiiSerializable {
/**
* Property permissions: A list of security group rules.
*
* A hundred at most.
*/
@org.jetbrains.annotations.NotNull java.lang.Object getPermissions();
/**
* Property securityGroupId: Id of the security group.
*/
@org.jetbrains.annotations.NotNull java.lang.Object getSecurityGroupId();
/**
* @return a {@link Builder} of {@link SecurityGroupIngressesProps}
*/
static Builder builder() {
return new Builder();
}
/**
* A builder for {@link SecurityGroupIngressesProps}
*/
public static final class Builder implements software.amazon.jsii.Builder {
java.lang.Object permissions;
java.lang.Object securityGroupId;
/**
* Sets the value of {@link SecurityGroupIngressesProps#getPermissions}
* @param permissions Property permissions: A list of security group rules. This parameter is required.
* A hundred at most.
* @return {@code this}
*/
public Builder permissions(com.aliyun.ros.cdk.core.IResolvable permissions) {
this.permissions = permissions;
return this;
}
/**
* Sets the value of {@link SecurityGroupIngressesProps#getPermissions}
* @param permissions Property permissions: A list of security group rules. This parameter is required.
* A hundred at most.
* @return {@code this}
*/
public Builder permissions(java.util.List extends java.lang.Object> permissions) {
this.permissions = permissions;
return this;
}
/**
* Sets the value of {@link SecurityGroupIngressesProps#getSecurityGroupId}
* @param securityGroupId Property securityGroupId: Id of the security group. This parameter is required.
* @return {@code this}
*/
public Builder securityGroupId(java.lang.String securityGroupId) {
this.securityGroupId = securityGroupId;
return this;
}
/**
* Sets the value of {@link SecurityGroupIngressesProps#getSecurityGroupId}
* @param securityGroupId Property securityGroupId: Id of the security group. This parameter is required.
* @return {@code this}
*/
public Builder securityGroupId(com.aliyun.ros.cdk.core.IResolvable securityGroupId) {
this.securityGroupId = securityGroupId;
return this;
}
/**
* Builds the configured instance.
* @return a new instance of {@link SecurityGroupIngressesProps}
* @throws NullPointerException if any required attribute was not provided
*/
@Override
public SecurityGroupIngressesProps build() {
return new Jsii$Proxy(this);
}
}
/**
* An implementation for {@link SecurityGroupIngressesProps}
*/
@software.amazon.jsii.Internal
final class Jsii$Proxy extends software.amazon.jsii.JsiiObject implements SecurityGroupIngressesProps {
private final java.lang.Object permissions;
private final java.lang.Object securityGroupId;
/**
* 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.permissions = software.amazon.jsii.Kernel.get(this, "permissions", software.amazon.jsii.NativeType.forClass(java.lang.Object.class));
this.securityGroupId = software.amazon.jsii.Kernel.get(this, "securityGroupId", 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.permissions = java.util.Objects.requireNonNull(builder.permissions, "permissions is required");
this.securityGroupId = java.util.Objects.requireNonNull(builder.securityGroupId, "securityGroupId is required");
}
@Override
public final java.lang.Object getPermissions() {
return this.permissions;
}
@Override
public final java.lang.Object getSecurityGroupId() {
return this.securityGroupId;
}
@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("permissions", om.valueToTree(this.getPermissions()));
data.set("securityGroupId", om.valueToTree(this.getSecurityGroupId()));
final com.fasterxml.jackson.databind.node.ObjectNode struct = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode();
struct.set("fqn", om.valueToTree("@alicloud/ros-cdk-ecs.SecurityGroupIngressesProps"));
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;
SecurityGroupIngressesProps.Jsii$Proxy that = (SecurityGroupIngressesProps.Jsii$Proxy) o;
if (!permissions.equals(that.permissions)) return false;
return this.securityGroupId.equals(that.securityGroupId);
}
@Override
public final int hashCode() {
int result = this.permissions.hashCode();
result = 31 * result + (this.securityGroupId.hashCode());
return result;
}
}
}