/*
* 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 events-2015-10-07.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.CloudWatchEvents.Model
{
///
/// An Archive
object that contains details about an archive.
///
public partial class Archive
{
private string _archiveName;
private DateTime? _creationTime;
private long? _eventCount;
private string _eventSourceArn;
private int? _retentionDays;
private long? _sizeBytes;
private ArchiveState _state;
private string _stateReason;
///
/// Gets and sets the property ArchiveName.
///
/// The name of the archive.
///
///
[AWSProperty(Min=1, Max=48)]
public string ArchiveName
{
get { return this._archiveName; }
set { this._archiveName = value; }
}
// Check to see if ArchiveName property is set
internal bool IsSetArchiveName()
{
return this._archiveName != null;
}
///
/// Gets and sets the property CreationTime.
///
/// The time stamp for the time that the archive was created.
///
///
public DateTime CreationTime
{
get { return this._creationTime.GetValueOrDefault(); }
set { this._creationTime = value; }
}
// Check to see if CreationTime property is set
internal bool IsSetCreationTime()
{
return this._creationTime.HasValue;
}
///
/// Gets and sets the property EventCount.
///
/// The number of events in the archive.
///
///
public long EventCount
{
get { return this._eventCount.GetValueOrDefault(); }
set { this._eventCount = value; }
}
// Check to see if EventCount property is set
internal bool IsSetEventCount()
{
return this._eventCount.HasValue;
}
///
/// Gets and sets the property EventSourceArn.
///
/// The ARN of the event bus associated with the archive. Only events from this event
/// bus are sent to the archive.
///
///
[AWSProperty(Min=1, Max=1600)]
public string EventSourceArn
{
get { return this._eventSourceArn; }
set { this._eventSourceArn = value; }
}
// Check to see if EventSourceArn property is set
internal bool IsSetEventSourceArn()
{
return this._eventSourceArn != null;
}
///
/// Gets and sets the property RetentionDays.
///
/// The number of days to retain events in the archive before they are deleted.
///
///
[AWSProperty(Min=0)]
public int RetentionDays
{
get { return this._retentionDays.GetValueOrDefault(); }
set { this._retentionDays = value; }
}
// Check to see if RetentionDays property is set
internal bool IsSetRetentionDays()
{
return this._retentionDays.HasValue;
}
///
/// Gets and sets the property SizeBytes.
///
/// The size of the archive, in bytes.
///
///
public long SizeBytes
{
get { return this._sizeBytes.GetValueOrDefault(); }
set { this._sizeBytes = value; }
}
// Check to see if SizeBytes property is set
internal bool IsSetSizeBytes()
{
return this._sizeBytes.HasValue;
}
///
/// Gets and sets the property State.
///
/// The current state of the archive.
///
///
public ArchiveState State
{
get { return this._state; }
set { this._state = value; }
}
// Check to see if State property is set
internal bool IsSetState()
{
return this._state != null;
}
///
/// Gets and sets the property StateReason.
///
/// A description for the reason that the archive is in the current state.
///
///
[AWSProperty(Max=512)]
public string StateReason
{
get { return this._stateReason; }
set { this._stateReason = value; }
}
// Check to see if StateReason property is set
internal bool IsSetStateReason()
{
return this._stateReason != null;
}
}
}