﻿/**
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * SPDX-License-Identifier: Apache-2.0.
 */

#pragma once
#include <aws/s3/S3_EXPORTS.h>

namespace Aws {
namespace Utils {
namespace Xml {
class XmlNode;
}  // namespace Xml
}  // namespace Utils
namespace S3 {
namespace Model {

/**
 * <p>Specifies when noncurrent object versions expire. Upon expiration, Amazon S3
 * permanently deletes the noncurrent object versions. You set this lifecycle
 * configuration action on a bucket that has versioning enabled (or suspended) to
 * request that Amazon S3 delete noncurrent object versions at a specific period in
 * the object's lifetime.</p>  <p>This parameter applies to general purpose
 * buckets only. It is not supported for directory bucket lifecycle
 * configurations.</p> <p><h3>See Also:</h3>   <a
 * href="http://docs.aws.amazon.com/goto/WebAPI/s3-2006-03-01/NoncurrentVersionExpiration">AWS
 * API Reference</a></p>
 */
class NoncurrentVersionExpiration {
 public:
  AWS_S3_API NoncurrentVersionExpiration() = default;
  AWS_S3_API NoncurrentVersionExpiration(const Aws::Utils::Xml::XmlNode& xmlNode);
  AWS_S3_API NoncurrentVersionExpiration& operator=(const Aws::Utils::Xml::XmlNode& xmlNode);

  AWS_S3_API void AddToNode(Aws::Utils::Xml::XmlNode& parentNode) const;

  ///@{
  /**
   * <p>Specifies the number of days an object is noncurrent before Amazon S3 can
   * perform the associated action. The value must be a non-zero positive integer.
   * For information about the noncurrent days calculations, see <a
   * href="https://docs.aws.amazon.com/AmazonS3/latest/dev/intro-lifecycle-rules.html#non-current-days-calculations">How
   * Amazon S3 Calculates When an Object Became Noncurrent</a> in the <i>Amazon S3
   * User Guide</i>.</p>  <p>This parameter applies to general purpose buckets
   * only. It is not supported for directory bucket lifecycle configurations.</p>
   *
   */
  inline int GetNoncurrentDays() const { return m_noncurrentDays; }
  inline bool NoncurrentDaysHasBeenSet() const { return m_noncurrentDaysHasBeenSet; }
  inline void SetNoncurrentDays(int value) {
    m_noncurrentDaysHasBeenSet = true;
    m_noncurrentDays = value;
  }
  inline NoncurrentVersionExpiration& WithNoncurrentDays(int value) {
    SetNoncurrentDays(value);
    return *this;
  }
  ///@}

  ///@{
  /**
   * <p>Specifies how many noncurrent versions Amazon S3 will retain. You can specify
   * up to 100 noncurrent versions to retain. Amazon S3 will permanently delete any
   * additional noncurrent versions beyond the specified number to retain. For more
   * information about noncurrent versions, see <a
   * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/intro-lifecycle-rules.html">Lifecycle
   * configuration elements</a> in the <i>Amazon S3 User Guide</i>.</p>
   * <p>This parameter applies to general purpose buckets only. It is not supported
   * for directory bucket lifecycle configurations.</p>
   */
  inline int GetNewerNoncurrentVersions() const { return m_newerNoncurrentVersions; }
  inline bool NewerNoncurrentVersionsHasBeenSet() const { return m_newerNoncurrentVersionsHasBeenSet; }
  inline void SetNewerNoncurrentVersions(int value) {
    m_newerNoncurrentVersionsHasBeenSet = true;
    m_newerNoncurrentVersions = value;
  }
  inline NoncurrentVersionExpiration& WithNewerNoncurrentVersions(int value) {
    SetNewerNoncurrentVersions(value);
    return *this;
  }
  ///@}
 private:
  int m_noncurrentDays{0};

  int m_newerNoncurrentVersions{0};
  bool m_noncurrentDaysHasBeenSet = false;
  bool m_newerNoncurrentVersionsHasBeenSet = false;
};

}  // namespace Model
}  // namespace S3
}  // namespace Aws
