/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include namespace Aws { namespace Utils { namespace Xml { class XmlNode; } // namespace Xml } // namespace Utils namespace S3Crt { namespace Model { /** *

Specifies encryption-related information for an Amazon S3 bucket that is a * destination for replicated objects.

See Also:

AWS * API Reference

*/ class EncryptionConfiguration { public: AWS_S3CRT_API EncryptionConfiguration(); AWS_S3CRT_API EncryptionConfiguration(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_S3CRT_API EncryptionConfiguration& operator=(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_S3CRT_API void AddToNode(Aws::Utils::Xml::XmlNode& parentNode) const; /** *

Specifies the ID (Key ARN or Alias ARN) of the customer managed Amazon Web * Services KMS key stored in Amazon Web Services Key Management Service (KMS) for * the destination bucket. Amazon S3 uses this key to encrypt replica objects. * Amazon S3 only supports symmetric encryption KMS keys. For more information, see * Asymmetric * keys in Amazon Web Services KMS in the Amazon Web Services Key Management * Service Developer Guide.

*/ inline const Aws::String& GetReplicaKmsKeyID() const{ return m_replicaKmsKeyID; } /** *

Specifies the ID (Key ARN or Alias ARN) of the customer managed Amazon Web * Services KMS key stored in Amazon Web Services Key Management Service (KMS) for * the destination bucket. Amazon S3 uses this key to encrypt replica objects. * Amazon S3 only supports symmetric encryption KMS keys. For more information, see * Asymmetric * keys in Amazon Web Services KMS in the Amazon Web Services Key Management * Service Developer Guide.

*/ inline bool ReplicaKmsKeyIDHasBeenSet() const { return m_replicaKmsKeyIDHasBeenSet; } /** *

Specifies the ID (Key ARN or Alias ARN) of the customer managed Amazon Web * Services KMS key stored in Amazon Web Services Key Management Service (KMS) for * the destination bucket. Amazon S3 uses this key to encrypt replica objects. * Amazon S3 only supports symmetric encryption KMS keys. For more information, see * Asymmetric * keys in Amazon Web Services KMS in the Amazon Web Services Key Management * Service Developer Guide.

*/ inline void SetReplicaKmsKeyID(const Aws::String& value) { m_replicaKmsKeyIDHasBeenSet = true; m_replicaKmsKeyID = value; } /** *

Specifies the ID (Key ARN or Alias ARN) of the customer managed Amazon Web * Services KMS key stored in Amazon Web Services Key Management Service (KMS) for * the destination bucket. Amazon S3 uses this key to encrypt replica objects. * Amazon S3 only supports symmetric encryption KMS keys. For more information, see * Asymmetric * keys in Amazon Web Services KMS in the Amazon Web Services Key Management * Service Developer Guide.

*/ inline void SetReplicaKmsKeyID(Aws::String&& value) { m_replicaKmsKeyIDHasBeenSet = true; m_replicaKmsKeyID = std::move(value); } /** *

Specifies the ID (Key ARN or Alias ARN) of the customer managed Amazon Web * Services KMS key stored in Amazon Web Services Key Management Service (KMS) for * the destination bucket. Amazon S3 uses this key to encrypt replica objects. * Amazon S3 only supports symmetric encryption KMS keys. For more information, see * Asymmetric * keys in Amazon Web Services KMS in the Amazon Web Services Key Management * Service Developer Guide.

*/ inline void SetReplicaKmsKeyID(const char* value) { m_replicaKmsKeyIDHasBeenSet = true; m_replicaKmsKeyID.assign(value); } /** *

Specifies the ID (Key ARN or Alias ARN) of the customer managed Amazon Web * Services KMS key stored in Amazon Web Services Key Management Service (KMS) for * the destination bucket. Amazon S3 uses this key to encrypt replica objects. * Amazon S3 only supports symmetric encryption KMS keys. For more information, see * Asymmetric * keys in Amazon Web Services KMS in the Amazon Web Services Key Management * Service Developer Guide.

*/ inline EncryptionConfiguration& WithReplicaKmsKeyID(const Aws::String& value) { SetReplicaKmsKeyID(value); return *this;} /** *

Specifies the ID (Key ARN or Alias ARN) of the customer managed Amazon Web * Services KMS key stored in Amazon Web Services Key Management Service (KMS) for * the destination bucket. Amazon S3 uses this key to encrypt replica objects. * Amazon S3 only supports symmetric encryption KMS keys. For more information, see * Asymmetric * keys in Amazon Web Services KMS in the Amazon Web Services Key Management * Service Developer Guide.

*/ inline EncryptionConfiguration& WithReplicaKmsKeyID(Aws::String&& value) { SetReplicaKmsKeyID(std::move(value)); return *this;} /** *

Specifies the ID (Key ARN or Alias ARN) of the customer managed Amazon Web * Services KMS key stored in Amazon Web Services Key Management Service (KMS) for * the destination bucket. Amazon S3 uses this key to encrypt replica objects. * Amazon S3 only supports symmetric encryption KMS keys. For more information, see * Asymmetric * keys in Amazon Web Services KMS in the Amazon Web Services Key Management * Service Developer Guide.

*/ inline EncryptionConfiguration& WithReplicaKmsKeyID(const char* value) { SetReplicaKmsKeyID(value); return *this;} private: Aws::String m_replicaKmsKeyID; bool m_replicaKmsKeyIDHasBeenSet = false; }; } // namespace Model } // namespace S3Crt } // namespace Aws