Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.pulumi.aws.cloudformation.StackSetArgs Maven / Gradle / Ivy
// *** WARNING: this file was generated by pulumi-java-gen. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
package com.pulumi.aws.cloudformation;
import com.pulumi.aws.cloudformation.inputs.StackSetAutoDeploymentArgs;
import com.pulumi.aws.cloudformation.inputs.StackSetManagedExecutionArgs;
import com.pulumi.aws.cloudformation.inputs.StackSetOperationPreferencesArgs;
import com.pulumi.core.Output;
import com.pulumi.core.annotations.Import;
import java.lang.String;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;
public final class StackSetArgs extends com.pulumi.resources.ResourceArgs {
public static final StackSetArgs Empty = new StackSetArgs();
/**
* Amazon Resource Number (ARN) of the IAM Role in the administrator account. This must be defined when using the `SELF_MANAGED` permission model.
*
*/
@Import(name="administrationRoleArn")
private @Nullable Output administrationRoleArn;
/**
* @return Amazon Resource Number (ARN) of the IAM Role in the administrator account. This must be defined when using the `SELF_MANAGED` permission model.
*
*/
public Optional> administrationRoleArn() {
return Optional.ofNullable(this.administrationRoleArn);
}
/**
* Configuration block containing the auto-deployment model for your StackSet. This can only be defined when using the `SERVICE_MANAGED` permission model.
*
*/
@Import(name="autoDeployment")
private @Nullable Output autoDeployment;
/**
* @return Configuration block containing the auto-deployment model for your StackSet. This can only be defined when using the `SERVICE_MANAGED` permission model.
*
*/
public Optional> autoDeployment() {
return Optional.ofNullable(this.autoDeployment);
}
/**
* Specifies whether you are acting as an account administrator in the organization's management account or as a delegated administrator in a member account. Valid values: `SELF` (default), `DELEGATED_ADMIN`.
*
*/
@Import(name="callAs")
private @Nullable Output callAs;
/**
* @return Specifies whether you are acting as an account administrator in the organization's management account or as a delegated administrator in a member account. Valid values: `SELF` (default), `DELEGATED_ADMIN`.
*
*/
public Optional> callAs() {
return Optional.ofNullable(this.callAs);
}
/**
* A list of capabilities. Valid values: `CAPABILITY_IAM`, `CAPABILITY_NAMED_IAM`, `CAPABILITY_AUTO_EXPAND`.
*
*/
@Import(name="capabilities")
private @Nullable Output> capabilities;
/**
* @return A list of capabilities. Valid values: `CAPABILITY_IAM`, `CAPABILITY_NAMED_IAM`, `CAPABILITY_AUTO_EXPAND`.
*
*/
public Optional>> capabilities() {
return Optional.ofNullable(this.capabilities);
}
/**
* Description of the StackSet.
*
*/
@Import(name="description")
private @Nullable Output description;
/**
* @return Description of the StackSet.
*
*/
public Optional> description() {
return Optional.ofNullable(this.description);
}
/**
* Name of the IAM Role in all target accounts for StackSet operations. Defaults to `AWSCloudFormationStackSetExecutionRole` when using the `SELF_MANAGED` permission model. This should not be defined when using the `SERVICE_MANAGED` permission model.
*
*/
@Import(name="executionRoleName")
private @Nullable Output executionRoleName;
/**
* @return Name of the IAM Role in all target accounts for StackSet operations. Defaults to `AWSCloudFormationStackSetExecutionRole` when using the `SELF_MANAGED` permission model. This should not be defined when using the `SERVICE_MANAGED` permission model.
*
*/
public Optional> executionRoleName() {
return Optional.ofNullable(this.executionRoleName);
}
/**
* Configuration block to allow StackSets to perform non-conflicting operations concurrently and queues conflicting operations.
*
*/
@Import(name="managedExecution")
private @Nullable Output managedExecution;
/**
* @return Configuration block to allow StackSets to perform non-conflicting operations concurrently and queues conflicting operations.
*
*/
public Optional> managedExecution() {
return Optional.ofNullable(this.managedExecution);
}
/**
* Name of the StackSet. The name must be unique in the region where you create your StackSet. The name can contain only alphanumeric characters (case-sensitive) and hyphens. It must start with an alphabetic character and cannot be longer than 128 characters.
*
*/
@Import(name="name")
private @Nullable Output name;
/**
* @return Name of the StackSet. The name must be unique in the region where you create your StackSet. The name can contain only alphanumeric characters (case-sensitive) and hyphens. It must start with an alphabetic character and cannot be longer than 128 characters.
*
*/
public Optional> name() {
return Optional.ofNullable(this.name);
}
/**
* Preferences for how AWS CloudFormation performs a stack set update.
*
*/
@Import(name="operationPreferences")
private @Nullable Output operationPreferences;
/**
* @return Preferences for how AWS CloudFormation performs a stack set update.
*
*/
public Optional> operationPreferences() {
return Optional.ofNullable(this.operationPreferences);
}
/**
* Key-value map of input parameters for the StackSet template. All template parameters, including those with a `Default`, must be configured or ignored with `lifecycle` configuration block `ignore_changes` argument. All `NoEcho` template parameters must be ignored with the `lifecycle` configuration block `ignore_changes` argument.
*
*/
@Import(name="parameters")
private @Nullable Output> parameters;
/**
* @return Key-value map of input parameters for the StackSet template. All template parameters, including those with a `Default`, must be configured or ignored with `lifecycle` configuration block `ignore_changes` argument. All `NoEcho` template parameters must be ignored with the `lifecycle` configuration block `ignore_changes` argument.
*
*/
public Optional>> parameters() {
return Optional.ofNullable(this.parameters);
}
/**
* Describes how the IAM roles required for your StackSet are created. Valid values: `SELF_MANAGED` (default), `SERVICE_MANAGED`.
*
*/
@Import(name="permissionModel")
private @Nullable Output permissionModel;
/**
* @return Describes how the IAM roles required for your StackSet are created. Valid values: `SELF_MANAGED` (default), `SERVICE_MANAGED`.
*
*/
public Optional> permissionModel() {
return Optional.ofNullable(this.permissionModel);
}
/**
* Key-value map of tags to associate with this StackSet and the Stacks created from it. AWS CloudFormation also propagates these tags to supported resources that are created in the Stacks. A maximum number of 50 tags can be specified. If configured with a provider `default_tags` configuration block present, tags with matching keys will overwrite those defined at the provider-level.
*
*/
@Import(name="tags")
private @Nullable Output> tags;
/**
* @return Key-value map of tags to associate with this StackSet and the Stacks created from it. AWS CloudFormation also propagates these tags to supported resources that are created in the Stacks. A maximum number of 50 tags can be specified. If configured with a provider `default_tags` configuration block present, tags with matching keys will overwrite those defined at the provider-level.
*
*/
public Optional>> tags() {
return Optional.ofNullable(this.tags);
}
/**
* String containing the CloudFormation template body. Maximum size: 51,200 bytes. Conflicts with `template_url`.
*
*/
@Import(name="templateBody")
private @Nullable Output templateBody;
/**
* @return String containing the CloudFormation template body. Maximum size: 51,200 bytes. Conflicts with `template_url`.
*
*/
public Optional> templateBody() {
return Optional.ofNullable(this.templateBody);
}
/**
* String containing the location of a file containing the CloudFormation template body. The URL must point to a template that is located in an Amazon S3 bucket. Maximum location file size: 460,800 bytes. Conflicts with `template_body`.
*
*/
@Import(name="templateUrl")
private @Nullable Output templateUrl;
/**
* @return String containing the location of a file containing the CloudFormation template body. The URL must point to a template that is located in an Amazon S3 bucket. Maximum location file size: 460,800 bytes. Conflicts with `template_body`.
*
*/
public Optional> templateUrl() {
return Optional.ofNullable(this.templateUrl);
}
private StackSetArgs() {}
private StackSetArgs(StackSetArgs $) {
this.administrationRoleArn = $.administrationRoleArn;
this.autoDeployment = $.autoDeployment;
this.callAs = $.callAs;
this.capabilities = $.capabilities;
this.description = $.description;
this.executionRoleName = $.executionRoleName;
this.managedExecution = $.managedExecution;
this.name = $.name;
this.operationPreferences = $.operationPreferences;
this.parameters = $.parameters;
this.permissionModel = $.permissionModel;
this.tags = $.tags;
this.templateBody = $.templateBody;
this.templateUrl = $.templateUrl;
}
public static Builder builder() {
return new Builder();
}
public static Builder builder(StackSetArgs defaults) {
return new Builder(defaults);
}
public static final class Builder {
private StackSetArgs $;
public Builder() {
$ = new StackSetArgs();
}
public Builder(StackSetArgs defaults) {
$ = new StackSetArgs(Objects.requireNonNull(defaults));
}
/**
* @param administrationRoleArn Amazon Resource Number (ARN) of the IAM Role in the administrator account. This must be defined when using the `SELF_MANAGED` permission model.
*
* @return builder
*
*/
public Builder administrationRoleArn(@Nullable Output administrationRoleArn) {
$.administrationRoleArn = administrationRoleArn;
return this;
}
/**
* @param administrationRoleArn Amazon Resource Number (ARN) of the IAM Role in the administrator account. This must be defined when using the `SELF_MANAGED` permission model.
*
* @return builder
*
*/
public Builder administrationRoleArn(String administrationRoleArn) {
return administrationRoleArn(Output.of(administrationRoleArn));
}
/**
* @param autoDeployment Configuration block containing the auto-deployment model for your StackSet. This can only be defined when using the `SERVICE_MANAGED` permission model.
*
* @return builder
*
*/
public Builder autoDeployment(@Nullable Output autoDeployment) {
$.autoDeployment = autoDeployment;
return this;
}
/**
* @param autoDeployment Configuration block containing the auto-deployment model for your StackSet. This can only be defined when using the `SERVICE_MANAGED` permission model.
*
* @return builder
*
*/
public Builder autoDeployment(StackSetAutoDeploymentArgs autoDeployment) {
return autoDeployment(Output.of(autoDeployment));
}
/**
* @param callAs Specifies whether you are acting as an account administrator in the organization's management account or as a delegated administrator in a member account. Valid values: `SELF` (default), `DELEGATED_ADMIN`.
*
* @return builder
*
*/
public Builder callAs(@Nullable Output callAs) {
$.callAs = callAs;
return this;
}
/**
* @param callAs Specifies whether you are acting as an account administrator in the organization's management account or as a delegated administrator in a member account. Valid values: `SELF` (default), `DELEGATED_ADMIN`.
*
* @return builder
*
*/
public Builder callAs(String callAs) {
return callAs(Output.of(callAs));
}
/**
* @param capabilities A list of capabilities. Valid values: `CAPABILITY_IAM`, `CAPABILITY_NAMED_IAM`, `CAPABILITY_AUTO_EXPAND`.
*
* @return builder
*
*/
public Builder capabilities(@Nullable Output> capabilities) {
$.capabilities = capabilities;
return this;
}
/**
* @param capabilities A list of capabilities. Valid values: `CAPABILITY_IAM`, `CAPABILITY_NAMED_IAM`, `CAPABILITY_AUTO_EXPAND`.
*
* @return builder
*
*/
public Builder capabilities(List capabilities) {
return capabilities(Output.of(capabilities));
}
/**
* @param capabilities A list of capabilities. Valid values: `CAPABILITY_IAM`, `CAPABILITY_NAMED_IAM`, `CAPABILITY_AUTO_EXPAND`.
*
* @return builder
*
*/
public Builder capabilities(String... capabilities) {
return capabilities(List.of(capabilities));
}
/**
* @param description Description of the StackSet.
*
* @return builder
*
*/
public Builder description(@Nullable Output description) {
$.description = description;
return this;
}
/**
* @param description Description of the StackSet.
*
* @return builder
*
*/
public Builder description(String description) {
return description(Output.of(description));
}
/**
* @param executionRoleName Name of the IAM Role in all target accounts for StackSet operations. Defaults to `AWSCloudFormationStackSetExecutionRole` when using the `SELF_MANAGED` permission model. This should not be defined when using the `SERVICE_MANAGED` permission model.
*
* @return builder
*
*/
public Builder executionRoleName(@Nullable Output executionRoleName) {
$.executionRoleName = executionRoleName;
return this;
}
/**
* @param executionRoleName Name of the IAM Role in all target accounts for StackSet operations. Defaults to `AWSCloudFormationStackSetExecutionRole` when using the `SELF_MANAGED` permission model. This should not be defined when using the `SERVICE_MANAGED` permission model.
*
* @return builder
*
*/
public Builder executionRoleName(String executionRoleName) {
return executionRoleName(Output.of(executionRoleName));
}
/**
* @param managedExecution Configuration block to allow StackSets to perform non-conflicting operations concurrently and queues conflicting operations.
*
* @return builder
*
*/
public Builder managedExecution(@Nullable Output managedExecution) {
$.managedExecution = managedExecution;
return this;
}
/**
* @param managedExecution Configuration block to allow StackSets to perform non-conflicting operations concurrently and queues conflicting operations.
*
* @return builder
*
*/
public Builder managedExecution(StackSetManagedExecutionArgs managedExecution) {
return managedExecution(Output.of(managedExecution));
}
/**
* @param name Name of the StackSet. The name must be unique in the region where you create your StackSet. The name can contain only alphanumeric characters (case-sensitive) and hyphens. It must start with an alphabetic character and cannot be longer than 128 characters.
*
* @return builder
*
*/
public Builder name(@Nullable Output name) {
$.name = name;
return this;
}
/**
* @param name Name of the StackSet. The name must be unique in the region where you create your StackSet. The name can contain only alphanumeric characters (case-sensitive) and hyphens. It must start with an alphabetic character and cannot be longer than 128 characters.
*
* @return builder
*
*/
public Builder name(String name) {
return name(Output.of(name));
}
/**
* @param operationPreferences Preferences for how AWS CloudFormation performs a stack set update.
*
* @return builder
*
*/
public Builder operationPreferences(@Nullable Output operationPreferences) {
$.operationPreferences = operationPreferences;
return this;
}
/**
* @param operationPreferences Preferences for how AWS CloudFormation performs a stack set update.
*
* @return builder
*
*/
public Builder operationPreferences(StackSetOperationPreferencesArgs operationPreferences) {
return operationPreferences(Output.of(operationPreferences));
}
/**
* @param parameters Key-value map of input parameters for the StackSet template. All template parameters, including those with a `Default`, must be configured or ignored with `lifecycle` configuration block `ignore_changes` argument. All `NoEcho` template parameters must be ignored with the `lifecycle` configuration block `ignore_changes` argument.
*
* @return builder
*
*/
public Builder parameters(@Nullable Output> parameters) {
$.parameters = parameters;
return this;
}
/**
* @param parameters Key-value map of input parameters for the StackSet template. All template parameters, including those with a `Default`, must be configured or ignored with `lifecycle` configuration block `ignore_changes` argument. All `NoEcho` template parameters must be ignored with the `lifecycle` configuration block `ignore_changes` argument.
*
* @return builder
*
*/
public Builder parameters(Map parameters) {
return parameters(Output.of(parameters));
}
/**
* @param permissionModel Describes how the IAM roles required for your StackSet are created. Valid values: `SELF_MANAGED` (default), `SERVICE_MANAGED`.
*
* @return builder
*
*/
public Builder permissionModel(@Nullable Output permissionModel) {
$.permissionModel = permissionModel;
return this;
}
/**
* @param permissionModel Describes how the IAM roles required for your StackSet are created. Valid values: `SELF_MANAGED` (default), `SERVICE_MANAGED`.
*
* @return builder
*
*/
public Builder permissionModel(String permissionModel) {
return permissionModel(Output.of(permissionModel));
}
/**
* @param tags Key-value map of tags to associate with this StackSet and the Stacks created from it. AWS CloudFormation also propagates these tags to supported resources that are created in the Stacks. A maximum number of 50 tags can be specified. If configured with a provider `default_tags` configuration block present, tags with matching keys will overwrite those defined at the provider-level.
*
* @return builder
*
*/
public Builder tags(@Nullable Output> tags) {
$.tags = tags;
return this;
}
/**
* @param tags Key-value map of tags to associate with this StackSet and the Stacks created from it. AWS CloudFormation also propagates these tags to supported resources that are created in the Stacks. A maximum number of 50 tags can be specified. If configured with a provider `default_tags` configuration block present, tags with matching keys will overwrite those defined at the provider-level.
*
* @return builder
*
*/
public Builder tags(Map tags) {
return tags(Output.of(tags));
}
/**
* @param templateBody String containing the CloudFormation template body. Maximum size: 51,200 bytes. Conflicts with `template_url`.
*
* @return builder
*
*/
public Builder templateBody(@Nullable Output templateBody) {
$.templateBody = templateBody;
return this;
}
/**
* @param templateBody String containing the CloudFormation template body. Maximum size: 51,200 bytes. Conflicts with `template_url`.
*
* @return builder
*
*/
public Builder templateBody(String templateBody) {
return templateBody(Output.of(templateBody));
}
/**
* @param templateUrl String containing the location of a file containing the CloudFormation template body. The URL must point to a template that is located in an Amazon S3 bucket. Maximum location file size: 460,800 bytes. Conflicts with `template_body`.
*
* @return builder
*
*/
public Builder templateUrl(@Nullable Output templateUrl) {
$.templateUrl = templateUrl;
return this;
}
/**
* @param templateUrl String containing the location of a file containing the CloudFormation template body. The URL must point to a template that is located in an Amazon S3 bucket. Maximum location file size: 460,800 bytes. Conflicts with `template_body`.
*
* @return builder
*
*/
public Builder templateUrl(String templateUrl) {
return templateUrl(Output.of(templateUrl));
}
public StackSetArgs build() {
return $;
}
}
}