com.aliyun.ros.cdk.pvtz.UserVpcAuthorization Maven / Gradle / Ivy
package com.aliyun.ros.cdk.pvtz;
/**
* This class encapsulates and extends the ROS resource type ALIYUN::PVTZ::UserVpcAuthorization
, which is used to associate virtual private clouds (VPCs) across accounts.
*/
@javax.annotation.Generated(value = "jsii-pacmak/1.85.0 (build 08ee592)", date = "2024-12-13T06:45:10.762Z")
@software.amazon.jsii.Jsii(module = com.aliyun.ros.cdk.pvtz.$Module.class, fqn = "@alicloud/ros-cdk-pvtz.UserVpcAuthorization")
public class UserVpcAuthorization extends com.aliyun.ros.cdk.core.Resource {
protected UserVpcAuthorization(final software.amazon.jsii.JsiiObjectRef objRef) {
super(objRef);
}
protected UserVpcAuthorization(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 UserVpcAuthorization(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.pvtz.UserVpcAuthorizationProps 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 UserVpcAuthorization(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.pvtz.UserVpcAuthorizationProps 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 AuthorizedUserId: The account ID of the user who authorizes the resource.
*/
public @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.core.IResolvable getAttrAuthorizedUserId() {
return software.amazon.jsii.Kernel.get(this, "attrAuthorizedUserId", software.amazon.jsii.NativeType.forClass(com.aliyun.ros.cdk.core.IResolvable.class));
}
/**
* Attribute AuthType: Authorization type.
*/
public @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.core.IResolvable getAttrAuthType() {
return software.amazon.jsii.Kernel.get(this, "attrAuthType", 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.pvtz.UserVpcAuthorizationProps getProps() {
return software.amazon.jsii.Kernel.get(this, "props", software.amazon.jsii.NativeType.forClass(com.aliyun.ros.cdk.pvtz.UserVpcAuthorizationProps.class));
}
protected void setProps(final @org.jetbrains.annotations.NotNull com.aliyun.ros.cdk.pvtz.UserVpcAuthorizationProps 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.pvtz.UserVpcAuthorization}.
*/
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.pvtz.UserVpcAuthorizationProps.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.pvtz.UserVpcAuthorizationProps.Builder();
}
/**
* Property authorizedUserId: The account ID of the user who authorizes the resource.
*
* @return {@code this}
* @param authorizedUserId Property authorizedUserId: The account ID of the user who authorizes the resource. This parameter is required.
*/
public Builder authorizedUserId(final java.lang.String authorizedUserId) {
this.props.authorizedUserId(authorizedUserId);
return this;
}
/**
* Property authorizedUserId: The account ID of the user who authorizes the resource.
*
* @return {@code this}
* @param authorizedUserId Property authorizedUserId: The account ID of the user who authorizes the resource. This parameter is required.
*/
public Builder authorizedUserId(final com.aliyun.ros.cdk.core.IResolvable authorizedUserId) {
this.props.authorizedUserId(authorizedUserId);
return this;
}
/**
* Property authChannel: Authorization channel.
*
* Valid values:
* AUTH_CODE: Verification code authorization, to verify whether the verification code passed in by AuthCode is correct.
* RESOURCE_DIRECTORY: Resource directory authorization, verify whether the AuthorizedUserId and the current account have resource directory credit.When it is empty, it is the same as AUTH_CODE, that is, verification code authorization.
*
* @return {@code this}
* @param authChannel Property authChannel: Authorization channel. This parameter is required.
*/
public Builder authChannel(final java.lang.String authChannel) {
this.props.authChannel(authChannel);
return this;
}
/**
* Property authChannel: Authorization channel.
*
* Valid values:
* AUTH_CODE: Verification code authorization, to verify whether the verification code passed in by AuthCode is correct.
* RESOURCE_DIRECTORY: Resource directory authorization, verify whether the AuthorizedUserId and the current account have resource directory credit.When it is empty, it is the same as AUTH_CODE, that is, verification code authorization.
*
* @return {@code this}
* @param authChannel Property authChannel: Authorization channel. This parameter is required.
*/
public Builder authChannel(final com.aliyun.ros.cdk.core.IResolvable authChannel) {
this.props.authChannel(authChannel);
return this;
}
/**
* Property authCode: Verification code, if AuthChannel takes "AUTH_CODE" or is empty, it is mandatory.
*
* @return {@code this}
* @param authCode Property authCode: Verification code, if AuthChannel takes "AUTH_CODE" or is empty, it is mandatory. This parameter is required.
*/
public Builder authCode(final java.lang.String authCode) {
this.props.authCode(authCode);
return this;
}
/**
* Property authCode: Verification code, if AuthChannel takes "AUTH_CODE" or is empty, it is mandatory.
*
* @return {@code this}
* @param authCode Property authCode: Verification code, if AuthChannel takes "AUTH_CODE" or is empty, it is mandatory. This parameter is required.
*/
public Builder authCode(final com.aliyun.ros.cdk.core.IResolvable authCode) {
this.props.authCode(authCode);
return this;
}
/**
* Property authType: Authorization type.
*
* @return {@code this}
* @param authType Property authType: Authorization type. This parameter is required.
*/
public Builder authType(final java.lang.String authType) {
this.props.authType(authType);
return this;
}
/**
* Property authType: Authorization type.
*
* @return {@code this}
* @param authType Property authType: Authorization type. This parameter is required.
*/
public Builder authType(final com.aliyun.ros.cdk.core.IResolvable authType) {
this.props.authType(authType);
return this;
}
/**
* Property ignoreDeletionForbidden: Whether to ignore following deletion forbidden errors when deleting:- UserAuth.DeleteForbidden.ZoneVpcExists.
*
* @return {@code this}
* @param ignoreDeletionForbidden Property ignoreDeletionForbidden: Whether to ignore following deletion forbidden errors when deleting:- UserAuth.DeleteForbidden.ZoneVpcExists. This parameter is required.
*/
public Builder ignoreDeletionForbidden(final java.lang.Boolean ignoreDeletionForbidden) {
this.props.ignoreDeletionForbidden(ignoreDeletionForbidden);
return this;
}
/**
* Property ignoreDeletionForbidden: Whether to ignore following deletion forbidden errors when deleting:- UserAuth.DeleteForbidden.ZoneVpcExists.
*
* @return {@code this}
* @param ignoreDeletionForbidden Property ignoreDeletionForbidden: Whether to ignore following deletion forbidden errors when deleting:- UserAuth.DeleteForbidden.ZoneVpcExists. This parameter is required.
*/
public Builder ignoreDeletionForbidden(final com.aliyun.ros.cdk.core.IResolvable ignoreDeletionForbidden) {
this.props.ignoreDeletionForbidden(ignoreDeletionForbidden);
return this;
}
/**
* @return a newly built instance of {@link com.aliyun.ros.cdk.pvtz.UserVpcAuthorization}.
*/
@Override
public com.aliyun.ros.cdk.pvtz.UserVpcAuthorization build() {
return new com.aliyun.ros.cdk.pvtz.UserVpcAuthorization(
this.scope,
this.id,
this.props.build(),
this.enableResourcePropertyConstraint
);
}
}
}