AWS Tools for Windows PowerShell
Command Reference

AWS services or capabilities described in AWS Documentation may vary by region/location. Click Getting Started with Amazon AWS to see specific differences applicable to the China (Beijing) Region.

Synopsis

Calls the AWS OpsWorks CloneStack API operation.

Syntax

Copy-OPSStack
-SourceStackId <String>
-Name <String>
-StackRegion <String>
-AgentVersion <String>
-Attribute <Hashtable>
-ChefConfiguration_BerkshelfVersion <String>
-CloneAppId <String[]>
-ClonePermission <Boolean>
-CustomJson <String>
-DefaultAvailabilityZone <String>
-DefaultInstanceProfileArn <String>
-DefaultOs <String>
-DefaultRootDeviceType <RootDeviceType>
-DefaultSshKeyName <String>
-DefaultSubnetId <String>
-HostnameTheme <String>
-ChefConfiguration_ManageBerkshelf <Boolean>
-ConfigurationManager_Name <String>
-CustomCookbooksSource_Password <String>
-CustomCookbooksSource_Revision <String>
-ServiceRoleArn <String>
-CustomCookbooksSource_SshKey <String>
-CustomCookbooksSource_Type <SourceType>
-CustomCookbooksSource_Url <String>
-UseCustomCookbook <Boolean>
-UseOpsworksSecurityGroup <Boolean>
-CustomCookbooksSource_Username <String>
-ConfigurationManager_Version <String>
-VpcId <String>
-Select <String>
-PassThru <SwitchParameter>
-Force <SwitchParameter>
-ClientConfig <AmazonOpsWorksConfig>

Description

Creates a clone of a specified stack. For more information, see Clone a Stack. By default, all parameters are set to the values used by the parent stack. Required Permissions: To use this action, an IAM user must have an attached policy that explicitly grants permissions. For more information about user permissions, see Managing User Permissions.

Parameters

-AgentVersion <String>
The default AWS OpsWorks Stacks agent version. You have the following options:
  • Auto-update - Set this parameter to LATEST. AWS OpsWorks Stacks automatically installs new agent versions on the stack's instances as soon as they are available.
  • Fixed version - Set this parameter to your preferred agent version. To update the agent version, you must edit the stack configuration and specify a new version. AWS OpsWorks Stacks then automatically installs that version on the stack's instances.
The default setting is LATEST. To specify an agent version, you must use the complete version number, not the abbreviated number shown on the console. For a list of available agent version numbers, call DescribeAgentVersions. AgentVersion cannot be set to Chef 12.2.You can also specify an agent version when you create or update an instance, which overrides the stack's default setting.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-Attribute <Hashtable>
A list of stack attributes and values as key/value pairs to be added to the cloned stack.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
AliasesAttributes
-ChefConfiguration_BerkshelfVersion <String>
The Berkshelf version.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-ChefConfiguration_ManageBerkshelf <Boolean>
Whether to enable Berkshelf.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-ClientConfig <AmazonOpsWorksConfig>
Amazon.PowerShell.Cmdlets.OPS.AmazonOpsWorksClientCmdlet.ClientConfig
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-CloneAppId <String[]>
A list of source stack app IDs to be included in the cloned stack.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
AliasesCloneAppIds
-ClonePermission <Boolean>
Whether to clone the source stack's permissions.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
AliasesClonePermissions
-ConfigurationManager_Name <String>
The name. This parameter must be set to "Chef".
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-ConfigurationManager_Version <String>
The Chef version. This parameter must be set to 12, 11.10, or 11.4 for Linux stacks, and to 12.2 for Windows stacks. The default value for Linux stacks is 11.4.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-CustomCookbooksSource_Password <String>
When included in a request, the parameter depends on the repository type.
  • For Amazon S3 bundles, set Password to the appropriate IAM secret access key.
  • For HTTP bundles and Subversion repositories, set Password to the password.
For more information on how to safely handle IAM credentials, see https://docs.aws.amazon.com/general/latest/gr/aws-access-keys-best-practices.html.In responses, AWS OpsWorks Stacks returns *****FILTERED***** instead of the actual value.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-CustomCookbooksSource_Revision <String>
The application's version. AWS OpsWorks Stacks enables you to easily deploy new versions of an application. One of the simplest approaches is to have branches or revisions in your repository that represent different versions that can potentially be deployed.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-CustomCookbooksSource_SshKey <String>
In requests, the repository's SSH key.In responses, AWS OpsWorks Stacks returns *****FILTERED***** instead of the actual value.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-CustomCookbooksSource_Type <SourceType>
The repository type.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-CustomCookbooksSource_Url <String>
The source URL. The following is an example of an Amazon S3 source URL: https://s3.amazonaws.com/opsworks-demo-bucket/opsworks_cookbook_demo.tar.gz.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-CustomCookbooksSource_Username <String>
This parameter depends on the repository type.
  • For Amazon S3 bundles, set Username to the appropriate IAM access key ID.
  • For HTTP bundles, Git repositories, and Subversion repositories, set Username to the user name.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-CustomJson <String>
A string that contains user-defined, custom JSON. It is used to override the corresponding default stack configuration JSON values. The string should be in the following format:"{\"key1\": \"value1\", \"key2\": \"value2\",...}"For more information about custom JSON, see Use Custom JSON to Modify the Stack Configuration Attributes
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-DefaultAvailabilityZone <String>
The cloned stack's default Availability Zone, which must be in the specified region. For more information, see Regions and Endpoints. If you also specify a value for DefaultSubnetId, the subnet must be in the same zone. For more information, see the VpcId parameter description.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-DefaultInstanceProfileArn <String>
The Amazon Resource Name (ARN) of an IAM profile that is the default profile for all of the stack's EC2 instances. For more information about IAM ARNs, see Using Identifiers.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-DefaultOs <String>
The stack's operating system, which must be set to one of the following.
  • A supported Linux operating system: An Amazon Linux version, such as Amazon Linux 2018.03, Amazon Linux 2017.09, Amazon Linux 2017.03, Amazon Linux 2016.09, Amazon Linux 2016.03, Amazon Linux 2015.09, or Amazon Linux 2015.03.
  • A supported Ubuntu operating system, such as Ubuntu 16.04 LTS, Ubuntu 14.04 LTS, or Ubuntu 12.04 LTS.
  • CentOS Linux 7
  • Red Hat Enterprise Linux 7
  • Microsoft Windows Server 2012 R2 Base, Microsoft Windows Server 2012 R2 with SQL Server Express, Microsoft Windows Server 2012 R2 with SQL Server Standard, or Microsoft Windows Server 2012 R2 with SQL Server Web.
  • A custom AMI: Custom. You specify the custom AMI you want to use when you create instances. For more information about how to use custom AMIs with OpsWorks, see Using Custom AMIs.
The default option is the parent stack's operating system. For more information about supported operating systems, see AWS OpsWorks Stacks Operating Systems.You can specify a different Linux operating system for the cloned stack, but you cannot change from Linux to Windows or Windows to Linux.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-DefaultRootDeviceType <RootDeviceType>
The default root device type. This value is used by default for all instances in the cloned stack, but you can override it when you create an instance. For more information, see Storage for the Root Device.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-DefaultSshKeyName <String>
A default Amazon EC2 key pair name. The default value is none. If you specify a key pair name, AWS OpsWorks installs the public key on the instance and you can use the private key with an SSH client to log in to the instance. For more information, see Using SSH to Communicate with an Instance and Managing SSH Access. You can override this setting by specifying a different key pair, or no key pair, when you create an instance.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-DefaultSubnetId <String>
The stack's default VPC subnet ID. This parameter is required if you specify a value for the VpcId parameter. All instances are launched into this subnet unless you specify otherwise when you create the instance. If you also specify a value for DefaultAvailabilityZone, the subnet must be in that zone. For information on default values and when this parameter is required, see the VpcId parameter description.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
This parameter overrides confirmation prompts to force the cmdlet to continue its operation. This parameter should always be used with caution.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-HostnameTheme <String>
The stack's host name theme, with spaces are replaced by underscores. The theme is used to generate host names for the stack's instances. By default, HostnameTheme is set to Layer_Dependent, which creates host names by appending integers to the layer's short name. The other themes are:
  • Baked_Goods
  • Clouds
  • Europe_Cities
  • Fruits
  • Greek_Deities_and_Titans
  • Legendary_creatures_from_Japan
  • Planets_and_Moons
  • Roman_Deities
  • Scottish_Islands
  • US_Cities
  • Wild_Cats
