/* * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). * You may not use this file except in compliance with the License. * A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either * express or implied. See the License for the specific language governing * permissions and limitations under the License. */ /* * Do not modify this file. This file is generated from the ec2-2016-11-15.normal.json service model. */ using System; using System.Collections.Generic; using System.Xml.Serialization; using System.Text; using System.IO; using System.Net; using Amazon.Runtime; using Amazon.Runtime.Internal; namespace Amazon.EC2.Model { /// /// Container for the parameters to the CopySnapshot operation. /// Copies a point-in-time snapshot of an EBS volume and stores it in Amazon S3. You can /// copy a snapshot within the same Region, from one Region to another, or from a Region /// to an Outpost. You can't copy a snapshot from an Outpost to a Region, from one Outpost /// to another, or within the same Outpost. /// /// /// /// You can use the snapshot to create EBS volumes or Amazon Machine Images (AMIs). /// /// /// /// When copying snapshots to a Region, copies of encrypted EBS snapshots remain encrypted. /// Copies of unencrypted snapshots remain unencrypted, unless you enable encryption for /// the snapshot copy operation. By default, encrypted snapshot copies use the default /// Key Management Service (KMS) KMS key; however, you can specify a different KMS key. /// To copy an encrypted snapshot that has been shared from another account, you must /// have permissions for the KMS key used to encrypt the snapshot. /// /// /// /// Snapshots copied to an Outpost are encrypted by default using the default encryption /// key for the Region, or a different key that you specify in the request using KmsKeyId. /// Outposts do not support unencrypted snapshots. For more information, /// Amazon EBS local snapshots on Outposts in the Amazon Elastic Compute Cloud /// User Guide. /// /// /// /// Snapshots created by copying another snapshot have an arbitrary volume ID that should /// not be used for any purpose. /// /// /// /// For more information, see Copy /// an Amazon EBS snapshot in the Amazon Elastic Compute Cloud User Guide. /// /// public partial class CopySnapshotRequest : AmazonEC2Request { private string _description; private string _destinationOutpostArn; private string _destinationRegion; private bool? _encrypted; private string _kmsKeyId; private string _presignedUrl; private string _sourceRegion; private string _sourceSnapshotId; private List _tagSpecifications = new List(); /// /// Gets and sets the property Description. /// /// A description for the EBS snapshot. /// /// public string Description { get { return this._description; } set { this._description = value; } } // Check to see if Description property is set internal bool IsSetDescription() { return this._description != null; } /// /// Gets and sets the property DestinationOutpostArn. /// /// The Amazon Resource Name (ARN) of the Outpost to which to copy the snapshot. Only /// specify this parameter when copying a snapshot from an Amazon Web Services Region /// to an Outpost. The snapshot must be in the Region for the destination Outpost. You /// cannot copy a snapshot from an Outpost to a Region, from one Outpost to another, or /// within the same Outpost. /// /// /// /// For more information, see /// Copy snapshots from an Amazon Web Services Region to an Outpost in the Amazon /// Elastic Compute Cloud User Guide. /// /// public string DestinationOutpostArn { get { return this._destinationOutpostArn; } set { this._destinationOutpostArn = value; } } // Check to see if DestinationOutpostArn property is set internal bool IsSetDestinationOutpostArn() { return this._destinationOutpostArn != null; } /// /// Gets and sets the property DestinationRegion. /// /// The destination Region to use in the PresignedUrl parameter of a snapshot /// copy operation. This parameter is only valid for specifying the destination Region /// in a PresignedUrl parameter, where it is required. /// /// /// /// The snapshot copy is sent to the regional endpoint that you sent the HTTP request /// to (for example, ec2.us-east-1.amazonaws.com). With the CLI, this is /// specified using the --region parameter or the default Region in your /// Amazon Web Services configuration file. /// /// public string DestinationRegion { get { return this._destinationRegion; } set { this._destinationRegion = value; } } // Check to see if DestinationRegion property is set internal bool IsSetDestinationRegion() { return this._destinationRegion != null; } /// /// Gets and sets the property Encrypted. /// /// To encrypt a copy of an unencrypted snapshot if encryption by default is not enabled, /// enable encryption using this parameter. Otherwise, omit this parameter. Encrypted /// snapshots are encrypted, even if you omit this parameter and encryption by default /// is not enabled. You cannot set this parameter to false. For more information, see /// Amazon /// EBS encryption in the Amazon Elastic Compute Cloud User Guide. /// /// public bool Encrypted { get { return this._encrypted.GetValueOrDefault(); } set { this._encrypted = value; } } // Check to see if Encrypted property is set internal bool IsSetEncrypted() { return this._encrypted.HasValue; } /// /// Gets and sets the property KmsKeyId. /// /// The identifier of the Key Management Service (KMS) KMS key to use for Amazon EBS encryption. /// If this parameter is not specified, your KMS key for Amazon EBS is used. If KmsKeyId /// is specified, the encrypted state must be true. /// /// /// /// You can specify the KMS key using any of the following: /// ///
  • /// /// Key ID. For example, 1234abcd-12ab-34cd-56ef-1234567890ab. /// ///
  • /// /// Key alias. For example, alias/ExampleAlias. /// ///
  • /// /// Key ARN. For example, arn:aws:kms:us-east-1:012345678910:key/1234abcd-12ab-34cd-56ef-1234567890ab. /// ///
  • /// /// Alias ARN. For example, arn:aws:kms:us-east-1:012345678910:alias/ExampleAlias. /// ///
/// /// Amazon Web Services authenticates the KMS key asynchronously. Therefore, if you specify /// an ID, alias, or ARN that is not valid, the action can appear to complete, but eventually /// fails. /// ///
public string KmsKeyId { get { return this._kmsKeyId; } set { this._kmsKeyId = value; } } // Check to see if KmsKeyId property is set internal bool IsSetKmsKeyId() { return this._kmsKeyId != null; } /// /// Gets and sets the property PresignedUrl. /// /// When you copy an encrypted source snapshot using the Amazon EC2 Query API, you must /// supply a pre-signed URL. This parameter is optional for unencrypted snapshots. For /// more information, see Query /// requests. /// /// /// /// The PresignedUrl should use the snapshot source endpoint, the CopySnapshot /// action, and include the SourceRegion, SourceSnapshotId, /// and DestinationRegion parameters. The PresignedUrl must /// be signed using Amazon Web Services Signature Version 4. Because EBS snapshots are /// stored in Amazon S3, the signing algorithm for this parameter uses the same logic /// that is described in Authenticating /// Requests: Using Query Parameters (Amazon Web Services Signature Version 4) in /// the Amazon Simple Storage Service API Reference. An invalid or improperly signed /// PresignedUrl will cause the copy operation to fail asynchronously, and /// the snapshot will move to an error state. /// /// [AWSProperty(Sensitive=true)] internal string PresignedUrl { get { return this._presignedUrl; } set { this._presignedUrl = value; } } // Check to see if PresignedUrl property is set internal bool IsSetPresignedUrl() { return this._presignedUrl != null; } /// /// Gets and sets the property SourceRegion. /// /// The ID of the Region that contains the snapshot to be copied. /// /// [AWSProperty(Required=true)] public string SourceRegion { get { return this._sourceRegion; } set { this._sourceRegion = value; } } // Check to see if SourceRegion property is set internal bool IsSetSourceRegion() { return this._sourceRegion != null; } /// /// Gets and sets the property SourceSnapshotId. /// /// The ID of the EBS snapshot to copy. /// /// [AWSProperty(Required=true)] public string SourceSnapshotId { get { return this._sourceSnapshotId; } set { this._sourceSnapshotId = value; } } // Check to see if SourceSnapshotId property is set internal bool IsSetSourceSnapshotId() { return this._sourceSnapshotId != null; } /// /// Gets and sets the property TagSpecifications. /// /// The tags to apply to the new snapshot. /// /// public List TagSpecifications { get { return this._tagSpecifications; } set { this._tagSpecifications = value; } } // Check to see if TagSpecifications property is set internal bool IsSetTagSpecifications() { return this._tagSpecifications != null && this._tagSpecifications.Count > 0; } } }