/*
* 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 CreateTransitGatewayVpcAttachment operation.
/// Attaches the specified VPC to the specified transit gateway.
///
///
///
/// If you attach a VPC with a CIDR range that overlaps the CIDR range of a VPC that is
/// already attached, the new VPC CIDR range is not propagated to the default propagation
/// route table.
///
///
///
/// To send VPC traffic to an attached transit gateway, add a route to the VPC route table
/// using CreateRoute.
///
///
public partial class CreateTransitGatewayVpcAttachmentRequest : AmazonEC2Request
{
private CreateTransitGatewayVpcAttachmentRequestOptions _options;
private List _subnetIds = new List();
private List _tagSpecifications = new List();
private string _transitGatewayId;
private string _vpcId;
///
/// Gets and sets the property Options.
///
/// The VPC attachment options.
///
///
public CreateTransitGatewayVpcAttachmentRequestOptions Options
{
get { return this._options; }
set { this._options = value; }
}
// Check to see if Options property is set
internal bool IsSetOptions()
{
return this._options != null;
}
///
/// Gets and sets the property SubnetIds.
///
/// The IDs of one or more subnets. You can specify only one subnet per Availability Zone.
/// You must specify at least one subnet, but we recommend that you specify two subnets
/// for better availability. The transit gateway uses one IP address from each specified
/// subnet.
///
///
[AWSProperty(Required=true)]
public List SubnetIds
{
get { return this._subnetIds; }
set { this._subnetIds = value; }
}
// Check to see if SubnetIds property is set
internal bool IsSetSubnetIds()
{
return this._subnetIds != null && this._subnetIds.Count > 0;
}
///
/// Gets and sets the property TagSpecifications.
///
/// The tags to apply to the VPC attachment.
///
///
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;
}
///
/// Gets and sets the property TransitGatewayId.
///
/// The ID of the transit gateway.
///
///
[AWSProperty(Required=true)]
public string TransitGatewayId
{
get { return this._transitGatewayId; }
set { this._transitGatewayId = value; }
}
// Check to see if TransitGatewayId property is set
internal bool IsSetTransitGatewayId()
{
return this._transitGatewayId != null;
}
///
/// Gets and sets the property VpcId.
///
/// The ID of the VPC.
///
///
[AWSProperty(Required=true)]
public string VpcId
{
get { return this._vpcId; }
set { this._vpcId = value; }
}
// Check to see if VpcId property is set
internal bool IsSetVpcId()
{
return this._vpcId != null;
}
}
}