To obtain a generated host name, call GetHostNameSuggestion, which returns a host name based on the current theme.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-Name <String>
The cloned stack name.
Required?False
Position?2
Accept pipeline input?True (ByPropertyName)
-PassThru <SwitchParameter>
Changes the cmdlet behavior to return the value passed to the SourceStackId parameter. The -PassThru parameter is deprecated, use -Select '^SourceStackId' instead. This parameter will be removed in a future version.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-Select <String>
Use the -Select parameter to control the cmdlet output. The default value is 'StackId'. Specifying -Select '*' will result in the cmdlet returning the whole service response (Amazon.OpsWorks.Model.CloneStackResponse). Specifying the name of a property of type Amazon.OpsWorks.Model.CloneStackResponse will result in that property being returned. Specifying -Select '^ParameterName' will result in the cmdlet returning the selected cmdlet parameter value.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-ServiceRoleArn <String>
The stack AWS Identity and Access Management (IAM) role, which allows AWS OpsWorks Stacks to work with AWS resources on your behalf. You must set this parameter to the Amazon Resource Name (ARN) for an existing IAM role. If you create a stack by using the AWS OpsWorks Stacks console, it creates the role for you. You can obtain an existing stack's IAM ARN programmatically by calling DescribePermissions. For more information about IAM ARNs, see Using Identifiers.You must set this parameter to a valid service role ARN or the action will fail; there is no default value. You can specify the source stack's service role ARN, if you prefer, but you must do so explicitly.
Required?True
Position?Named
Accept pipeline input?True (ByPropertyName)
-SourceStackId <String>
The source stack ID.
Required?True
Position?1
Accept pipeline input?True (ByValue, ByPropertyName)
-StackRegion <String>
The cloned stack AWS region, such as "ap-northeast-2". For more information about AWS regions, see Regions and Endpoints.
Required?False
Position?3
Accept pipeline input?True (ByPropertyName)
-UseCustomCookbook <Boolean>
Whether to use custom cookbooks.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
AliasesUseCustomCookbooks
-UseOpsworksSecurityGroup <Boolean>
Whether to associate the AWS OpsWorks Stacks built-in security groups with the stack's layers.AWS OpsWorks Stacks provides a standard set of built-in security groups, one for each layer, which are associated with layers by default. With UseOpsworksSecurityGroups you can instead provide your own custom security groups. UseOpsworksSecurityGroups has the following settings:
  • True - AWS OpsWorks Stacks automatically associates the appropriate built-in security group with each layer (default setting). You can associate additional security groups with a layer after you create it but you cannot delete the built-in security group.
  • False - AWS OpsWorks Stacks does not associate built-in security groups with layers. You must create appropriate Amazon Elastic Compute Cloud (Amazon EC2) security groups and associate a security group with each layer that you create. However, you can still manually associate a built-in security group with a layer on creation; custom security groups are required only for those layers that need custom settings.
