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

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

package com.aliyun.ros.cdk.cloudsso;

/**
 * Properties for defining a UserProvision.
 * 

* See https://www.alibabacloud.com/help/ros/developer-reference/aliyun-cloudsso-userprovision */ @javax.annotation.Generated(value = "jsii-pacmak/1.85.0 (build 08ee592)", date = "2024-04-09T06:05:31.047Z") @software.amazon.jsii.Jsii(module = com.aliyun.ros.cdk.cloudsso.$Module.class, fqn = "@alicloud/ros-cdk-cloudsso.UserProvisionProps") @software.amazon.jsii.Jsii.Proxy(UserProvisionProps.Jsii$Proxy.class) public interface UserProvisionProps extends software.amazon.jsii.JsiiSerializable { /** * Property deletionStrategy: Delete policy. *

* The treatment strategy for the synchronized RAM users when the RAM user synchronization is removed. Valid values: *

*

    *
  • Delete: Delete When the RAM user synchronization is removed, the RAM users that have been synchronized to the RAM from the cloud SSO are deleted.
  • *
  • Keep: When the RAM user synchronization is removed, the RAM users that have been synchronized to the RAM from the cloud SSO are retained.
  • *
*/ @org.jetbrains.annotations.NotNull java.lang.Object getDeletionStrategy(); /** * Property directoryId: The ID of the directory. */ @org.jetbrains.annotations.NotNull java.lang.Object getDirectoryId(); /** * Property duplicationStrategy: Conflict policy. *

* When the cloud SSO user is synchronized to the RAM, the processing strategy if there is a user with the same name in the RAM. Valid values: *

*

    *
  • KeepBoth: Keep both of them. When the cloud SSO user is synchronized to RAM, if the RAM already has a user with the same name, it will try to create a RAM user with the user name after adding the suffix _sso to the user name of the cloud SSO user.
  • *
  • TakeOver: Take over. When the cloud SSO user is synchronized to the RAM, if the RAM already has a user with the same name, the existing RAM user is directly replaced by the cloud SSO synchronization user.
  • *
*/ @org.jetbrains.annotations.NotNull java.lang.Object getDuplicationStrategy(); /** * Property principalId: The ID of the principal. *

* Valid values: *

*

    *
  • When the PrincipalType value is Group, the value is the cloud SSO user group ID (g-********).
  • *
  • When PrincipalType takes the value User, this value is the cloud SSO user ID (u-********).
  • *
*/ @org.jetbrains.annotations.NotNull java.lang.Object getPrincipalId(); /** * Property principalType: The type of the principal. *

* Valid values: *

*

    *
  • User: The principal is a cloud SSO user.
  • *
  • Group: The principal is a cloud SSO group.
  • *
*/ @org.jetbrains.annotations.NotNull java.lang.Object getPrincipalType(); /** * Property targetId: Target ID for RAM user synchronization. *

* Currently, it is the RD account ID. */ @org.jetbrains.annotations.NotNull java.lang.Object getTargetId(); /** * Property targetType: Target type for RAM user synchronization. *

* Currently, it is RD-Account. */ @org.jetbrains.annotations.NotNull java.lang.Object getTargetType(); /** * Property description: The description of the user. */ default @org.jetbrains.annotations.Nullable java.lang.Object getDescription() { return null; } /** * @return a {@link Builder} of {@link UserProvisionProps} */ static Builder builder() { return new Builder(); } /** * A builder for {@link UserProvisionProps} */ public static final class Builder implements software.amazon.jsii.Builder { java.lang.Object deletionStrategy; java.lang.Object directoryId; java.lang.Object duplicationStrategy; java.lang.Object principalId; java.lang.Object principalType; java.lang.Object targetId; java.lang.Object targetType; java.lang.Object description; /** * Sets the value of {@link UserProvisionProps#getDeletionStrategy} * @param deletionStrategy Property deletionStrategy: Delete policy. This parameter is required. * The treatment strategy for the synchronized RAM users when the RAM user synchronization is removed. Valid values: *

*

    *
  • Delete: Delete When the RAM user synchronization is removed, the RAM users that have been synchronized to the RAM from the cloud SSO are deleted.
  • *
  • Keep: When the RAM user synchronization is removed, the RAM users that have been synchronized to the RAM from the cloud SSO are retained.
  • *
* @return {@code this} */ public Builder deletionStrategy(java.lang.String deletionStrategy) { this.deletionStrategy = deletionStrategy; return this; } /** * Sets the value of {@link UserProvisionProps#getDeletionStrategy} * @param deletionStrategy Property deletionStrategy: Delete policy. This parameter is required. * The treatment strategy for the synchronized RAM users when the RAM user synchronization is removed. Valid values: *

*

    *
  • Delete: Delete When the RAM user synchronization is removed, the RAM users that have been synchronized to the RAM from the cloud SSO are deleted.
  • *
  • Keep: When the RAM user synchronization is removed, the RAM users that have been synchronized to the RAM from the cloud SSO are retained.
  • *
* @return {@code this} */ public Builder deletionStrategy(com.aliyun.ros.cdk.core.IResolvable deletionStrategy) { this.deletionStrategy = deletionStrategy; return this; } /** * Sets the value of {@link UserProvisionProps#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 UserProvisionProps#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 UserProvisionProps#getDuplicationStrategy} * @param duplicationStrategy Property duplicationStrategy: Conflict policy. This parameter is required. * When the cloud SSO user is synchronized to the RAM, the processing strategy if there is a user with the same name in the RAM. Valid values: *

*

    *
  • KeepBoth: Keep both of them. When the cloud SSO user is synchronized to RAM, if the RAM already has a user with the same name, it will try to create a RAM user with the user name after adding the suffix _sso to the user name of the cloud SSO user.
  • *
  • TakeOver: Take over. When the cloud SSO user is synchronized to the RAM, if the RAM already has a user with the same name, the existing RAM user is directly replaced by the cloud SSO synchronization user.
  • *
* @return {@code this} */ public Builder duplicationStrategy(java.lang.String duplicationStrategy) { this.duplicationStrategy = duplicationStrategy; return this; } /** * Sets the value of {@link UserProvisionProps#getDuplicationStrategy} * @param duplicationStrategy Property duplicationStrategy: Conflict policy. This parameter is required. * When the cloud SSO user is synchronized to the RAM, the processing strategy if there is a user with the same name in the RAM. Valid values: *

*

    *
  • KeepBoth: Keep both of them. When the cloud SSO user is synchronized to RAM, if the RAM already has a user with the same name, it will try to create a RAM user with the user name after adding the suffix _sso to the user name of the cloud SSO user.
  • *
  • TakeOver: Take over. When the cloud SSO user is synchronized to the RAM, if the RAM already has a user with the same name, the existing RAM user is directly replaced by the cloud SSO synchronization user.
  • *
* @return {@code this} */ public Builder duplicationStrategy(com.aliyun.ros.cdk.core.IResolvable duplicationStrategy) { this.duplicationStrategy = duplicationStrategy; return this; } /** * Sets the value of {@link UserProvisionProps#getPrincipalId} * @param principalId Property principalId: The ID of the principal. This parameter is required. * Valid values: *

*

    *
  • When the PrincipalType value is Group, the value is the cloud SSO user group ID (g-********).
  • *
  • When PrincipalType takes the value User, this value is the cloud SSO user ID (u-********).
  • *
* @return {@code this} */ public Builder principalId(java.lang.String principalId) { this.principalId = principalId; return this; } /** * Sets the value of {@link UserProvisionProps#getPrincipalId} * @param principalId Property principalId: The ID of the principal. This parameter is required. * Valid values: *

*

    *
  • When the PrincipalType value is Group, the value is the cloud SSO user group ID (g-********).
  • *
  • When PrincipalType takes the value User, this value is the cloud SSO user ID (u-********).
  • *
* @return {@code this} */ public Builder principalId(com.aliyun.ros.cdk.core.IResolvable principalId) { this.principalId = principalId; return this; } /** * Sets the value of {@link UserProvisionProps#getPrincipalType} * @param principalType Property principalType: The type of the principal. This parameter is required. * Valid values: *

*

    *
  • User: The principal is a cloud SSO user.
  • *
  • Group: The principal is a cloud SSO group.
  • *
* @return {@code this} */ public Builder principalType(java.lang.String principalType) { this.principalType = principalType; return this; } /** * Sets the value of {@link UserProvisionProps#getPrincipalType} * @param principalType Property principalType: The type of the principal. This parameter is required. * Valid values: *

*

    *
  • User: The principal is a cloud SSO user.
  • *
  • Group: The principal is a cloud SSO group.
  • *
* @return {@code this} */ public Builder principalType(com.aliyun.ros.cdk.core.IResolvable principalType) { this.principalType = principalType; return this; } /** * Sets the value of {@link UserProvisionProps#getTargetId} * @param targetId Property targetId: Target ID for RAM user synchronization. This parameter is required. * Currently, it is the RD account ID. * @return {@code this} */ public Builder targetId(java.lang.String targetId) { this.targetId = targetId; return this; } /** * Sets the value of {@link UserProvisionProps#getTargetId} * @param targetId Property targetId: Target ID for RAM user synchronization. This parameter is required. * Currently, it is the RD account ID. * @return {@code this} */ public Builder targetId(com.aliyun.ros.cdk.core.IResolvable targetId) { this.targetId = targetId; return this; } /** * Sets the value of {@link UserProvisionProps#getTargetType} * @param targetType Property targetType: Target type for RAM user synchronization. This parameter is required. * Currently, it is RD-Account. * @return {@code this} */ public Builder targetType(java.lang.String targetType) { this.targetType = targetType; return this; } /** * Sets the value of {@link UserProvisionProps#getTargetType} * @param targetType Property targetType: Target type for RAM user synchronization. This parameter is required. * Currently, it is RD-Account. * @return {@code this} */ public Builder targetType(com.aliyun.ros.cdk.core.IResolvable targetType) { this.targetType = targetType; return this; } /** * Sets the value of {@link UserProvisionProps#getDescription} * @param description Property description: The description of the user. * @return {@code this} */ public Builder description(java.lang.String description) { this.description = description; return this; } /** * Sets the value of {@link UserProvisionProps#getDescription} * @param description Property description: The description of the user. * @return {@code this} */ public Builder description(com.aliyun.ros.cdk.core.IResolvable description) { this.description = description; return this; } /** * Builds the configured instance. * @return a new instance of {@link UserProvisionProps} * @throws NullPointerException if any required attribute was not provided */ @Override public UserProvisionProps build() { return new Jsii$Proxy(this); } } /** * An implementation for {@link UserProvisionProps} */ @software.amazon.jsii.Internal final class Jsii$Proxy extends software.amazon.jsii.JsiiObject implements UserProvisionProps { private final java.lang.Object deletionStrategy; private final java.lang.Object directoryId; private final java.lang.Object duplicationStrategy; private final java.lang.Object principalId; private final java.lang.Object principalType; private final java.lang.Object targetId; private final java.lang.Object targetType; private final java.lang.Object description; /** * 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.deletionStrategy = software.amazon.jsii.Kernel.get(this, "deletionStrategy", 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.duplicationStrategy = software.amazon.jsii.Kernel.get(this, "duplicationStrategy", software.amazon.jsii.NativeType.forClass(java.lang.Object.class)); this.principalId = software.amazon.jsii.Kernel.get(this, "principalId", software.amazon.jsii.NativeType.forClass(java.lang.Object.class)); this.principalType = software.amazon.jsii.Kernel.get(this, "principalType", software.amazon.jsii.NativeType.forClass(java.lang.Object.class)); this.targetId = software.amazon.jsii.Kernel.get(this, "targetId", software.amazon.jsii.NativeType.forClass(java.lang.Object.class)); this.targetType = software.amazon.jsii.Kernel.get(this, "targetType", 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)); } /** * 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.deletionStrategy = java.util.Objects.requireNonNull(builder.deletionStrategy, "deletionStrategy is required"); this.directoryId = java.util.Objects.requireNonNull(builder.directoryId, "directoryId is required"); this.duplicationStrategy = java.util.Objects.requireNonNull(builder.duplicationStrategy, "duplicationStrategy is required"); this.principalId = java.util.Objects.requireNonNull(builder.principalId, "principalId is required"); this.principalType = java.util.Objects.requireNonNull(builder.principalType, "principalType is required"); this.targetId = java.util.Objects.requireNonNull(builder.targetId, "targetId is required"); this.targetType = java.util.Objects.requireNonNull(builder.targetType, "targetType is required"); this.description = builder.description; } @Override public final java.lang.Object getDeletionStrategy() { return this.deletionStrategy; } @Override public final java.lang.Object getDirectoryId() { return this.directoryId; } @Override public final java.lang.Object getDuplicationStrategy() { return this.duplicationStrategy; } @Override public final java.lang.Object getPrincipalId() { return this.principalId; } @Override public final java.lang.Object getPrincipalType() { return this.principalType; } @Override public final java.lang.Object getTargetId() { return this.targetId; } @Override public final java.lang.Object getTargetType() { return this.targetType; } @Override public final java.lang.Object getDescription() { return this.description; } @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("deletionStrategy", om.valueToTree(this.getDeletionStrategy())); data.set("directoryId", om.valueToTree(this.getDirectoryId())); data.set("duplicationStrategy", om.valueToTree(this.getDuplicationStrategy())); data.set("principalId", om.valueToTree(this.getPrincipalId())); data.set("principalType", om.valueToTree(this.getPrincipalType())); data.set("targetId", om.valueToTree(this.getTargetId())); data.set("targetType", om.valueToTree(this.getTargetType())); if (this.getDescription() != null) { data.set("description", om.valueToTree(this.getDescription())); } 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.UserProvisionProps")); 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; UserProvisionProps.Jsii$Proxy that = (UserProvisionProps.Jsii$Proxy) o; if (!deletionStrategy.equals(that.deletionStrategy)) return false; if (!directoryId.equals(that.directoryId)) return false; if (!duplicationStrategy.equals(that.duplicationStrategy)) return false; if (!principalId.equals(that.principalId)) return false; if (!principalType.equals(that.principalType)) return false; if (!targetId.equals(that.targetId)) return false; if (!targetType.equals(that.targetType)) return false; return this.description != null ? this.description.equals(that.description) : that.description == null; } @Override public final int hashCode() { int result = this.deletionStrategy.hashCode(); result = 31 * result + (this.directoryId.hashCode()); result = 31 * result + (this.duplicationStrategy.hashCode()); result = 31 * result + (this.principalId.hashCode()); result = 31 * result + (this.principalType.hashCode()); result = 31 * result + (this.targetId.hashCode()); result = 31 * result + (this.targetType.hashCode()); result = 31 * result + (this.description != null ? this.description.hashCode() : 0); return result; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy