/* * 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 storagegateway-2013-06-30.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.StorageGateway.Model { /// /// Container for the parameters to the CreateSnapshot operation. /// Initiates a snapshot of a volume. /// /// /// /// Storage Gateway provides the ability to back up point-in-time snapshots of your data /// to Amazon Simple Storage (Amazon S3) for durable off-site recovery, and also import /// the data to an Amazon Elastic Block Store (EBS) volume in Amazon Elastic Compute Cloud /// (EC2). You can take snapshots of your gateway volume on a scheduled or ad hoc basis. /// This API enables you to take an ad hoc snapshot. For more information, see Editing /// a snapshot schedule. /// /// /// /// In the CreateSnapshot request, you identify the volume by providing its /// Amazon Resource Name (ARN). You must also provide description for the snapshot. When /// Storage Gateway takes the snapshot of specified volume, the snapshot and description /// appears in the Storage Gateway console. In response, Storage Gateway returns you a /// snapshot ID. You can use this snapshot ID to check the snapshot progress or later /// use it when you want to create a volume from a snapshot. This operation is only supported /// in stored and cached volume gateway type. /// /// /// /// To list or delete a snapshot, you must use the Amazon EC2 API. For more information, /// see DescribeSnapshots /// or DeleteSnapshot /// in the Amazon Elastic Compute Cloud API Reference. /// /// /// /// Volume and snapshot IDs are changing to a longer length ID format. For more information, /// see the important note on the Welcome /// page. /// /// /// public partial class CreateSnapshotRequest : AmazonStorageGatewayRequest { private string _snapshotDescription; private List _tags = new List(); private string _volumeARN; /// /// Gets and sets the property SnapshotDescription. /// /// Textual description of the snapshot that appears in the Amazon EC2 console, Elastic /// Block Store snapshots panel in the Description field, and in the Storage Gateway /// snapshot Details pane, Description field. /// /// [AWSProperty(Required=true, Min=1, Max=255)] public string SnapshotDescription { get { return this._snapshotDescription; } set { this._snapshotDescription = value; } } // Check to see if SnapshotDescription property is set internal bool IsSetSnapshotDescription() { return this._snapshotDescription != null; } /// /// Gets and sets the property Tags. /// /// A list of up to 50 tags that can be assigned to a snapshot. Each tag is a key-value /// pair. /// /// /// /// Valid characters for key and value are letters, spaces, and numbers representable /// in UTF-8 format, and the following special characters: + - = . _ : / @. The maximum /// length of a tag's key is 128 characters, and the maximum length for a tag's value /// is 256. /// /// /// public List Tags { get { return this._tags; } set { this._tags = value; } } // Check to see if Tags property is set internal bool IsSetTags() { return this._tags != null && this._tags.Count > 0; } /// /// Gets and sets the property VolumeARN. /// /// The Amazon Resource Name (ARN) of the volume. Use the ListVolumes operation /// to return a list of gateway volumes. /// /// [AWSProperty(Required=true, Min=50, Max=500)] public string VolumeARN { get { return this._volumeARN; } set { this._volumeARN = value; } } // Check to see if VolumeARN property is set internal bool IsSetVolumeARN() { return this._volumeARN != null; } } }