/*
* 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 route53resolver-2018-04-01.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.Route53Resolver.Model
{
///
/// Container for the parameters to the CreateOutpostResolver operation.
/// Creates an Route 53 Resolver on an Outpost.
///
public partial class CreateOutpostResolverRequest : AmazonRoute53ResolverRequest
{
private string _creatorRequestId;
private int? _instanceCount;
private string _name;
private string _outpostArn;
private string _preferredInstanceType;
private List _tags = new List();
///
/// Gets and sets the property CreatorRequestId.
///
/// A unique string that identifies the request and that allows failed requests to be
/// retried without the risk of running the operation twice.
///
///
///
/// CreatorRequestId
can be any unique string, for example, a date/time
/// stamp.
///
///
[AWSProperty(Required=true, Min=1, Max=255)]
public string CreatorRequestId
{
get { return this._creatorRequestId; }
set { this._creatorRequestId = value; }
}
// Check to see if CreatorRequestId property is set
internal bool IsSetCreatorRequestId()
{
return this._creatorRequestId != null;
}
///
/// Gets and sets the property InstanceCount.
///
/// Number of Amazon EC2 instances for the Resolver on Outpost. The default and minimal
/// value is 4.
///
///
public int InstanceCount
{
get { return this._instanceCount.GetValueOrDefault(); }
set { this._instanceCount = value; }
}
// Check to see if InstanceCount property is set
internal bool IsSetInstanceCount()
{
return this._instanceCount.HasValue;
}
///
/// Gets and sets the property Name.
///
/// A friendly name that lets you easily find a configuration in the Resolver dashboard
/// in the Route 53 console.
///
///
[AWSProperty(Required=true, Min=1, Max=255)]
public string Name
{
get { return this._name; }
set { this._name = value; }
}
// Check to see if Name property is set
internal bool IsSetName()
{
return this._name != null;
}
///
/// Gets and sets the property OutpostArn.
///
/// The Amazon Resource Name (ARN) of the Outpost. If you specify this, you must also
/// specify a value for the PreferredInstanceType
.
///
///
[AWSProperty(Required=true, Min=1, Max=255)]
public string OutpostArn
{
get { return this._outpostArn; }
set { this._outpostArn = value; }
}
// Check to see if OutpostArn property is set
internal bool IsSetOutpostArn()
{
return this._outpostArn != null;
}
///
/// Gets and sets the property PreferredInstanceType.
///
/// The Amazon EC2 instance type. If you specify this, you must also specify a value
/// for the OutpostArn
.
///
///
[AWSProperty(Required=true, Min=1, Max=255)]
public string PreferredInstanceType
{
get { return this._preferredInstanceType; }
set { this._preferredInstanceType = value; }
}
// Check to see if PreferredInstanceType property is set
internal bool IsSetPreferredInstanceType()
{
return this._preferredInstanceType != null;
}
///
/// Gets and sets the property Tags.
///
/// A string that helps identify the Route 53 Resolvers on Outpost.
///
///
[AWSProperty(Max=200)]
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;
}
}
}