For more information, see Create a New Stack.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
AliasesUseOpsworksSecurityGroups
-VpcId <String>
The ID of the VPC that the cloned stack is to be launched into. It must be in the specified region. All instances are launched into this VPC, and you cannot change the ID later.
  • If your account supports EC2 Classic, the default value is no VPC.
  • If your account does not support EC2 Classic, the default value is the default VPC for the specified region.
If the VPC ID corresponds to a default VPC and you have specified either the DefaultAvailabilityZone or the DefaultSubnetId parameter only, AWS OpsWorks Stacks infers the value of the other parameter. If you specify neither parameter, AWS OpsWorks Stacks sets these parameters to the first valid Availability Zone for the specified region and the corresponding default VPC subnet ID, respectively. If you specify a nondefault VPC ID, note the following:
  • It must belong to a VPC in your account that is in the specified region.
  • You must specify a value for DefaultSubnetId.
For more information about how to use AWS OpsWorks Stacks with a VPC, see Running a Stack in a VPC. For more information about default VPC and EC2 Classic, see Supported Platforms.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)

Common Credential and Region Parameters

-AccessKey <String>
The AWS access key for the user account. This can be a temporary access key if the corresponding session token is supplied to the -SessionToken parameter.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
AliasesAK
-Credential <AWSCredentials>
An AWSCredentials object instance containing access and secret key information, and optionally a token for session-based credentials.
Required?False
Position?Named
Accept pipeline input?True (ByValue, ByPropertyName)
-EndpointUrl <String>
The endpoint to make the call against.Note: This parameter is primarily for internal AWS use and is not required/should not be specified for normal usage. The cmdlets normally determine which endpoint to call based on the region specified to the -Region parameter or set as default in the shell (via Set-DefaultAWSRegion). Only specify this parameter if you must direct the call to a specific custom endpoint.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
-NetworkCredential <PSCredential>
Used with SAML-based authentication when ProfileName references a SAML role profile. Contains the network credentials to be supplied during authentication with the configured identity provider's endpoint. This parameter is not required if the user's default network identity can or should be used during authentication.
Required?False
Position?Named
Accept pipeline input?True (ByValue, ByPropertyName)
-ProfileLocation <String>
Used to specify the name and location of the ini-format credential file (shared with the AWS CLI and other AWS SDKs)If this optional parameter is omitted this cmdlet will search the encrypted credential file used by the AWS SDK for .NET and AWS Toolkit for Visual Studio first. If the profile is not found then the cmdlet will search in the ini-format credential file at the default location: (user's home directory)\.aws\credentials.If this parameter is specified then this cmdlet will only search the ini-format credential file at the location given.As the current folder can vary in a shell or during script execution it is advised that you use specify a fully qualified path instead of a relative path.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
AliasesAWSProfilesLocation, ProfilesLocation
-ProfileName <String>
The user-defined name of an AWS credentials or SAML-based role profile containing credential information. The profile is expected to be found in the secure credential file shared with the AWS SDK for .NET and AWS Toolkit for Visual Studio. You can also specify the name of a profile stored in the .ini-format credential file used with the AWS CLI and other AWS SDKs.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
AliasesStoredCredentials, AWSProfileName
-Region <Object>
The system name of an AWS region or an AWSRegion instance. This governs the endpoint that will be used when calling service operations. Note that the AWS resources referenced in a call are usually region-specific.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
AliasesRegionToCall
-SecretKey <String>
The AWS secret key for the user account. This can be a temporary secret key if the corresponding session token is supplied to the -SessionToken parameter.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
AliasesSK, SecretAccessKey
-SessionToken <String>
The session token if the access and secret keys are temporary session-based credentials.
Required?False
Position?Named
Accept pipeline input?True (ByPropertyName)
AliasesST

Outputs

This cmdlet returns a System.String object. The service call response (type Amazon.OpsWorks.Model.CloneStackResponse) can also be referenced from properties attached to the cmdlet entry in the $AWSHistory stack.

Supported Version

AWS Tools for PowerShell: 2.x.y.z