/*
* 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 CreateResolverQueryLogConfig operation.
/// Creates a Resolver query logging configuration, which defines where you want Resolver
/// to save DNS query logs that originate in your VPCs. Resolver can log queries only
/// for VPCs that are in the same Region as the query logging configuration.
///
///
///
/// To specify which VPCs you want to log queries for, you use AssociateResolverQueryLogConfig
.
/// For more information, see AssociateResolverQueryLogConfig.
///
///
///
///
/// You can optionally use Resource Access Manager (RAM) to share a query logging configuration
/// with other Amazon Web Services accounts. The other accounts can then associate VPCs
/// with the configuration. The query logs that Resolver creates for a configuration include
/// all DNS queries that originate in all VPCs that are associated with the configuration.
///
///
public partial class CreateResolverQueryLogConfigRequest : AmazonRoute53ResolverRequest
{
private string _creatorRequestId;
private string _destinationArn;
private string _name;
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(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 DestinationArn.
///
/// The ARN of the resource that you want Resolver to send query logs. You can send query
/// logs to an S3 bucket, a CloudWatch Logs log group, or a Kinesis Data Firehose delivery
/// stream. Examples of valid values include the following:
///
/// -
///
/// S3 bucket:
///
///
///
///
arn:aws:s3:::examplebucket
///
///
///
/// You can optionally append a file prefix to the end of the ARN.
///
///
///
/// arn:aws:s3:::examplebucket/development/
///
/// -
///
/// CloudWatch Logs log group:
///
///
///
///
arn:aws:logs:us-west-1:123456789012:log-group:/mystack-testgroup-12ABC1AB12A1:*
///
///
/// -
///
/// Kinesis Data Firehose delivery stream:
///
///
///
///
arn:aws:kinesis:us-east-2:0123456789:stream/my_stream_name
///
///
///
[AWSProperty(Required=true, Min=1, Max=600)]
public string DestinationArn
{
get { return this._destinationArn; }
set { this._destinationArn = value; }
}
// Check to see if DestinationArn property is set
internal bool IsSetDestinationArn()
{
return this._destinationArn != null;
}
///
/// Gets and sets the property Name.
///
/// The name that you want to give the query logging configuration.
///
///
[AWSProperty(Required=true, Min=1, Max=64)]
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 Tags.
///
/// A list of the tag keys and values that you want to associate with the query logging
/// configuration.
///
///
[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;
}
}
}