com.aliyun.ros.cdk.ram.ManagedPolicyProps Maven / Gradle / Ivy
package com.aliyun.ros.cdk.ram;
/**
* Properties for defining a ManagedPolicy
.
*
* See https://www.alibabacloud.com/help/ros/developer-reference/aliyun-ram-managedpolicy
*/
@javax.annotation.Generated(value = "jsii-pacmak/1.85.0 (build 08ee592)", date = "2024-12-13T06:45:10.817Z")
@software.amazon.jsii.Jsii(module = com.aliyun.ros.cdk.ram.$Module.class, fqn = "@alicloud/ros-cdk-ram.ManagedPolicyProps")
@software.amazon.jsii.Jsii.Proxy(ManagedPolicyProps.Jsii$Proxy.class)
public interface ManagedPolicyProps extends software.amazon.jsii.JsiiSerializable {
/**
* Property policyName: Specifies the authorization policy name, containing up to 128 characters.
*/
@org.jetbrains.annotations.NotNull java.lang.Object getPolicyName();
/**
* Property description: Specifies the authorization policy description, containing up to 1024 characters.
*/
default @org.jetbrains.annotations.Nullable java.lang.Object getDescription() {
return null;
}
/**
* Property groups: The names of groups to attach to this policy.
*/
default @org.jetbrains.annotations.Nullable java.lang.Object getGroups() {
return null;
}
/**
* Property ignoreExisting: Whether to ignore existing policy False: ROS will perform a uniqueness check.If a policy with the same name exists, an error will be reported when creating it. True: ROS will not check the uniqueness.If there is a policy with the same name, the policy creation process will be ignored. If the policy is not created by ROS, it will be ignored during update and delete stage.
*/
default @org.jetbrains.annotations.Nullable java.lang.Object getIgnoreExisting() {
return null;
}
/**
* Property policyDocument: A policy document that describes what actions are allowed on which resources.
*/
default @org.jetbrains.annotations.Nullable java.lang.Object getPolicyDocument() {
return null;
}
/**
* Property policyDocumentUnchecked: A policy document that describes what actions are allowed on which resources.
*
* If it is specified, PolicyDocument will be ignored.
*/
default @org.jetbrains.annotations.Nullable java.lang.Object getPolicyDocumentUnchecked() {
return null;
}
/**
* Property roles: The names of roles to attach to this policy.
*/
default @org.jetbrains.annotations.Nullable java.lang.Object getRoles() {
return null;
}
/**
* Property users: The names of users to attach to this policy.
*/
default @org.jetbrains.annotations.Nullable java.lang.Object getUsers() {
return null;
}
/**
* @return a {@link Builder} of {@link ManagedPolicyProps}
*/
static Builder builder() {
return new Builder();
}
/**
* A builder for {@link ManagedPolicyProps}
*/
public static final class Builder implements software.amazon.jsii.Builder {
java.lang.Object policyName;
java.lang.Object description;
java.lang.Object groups;
java.lang.Object ignoreExisting;
java.lang.Object policyDocument;
java.lang.Object policyDocumentUnchecked;
java.lang.Object roles;
java.lang.Object users;
/**
* Sets the value of {@link ManagedPolicyProps#getPolicyName}
* @param policyName Property policyName: Specifies the authorization policy name, containing up to 128 characters. This parameter is required.
* @return {@code this}
*/
public Builder policyName(java.lang.String policyName) {
this.policyName = policyName;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getPolicyName}
* @param policyName Property policyName: Specifies the authorization policy name, containing up to 128 characters. This parameter is required.
* @return {@code this}
*/
public Builder policyName(com.aliyun.ros.cdk.core.IResolvable policyName) {
this.policyName = policyName;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getDescription}
* @param description Property description: Specifies the authorization policy description, containing up to 1024 characters.
* @return {@code this}
*/
public Builder description(java.lang.String description) {
this.description = description;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getDescription}
* @param description Property description: Specifies the authorization policy description, containing up to 1024 characters.
* @return {@code this}
*/
public Builder description(com.aliyun.ros.cdk.core.IResolvable description) {
this.description = description;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getGroups}
* @param groups Property groups: The names of groups to attach to this policy.
* @return {@code this}
*/
public Builder groups(java.util.List extends java.lang.Object> groups) {
this.groups = groups;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getGroups}
* @param groups Property groups: The names of groups to attach to this policy.
* @return {@code this}
*/
public Builder groups(com.aliyun.ros.cdk.core.IResolvable groups) {
this.groups = groups;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getIgnoreExisting}
* @param ignoreExisting Property ignoreExisting: Whether to ignore existing policy False: ROS will perform a uniqueness check.If a policy with the same name exists, an error will be reported when creating it. True: ROS will not check the uniqueness.If there is a policy with the same name, the policy creation process will be ignored. If the policy is not created by ROS, it will be ignored during update and delete stage.
* @return {@code this}
*/
public Builder ignoreExisting(java.lang.Boolean ignoreExisting) {
this.ignoreExisting = ignoreExisting;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getIgnoreExisting}
* @param ignoreExisting Property ignoreExisting: Whether to ignore existing policy False: ROS will perform a uniqueness check.If a policy with the same name exists, an error will be reported when creating it. True: ROS will not check the uniqueness.If there is a policy with the same name, the policy creation process will be ignored. If the policy is not created by ROS, it will be ignored during update and delete stage.
* @return {@code this}
*/
public Builder ignoreExisting(com.aliyun.ros.cdk.core.IResolvable ignoreExisting) {
this.ignoreExisting = ignoreExisting;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getPolicyDocument}
* @param policyDocument Property policyDocument: A policy document that describes what actions are allowed on which resources.
* @return {@code this}
*/
public Builder policyDocument(com.aliyun.ros.cdk.core.IResolvable policyDocument) {
this.policyDocument = policyDocument;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getPolicyDocument}
* @param policyDocument Property policyDocument: A policy document that describes what actions are allowed on which resources.
* @return {@code this}
*/
public Builder policyDocument(com.aliyun.ros.cdk.ram.RosManagedPolicy.PolicyDocumentProperty policyDocument) {
this.policyDocument = policyDocument;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getPolicyDocumentUnchecked}
* @param policyDocumentUnchecked Property policyDocumentUnchecked: A policy document that describes what actions are allowed on which resources.
* If it is specified, PolicyDocument will be ignored.
* @return {@code this}
*/
public Builder policyDocumentUnchecked(com.aliyun.ros.cdk.core.IResolvable policyDocumentUnchecked) {
this.policyDocumentUnchecked = policyDocumentUnchecked;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getPolicyDocumentUnchecked}
* @param policyDocumentUnchecked Property policyDocumentUnchecked: A policy document that describes what actions are allowed on which resources.
* If it is specified, PolicyDocument will be ignored.
* @return {@code this}
*/
public Builder policyDocumentUnchecked(java.util.Map policyDocumentUnchecked) {
this.policyDocumentUnchecked = policyDocumentUnchecked;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getRoles}
* @param roles Property roles: The names of roles to attach to this policy.
* @return {@code this}
*/
public Builder roles(java.util.List extends java.lang.Object> roles) {
this.roles = roles;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getRoles}
* @param roles Property roles: The names of roles to attach to this policy.
* @return {@code this}
*/
public Builder roles(com.aliyun.ros.cdk.core.IResolvable roles) {
this.roles = roles;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getUsers}
* @param users Property users: The names of users to attach to this policy.
* @return {@code this}
*/
public Builder users(java.util.List extends java.lang.Object> users) {
this.users = users;
return this;
}
/**
* Sets the value of {@link ManagedPolicyProps#getUsers}
* @param users Property users: The names of users to attach to this policy.
* @return {@code this}
*/
public Builder users(com.aliyun.ros.cdk.core.IResolvable users) {
this.users = users;
return this;
}
/**
* Builds the configured instance.
* @return a new instance of {@link ManagedPolicyProps}
* @throws NullPointerException if any required attribute was not provided
*/
@Override
public ManagedPolicyProps build() {
return new Jsii$Proxy(this);
}
}
/**
* An implementation for {@link ManagedPolicyProps}
*/
@software.amazon.jsii.Internal
final class Jsii$Proxy extends software.amazon.jsii.JsiiObject implements ManagedPolicyProps {
private final java.lang.Object policyName;
private final java.lang.Object description;
private final java.lang.Object groups;
private final java.lang.Object ignoreExisting;
private final java.lang.Object policyDocument;
private final java.lang.Object policyDocumentUnchecked;
private final java.lang.Object roles;
private final java.lang.Object users;
/**
* 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.policyName = software.amazon.jsii.Kernel.get(this, "policyName", software.amazon.jsii.NativeType.forClass(java.lang.Object.class));
this.description = software.amazon.jsii.Kernel.get(this, "description", software.amazon.jsii.NativeType.forClass(java.lang.Object.class));
this.groups = software.amazon.jsii.Kernel.get(this, "groups", software.amazon.jsii.NativeType.forClass(java.lang.Object.class));
this.ignoreExisting = software.amazon.jsii.Kernel.get(this, "ignoreExisting", software.amazon.jsii.NativeType.forClass(java.lang.Object.class));
this.policyDocument = software.amazon.jsii.Kernel.get(this, "policyDocument", software.amazon.jsii.NativeType.forClass(java.lang.Object.class));
this.policyDocumentUnchecked = software.amazon.jsii.Kernel.get(this, "policyDocumentUnchecked", software.amazon.jsii.NativeType.forClass(java.lang.Object.class));
this.roles = software.amazon.jsii.Kernel.get(this, "roles", software.amazon.jsii.NativeType.forClass(java.lang.Object.class));
this.users = software.amazon.jsii.Kernel.get(this, "users", 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.policyName = java.util.Objects.requireNonNull(builder.policyName, "policyName is required");
this.description = builder.description;
this.groups = builder.groups;
this.ignoreExisting = builder.ignoreExisting;
this.policyDocument = builder.policyDocument;
this.policyDocumentUnchecked = builder.policyDocumentUnchecked;
this.roles = builder.roles;
this.users = builder.users;
}
@Override
public final java.lang.Object getPolicyName() {
return this.policyName;
}
@Override
public final java.lang.Object getDescription() {
return this.description;
}
@Override
public final java.lang.Object getGroups() {
return this.groups;
}
@Override
public final java.lang.Object getIgnoreExisting() {
return this.ignoreExisting;
}
@Override
public final java.lang.Object getPolicyDocument() {
return this.policyDocument;
}
@Override
public final java.lang.Object getPolicyDocumentUnchecked() {
return this.policyDocumentUnchecked;
}
@Override
public final java.lang.Object getRoles() {
return this.roles;
}
@Override
public final java.lang.Object getUsers() {
return this.users;
}
@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("policyName", om.valueToTree(this.getPolicyName()));
if (this.getDescription() != null) {
data.set("description", om.valueToTree(this.getDescription()));
}
if (this.getGroups() != null) {
data.set("groups", om.valueToTree(this.getGroups()));
}
if (this.getIgnoreExisting() != null) {
data.set("ignoreExisting", om.valueToTree(this.getIgnoreExisting()));
}
if (this.getPolicyDocument() != null) {
data.set("policyDocument", om.valueToTree(this.getPolicyDocument()));
}
if (this.getPolicyDocumentUnchecked() != null) {
data.set("policyDocumentUnchecked", om.valueToTree(this.getPolicyDocumentUnchecked()));
}
if (this.getRoles() != null) {
data.set("roles", om.valueToTree(this.getRoles()));
}
if (this.getUsers() != null) {
data.set("users", om.valueToTree(this.getUsers()));
}
final com.fasterxml.jackson.databind.node.ObjectNode struct = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode();
struct.set("fqn", om.valueToTree("@alicloud/ros-cdk-ram.ManagedPolicyProps"));
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;
ManagedPolicyProps.Jsii$Proxy that = (ManagedPolicyProps.Jsii$Proxy) o;
if (!policyName.equals(that.policyName)) return false;
if (this.description != null ? !this.description.equals(that.description) : that.description != null) return false;
if (this.groups != null ? !this.groups.equals(that.groups) : that.groups != null) return false;
if (this.ignoreExisting != null ? !this.ignoreExisting.equals(that.ignoreExisting) : that.ignoreExisting != null) return false;
if (this.policyDocument != null ? !this.policyDocument.equals(that.policyDocument) : that.policyDocument != null) return false;
if (this.policyDocumentUnchecked != null ? !this.policyDocumentUnchecked.equals(that.policyDocumentUnchecked) : that.policyDocumentUnchecked != null) return false;
if (this.roles != null ? !this.roles.equals(that.roles) : that.roles != null) return false;
return this.users != null ? this.users.equals(that.users) : that.users == null;
}
@Override
public final int hashCode() {
int result = this.policyName.hashCode();
result = 31 * result + (this.description != null ? this.description.hashCode() : 0);
result = 31 * result + (this.groups != null ? this.groups.hashCode() : 0);
result = 31 * result + (this.ignoreExisting != null ? this.ignoreExisting.hashCode() : 0);
result = 31 * result + (this.policyDocument != null ? this.policyDocument.hashCode() : 0);
result = 31 * result + (this.policyDocumentUnchecked != null ? this.policyDocumentUnchecked.hashCode() : 0);
result = 31 * result + (this.roles != null ? this.roles.hashCode() : 0);
result = 31 * result + (this.users != null ? this.users.hashCode() : 0);
return result;
}
}
}