/*
* 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 dlm-2018-01-12.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.DLM.Model
{
///
/// [Snapshot and AMI policies only] Specifies a retention rule for snapshots
/// created by snapshot policies, or for AMIs created by AMI policies.
///
///
///
/// For snapshot policies that have an ArchiveRule, this retention rule applies
/// to standard tier retention. When the retention threshold is met, snapshots are moved
/// from the standard to the archive tier.
///
///
///
/// For snapshot policies that do not have an ArchiveRule, snapshots are permanently
/// deleted when this retention threshold is met.
///
///
///
/// You can retain snapshots based on either a count or a time interval.
///
/// -
///
/// Count-based retention
///
///
///
/// You must specify Count. If you specify an ArchiveRule for the schedule,
/// then you can specify a retention count of
0
to archive snapshots immediately
/// after creation. If you specify a FastRestoreRule, ShareRule, or a CrossRegionCopyRule,
/// then you must specify a retention count of 1
or more.
///
/// -
///
/// Age-based retention
///
///
///
/// You must specify Interval and IntervalUnit. If you specify an ArchiveRule
/// for the schedule, then you can specify a retention interval of
0
days
/// to archive snapshots immediately after creation. If you specify a FastRestoreRule,
/// ShareRule, or a CrossRegionCopyRule, then you must specify a retention
/// interval of 1
day or more.
///
///
///
public partial class RetainRule
{
private int? _count;
private int? _interval;
private RetentionIntervalUnitValues _intervalUnit;
///
/// Gets and sets the property Count.
///
/// The number of snapshots to retain for each volume, up to a maximum of 1000. For example
/// if you want to retain a maximum of three snapshots, specify 3
. When the
/// fourth snapshot is created, the oldest retained snapshot is deleted, or it is moved
/// to the archive tier if you have specified an ArchiveRule.
///
///
[AWSProperty(Min=0, Max=1000)]
public int Count
{
get { return this._count.GetValueOrDefault(); }
set { this._count = value; }
}
// Check to see if Count property is set
internal bool IsSetCount()
{
return this._count.HasValue;
}
///
/// Gets and sets the property Interval.
///
/// The amount of time to retain each snapshot. The maximum is 100 years. This is equivalent
/// to 1200 months, 5200 weeks, or 36500 days.
///
///
[AWSProperty(Min=0)]
public int Interval
{
get { return this._interval.GetValueOrDefault(); }
set { this._interval = value; }
}
// Check to see if Interval property is set
internal bool IsSetInterval()
{
return this._interval.HasValue;
}
///
/// Gets and sets the property IntervalUnit.
///
/// The unit of time for time-based retention. For example, to retain snapshots for 3
/// months, specify Interval=3
and IntervalUnit=MONTHS
. Once
/// the snapshot has been retained for 3 months, it is deleted, or it is moved to the
/// archive tier if you have specified an ArchiveRule.
///
///
public RetentionIntervalUnitValues IntervalUnit
{
get { return this._intervalUnit; }
set { this._intervalUnit = value; }
}
// Check to see if IntervalUnit property is set
internal bool IsSetIntervalUnit()
{
return this._intervalUnit != null;
}
}
}