/*
 * 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 lightsail-2016-11-28.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.Lightsail.Model
{
    /// 
    /// Container for the parameters to the CreateDisk operation.
    /// Creates a block storage disk that can be attached to an Amazon Lightsail instance
    /// in the same Availability Zone (e.g., us-east-2a).
    /// 
    ///  
    /// 
    /// The create disk operation supports tag-based access control via request
    /// tags. For more information, see the Amazon
    /// Lightsail Developer Guide.
    /// 
    /// 
    public partial class CreateDiskRequest : AmazonLightsailRequest
    {
        private List _addOns = new List();
        private string _availabilityZone;
        private string _diskName;
        private int? _sizeInGb;
        private List _tags = new List();
        /// 
        /// Gets and sets the property AddOns. 
        /// 
        /// An array of objects that represent the add-ons to enable for the new disk.
        /// 
        /// 
        public List AddOns
        {
            get { return this._addOns; }
            set { this._addOns = value; }
        }
        // Check to see if AddOns property is set
        internal bool IsSetAddOns()
        {
            return this._addOns != null && this._addOns.Count > 0; 
        }
        /// 
        /// Gets and sets the property AvailabilityZone. 
        /// 
        /// The Availability Zone where you want to create the disk (e.g., us-east-2a).
        /// Use the same Availability Zone as the Lightsail instance to which you want to attach
        /// the disk.
        /// 
        ///  
        /// 
        /// Use the get regions operation to list the Availability Zones where Lightsail
        /// is currently available.
        /// 
        /// 
        [AWSProperty(Required=true)]
        public string AvailabilityZone
        {
            get { return this._availabilityZone; }
            set { this._availabilityZone = value; }
        }
        // Check to see if AvailabilityZone property is set
        internal bool IsSetAvailabilityZone()
        {
            return this._availabilityZone != null;
        }
        /// 
        /// Gets and sets the property DiskName. 
        /// 
        /// The unique Lightsail disk name (e.g., my-disk).
        /// 
        /// 
        [AWSProperty(Required=true)]
        public string DiskName
        {
            get { return this._diskName; }
            set { this._diskName = value; }
        }
        // Check to see if DiskName property is set
        internal bool IsSetDiskName()
        {
            return this._diskName != null;
        }
        /// 
        /// Gets and sets the property SizeInGb. 
        /// 
        /// The size of the disk in GB (e.g., 32).
        /// 
        /// 
        [AWSProperty(Required=true)]
        public int SizeInGb
        {
            get { return this._sizeInGb.GetValueOrDefault(); }
            set { this._sizeInGb = value; }
        }
        // Check to see if SizeInGb property is set
        internal bool IsSetSizeInGb()
        {
            return this._sizeInGb.HasValue; 
        }
        /// 
        /// Gets and sets the property Tags. 
        /// 
        /// The tag keys and optional values to add to the resource during create.
        /// 
        ///  
        /// 
        /// Use the TagResource action to tag a resource after it's created.
        /// 
        /// 
        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; 
        }
    }
}