/*
* 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 cloudfront-2020-05-31.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.CloudFront.Model
{
///
/// A complex type that controls whether access logs are written for the distribution.
///
public partial class LoggingConfig
{
private string _bucket;
private bool? _enabled;
private bool? _includeCookies;
private string _prefix;
///
/// Empty constructor used to set properties independently even when a simple constructor is available
///
public LoggingConfig() { }
///
/// Instantiates LoggingConfig with the parameterized properties
///
/// The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com
.
/// An optional string that you want CloudFront to prefix to the access log filenames
for this distribution, for example, myprefix/
. If you want to enable logging, but you don't want to specify a prefix, you still must include an empty Prefix
element in the Logging
element.
public LoggingConfig(string bucket, string prefix)
{
_bucket = bucket;
_prefix = prefix;
}
///
/// Gets and sets the property Bucket.
///
/// The Amazon S3 bucket to store the access logs in, for example, myawslogbucket.s3.amazonaws.com
.
///
///
[AWSProperty(Required=true)]
public string Bucket
{
get { return this._bucket; }
set { this._bucket = value; }
}
// Check to see if Bucket property is set
internal bool IsSetBucket()
{
return this._bucket != null;
}
///
/// Gets and sets the property Enabled.
///
/// Specifies whether you want CloudFront to save access logs to an Amazon S3 bucket.
/// If you don't want to enable logging when you create a distribution or if you want
/// to disable logging for an existing distribution, specify false
for Enabled
,
/// and specify empty Bucket
and Prefix
elements. If you specify
/// false
for Enabled
but you specify values for Bucket
,
/// prefix
, and IncludeCookies
, the values are automatically
/// deleted.
///
///
[AWSProperty(Required=true)]
public bool Enabled
{
get { return this._enabled.GetValueOrDefault(); }
set { this._enabled = value; }
}
// Check to see if Enabled property is set
internal bool IsSetEnabled()
{
return this._enabled.HasValue;
}
///
/// Gets and sets the property IncludeCookies.
///
/// Specifies whether you want CloudFront to include cookies in access logs, specify true
/// for IncludeCookies
. If you choose to include cookies in logs, CloudFront
/// logs all cookies regardless of how you configure the cache behaviors for this distribution.
/// If you don't want to include cookies when you create a distribution or if you want
/// to disable include cookies for an existing distribution, specify false
/// for IncludeCookies
.
///
///
[AWSProperty(Required=true)]
public bool IncludeCookies
{
get { return this._includeCookies.GetValueOrDefault(); }
set { this._includeCookies = value; }
}
// Check to see if IncludeCookies property is set
internal bool IsSetIncludeCookies()
{
return this._includeCookies.HasValue;
}
///
/// Gets and sets the property Prefix.
///
/// An optional string that you want CloudFront to prefix to the access log filenames
/// for this distribution, for example, myprefix/
. If you want to enable
/// logging, but you don't want to specify a prefix, you still must include an empty Prefix
/// element in the Logging
element.
///
///
[AWSProperty(Required=true)]
public string Prefix
{
get { return this._prefix; }
set { this._prefix = value; }
}
// Check to see if Prefix property is set
internal bool IsSetPrefix()
{
return this._prefix != null;
}
}
}