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

com.aliyun.ros.cdk.cloudsso.PermissionPolicyToAccessConfigurationAdditionProps Maven / Gradle / Ivy

Go to download

Aliyun SDK Copyright (C) Alibaba Cloud Computing All rights reserved. http://www.aliyun.com

There is a newer version: 1.4.0
Show newest version
package com.aliyun.ros.cdk.cloudsso;

/**
 * Properties for defining a PermissionPolicyToAccessConfigurationAddition.
 * 

* See https://www.alibabacloud.com/help/ros/developer-reference/aliyun-cloudsso-permissionpolicytoaccessconfigurationaddition */ @javax.annotation.Generated(value = "jsii-pacmak/1.85.0 (build 08ee592)", date = "2024-12-13T06:45:05.564Z") @software.amazon.jsii.Jsii(module = com.aliyun.ros.cdk.cloudsso.$Module.class, fqn = "@alicloud/ros-cdk-cloudsso.PermissionPolicyToAccessConfigurationAdditionProps") @software.amazon.jsii.Jsii.Proxy(PermissionPolicyToAccessConfigurationAdditionProps.Jsii$Proxy.class) public interface PermissionPolicyToAccessConfigurationAdditionProps extends software.amazon.jsii.JsiiSerializable { /** * Property accessConfigurationId: The ID of the access configuration. */ @org.jetbrains.annotations.NotNull java.lang.Object getAccessConfigurationId(); /** * Property directoryId: The ID of the directory. */ @org.jetbrains.annotations.NotNull java.lang.Object getDirectoryId(); /** * Property permissionPolicyName: The name of the permission policy. *

*

    *
  • If you set PermissionPolicyType to System, you must set this parameter to the name of the system policy. You can obtain the name of the system policy from RAM.
  • *
  • If you set PermissionPolicyType to Inline, you must set this parameter to the name of the inline policy. A custom value is supported.
  • *
*/ @org.jetbrains.annotations.NotNull java.lang.Object getPermissionPolicyName(); /** * Property permissionPolicyType: The type of the permission policy. *

* Valid values: *

*

    *
  • System: system policy. Resource Access Management (RAM) system policies are reused.
  • *
  • Inline: inline policy. Inline policies are created based on the RAM policy syntax and structure.
  • *
*/ @org.jetbrains.annotations.NotNull java.lang.Object getPermissionPolicyType(); /** * Property inlinePolicyDocument: The configurations of the inline policy. *

* The value can be up to 4,096 characters in length. * If you set PermissionPolicyType to Inline, you must specify this parameter. */ default @org.jetbrains.annotations.Nullable java.lang.Object getInlinePolicyDocument() { return null; } /** * @return a {@link Builder} of {@link PermissionPolicyToAccessConfigurationAdditionProps} */ static Builder builder() { return new Builder(); } /** * A builder for {@link PermissionPolicyToAccessConfigurationAdditionProps} */ public static final class Builder implements software.amazon.jsii.Builder { java.lang.Object accessConfigurationId; java.lang.Object directoryId; java.lang.Object permissionPolicyName; java.lang.Object permissionPolicyType; java.lang.Object inlinePolicyDocument; /** * Sets the value of {@link PermissionPolicyToAccessConfigurationAdditionProps#getAccessConfigurationId} * @param accessConfigurationId Property accessConfigurationId: The ID of the access configuration. This parameter is required. * @return {@code this} */ public Builder accessConfigurationId(java.lang.String accessConfigurationId) { this.accessConfigurationId = accessConfigurationId; return this; } /** * Sets the value of {@link PermissionPolicyToAccessConfigurationAdditionProps#getAccessConfigurationId} * @param accessConfigurationId Property accessConfigurationId: The ID of the access configuration. This parameter is required. * @return {@code this} */ public Builder accessConfigurationId(com.aliyun.ros.cdk.core.IResolvable accessConfigurationId) { this.accessConfigurationId = accessConfigurationId; return this; } /** * Sets the value of {@link PermissionPolicyToAccessConfigurationAdditionProps#getDirectoryId} * @param directoryId Property directoryId: The ID of the directory. This parameter is required. * @return {@code this} */ public Builder directoryId(java.lang.String directoryId) { this.directoryId = directoryId; return this; } /** * Sets the value of {@link PermissionPolicyToAccessConfigurationAdditionProps#getDirectoryId} * @param directoryId Property directoryId: The ID of the directory. This parameter is required. * @return {@code this} */ public Builder directoryId(com.aliyun.ros.cdk.core.IResolvable directoryId) { this.directoryId = directoryId; return this; } /** * Sets the value of {@link PermissionPolicyToAccessConfigurationAdditionProps#getPermissionPolicyName} * @param permissionPolicyName Property permissionPolicyName: The name of the permission policy. This parameter is required. *

    *
  • If you set PermissionPolicyType to System, you must set this parameter to the name of the system policy. You can obtain the name of the system policy from RAM.
  • *
  • If you set PermissionPolicyType to Inline, you must set this parameter to the name of the inline policy. A custom value is supported.
  • *
* @return {@code this} */ public Builder permissionPolicyName(java.lang.String permissionPolicyName) { this.permissionPolicyName = permissionPolicyName; return this; } /** * Sets the value of {@link PermissionPolicyToAccessConfigurationAdditionProps#getPermissionPolicyName} * @param permissionPolicyName Property permissionPolicyName: The name of the permission policy. This parameter is required. *
    *
  • If you set PermissionPolicyType to System, you must set this parameter to the name of the system policy. You can obtain the name of the system policy from RAM.
  • *
  • If you set PermissionPolicyType to Inline, you must set this parameter to the name of the inline policy. A custom value is supported.
  • *
* @return {@code this} */ public Builder permissionPolicyName(com.aliyun.ros.cdk.core.IResolvable permissionPolicyName) { this.permissionPolicyName = permissionPolicyName; return this; } /** * Sets the value of {@link PermissionPolicyToAccessConfigurationAdditionProps#getPermissionPolicyType} * @param permissionPolicyType Property permissionPolicyType: The type of the permission policy. This parameter is required. * Valid values: *

*

    *
  • System: system policy. Resource Access Management (RAM) system policies are reused.
  • *
  • Inline: inline policy. Inline policies are created based on the RAM policy syntax and structure.
  • *
* @return {@code this} */ public Builder permissionPolicyType(java.lang.String permissionPolicyType) { this.permissionPolicyType = permissionPolicyType; return this; } /** * Sets the value of {@link PermissionPolicyToAccessConfigurationAdditionProps#getPermissionPolicyType} * @param permissionPolicyType Property permissionPolicyType: The type of the permission policy. This parameter is required. * Valid values: *

*

    *
  • System: system policy. Resource Access Management (RAM) system policies are reused.
  • *
  • Inline: inline policy. Inline policies are created based on the RAM policy syntax and structure.
  • *
* @return {@code this} */ public Builder permissionPolicyType(com.aliyun.ros.cdk.core.IResolvable permissionPolicyType) { this.permissionPolicyType = permissionPolicyType; return this; } /** * Sets the value of {@link PermissionPolicyToAccessConfigurationAdditionProps#getInlinePolicyDocument} * @param inlinePolicyDocument Property inlinePolicyDocument: The configurations of the inline policy. * The value can be up to 4,096 characters in length. * If you set PermissionPolicyType to Inline, you must specify this parameter. * @return {@code this} */ public Builder inlinePolicyDocument(com.aliyun.ros.cdk.core.IResolvable inlinePolicyDocument) { this.inlinePolicyDocument = inlinePolicyDocument; return this; } /** * Sets the value of {@link PermissionPolicyToAccessConfigurationAdditionProps#getInlinePolicyDocument} * @param inlinePolicyDocument Property inlinePolicyDocument: The configurations of the inline policy. * The value can be up to 4,096 characters in length. * If you set PermissionPolicyType to Inline, you must specify this parameter. * @return {@code this} */ public Builder inlinePolicyDocument(java.util.Map inlinePolicyDocument) { this.inlinePolicyDocument = inlinePolicyDocument; return this; } /** * Builds the configured instance. * @return a new instance of {@link PermissionPolicyToAccessConfigurationAdditionProps} * @throws NullPointerException if any required attribute was not provided */ @Override public PermissionPolicyToAccessConfigurationAdditionProps build() { return new Jsii$Proxy(this); } } /** * An implementation for {@link PermissionPolicyToAccessConfigurationAdditionProps} */ @software.amazon.jsii.Internal final class Jsii$Proxy extends software.amazon.jsii.JsiiObject implements PermissionPolicyToAccessConfigurationAdditionProps { private final java.lang.Object accessConfigurationId; private final java.lang.Object directoryId; private final java.lang.Object permissionPolicyName; private final java.lang.Object permissionPolicyType; private final java.lang.Object inlinePolicyDocument; /** * 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.accessConfigurationId = software.amazon.jsii.Kernel.get(this, "accessConfigurationId", software.amazon.jsii.NativeType.forClass(java.lang.Object.class)); this.directoryId = software.amazon.jsii.Kernel.get(this, "directoryId", software.amazon.jsii.NativeType.forClass(java.lang.Object.class)); this.permissionPolicyName = software.amazon.jsii.Kernel.get(this, "permissionPolicyName", software.amazon.jsii.NativeType.forClass(java.lang.Object.class)); this.permissionPolicyType = software.amazon.jsii.Kernel.get(this, "permissionPolicyType", software.amazon.jsii.NativeType.forClass(java.lang.Object.class)); this.inlinePolicyDocument = software.amazon.jsii.Kernel.get(this, "inlinePolicyDocument", 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.accessConfigurationId = java.util.Objects.requireNonNull(builder.accessConfigurationId, "accessConfigurationId is required"); this.directoryId = java.util.Objects.requireNonNull(builder.directoryId, "directoryId is required"); this.permissionPolicyName = java.util.Objects.requireNonNull(builder.permissionPolicyName, "permissionPolicyName is required"); this.permissionPolicyType = java.util.Objects.requireNonNull(builder.permissionPolicyType, "permissionPolicyType is required"); this.inlinePolicyDocument = builder.inlinePolicyDocument; } @Override public final java.lang.Object getAccessConfigurationId() { return this.accessConfigurationId; } @Override public final java.lang.Object getDirectoryId() { return this.directoryId; } @Override public final java.lang.Object getPermissionPolicyName() { return this.permissionPolicyName; } @Override public final java.lang.Object getPermissionPolicyType() { return this.permissionPolicyType; } @Override public final java.lang.Object getInlinePolicyDocument() { return this.inlinePolicyDocument; } @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("accessConfigurationId", om.valueToTree(this.getAccessConfigurationId())); data.set("directoryId", om.valueToTree(this.getDirectoryId())); data.set("permissionPolicyName", om.valueToTree(this.getPermissionPolicyName())); data.set("permissionPolicyType", om.valueToTree(this.getPermissionPolicyType())); if (this.getInlinePolicyDocument() != null) { data.set("inlinePolicyDocument", om.valueToTree(this.getInlinePolicyDocument())); } final com.fasterxml.jackson.databind.node.ObjectNode struct = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode(); struct.set("fqn", om.valueToTree("@alicloud/ros-cdk-cloudsso.PermissionPolicyToAccessConfigurationAdditionProps")); 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; PermissionPolicyToAccessConfigurationAdditionProps.Jsii$Proxy that = (PermissionPolicyToAccessConfigurationAdditionProps.Jsii$Proxy) o; if (!accessConfigurationId.equals(that.accessConfigurationId)) return false; if (!directoryId.equals(that.directoryId)) return false; if (!permissionPolicyName.equals(that.permissionPolicyName)) return false; if (!permissionPolicyType.equals(that.permissionPolicyType)) return false; return this.inlinePolicyDocument != null ? this.inlinePolicyDocument.equals(that.inlinePolicyDocument) : that.inlinePolicyDocument == null; } @Override public final int hashCode() { int result = this.accessConfigurationId.hashCode(); result = 31 * result + (this.directoryId.hashCode()); result = 31 * result + (this.permissionPolicyName.hashCode()); result = 31 * result + (this.permissionPolicyType.hashCode()); result = 31 * result + (this.inlinePolicyDocument != null ? this.inlinePolicyDocument.hashCode() : 0); return result; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy