/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include namespace Aws { template class AmazonWebServiceResult; namespace Utils { namespace Json { class JsonValue; } // namespace Json } // namespace Utils namespace KMS { namespace Model { class AWS_KMS_API GenerateDataKeyResult { public: GenerateDataKeyResult(); GenerateDataKeyResult(const Aws::AmazonWebServiceResult& result); GenerateDataKeyResult& operator=(const Aws::AmazonWebServiceResult& result); /** *

The encrypted copy of the data key. When you use the HTTP API or the AWS CLI, * the value is Base64-encoded. Otherwise, it is not Base64-encoded.

*/ inline const Aws::Utils::ByteBuffer& GetCiphertextBlob() const{ return m_ciphertextBlob; } /** *

The encrypted copy of the data key. When you use the HTTP API or the AWS CLI, * the value is Base64-encoded. Otherwise, it is not Base64-encoded.

*/ inline void SetCiphertextBlob(const Aws::Utils::ByteBuffer& value) { m_ciphertextBlob = value; } /** *

The encrypted copy of the data key. When you use the HTTP API or the AWS CLI, * the value is Base64-encoded. Otherwise, it is not Base64-encoded.

*/ inline void SetCiphertextBlob(Aws::Utils::ByteBuffer&& value) { m_ciphertextBlob = std::move(value); } /** *

The encrypted copy of the data key. When you use the HTTP API or the AWS CLI, * the value is Base64-encoded. Otherwise, it is not Base64-encoded.

*/ inline GenerateDataKeyResult& WithCiphertextBlob(const Aws::Utils::ByteBuffer& value) { SetCiphertextBlob(value); return *this;} /** *

The encrypted copy of the data key. When you use the HTTP API or the AWS CLI, * the value is Base64-encoded. Otherwise, it is not Base64-encoded.

*/ inline GenerateDataKeyResult& WithCiphertextBlob(Aws::Utils::ByteBuffer&& value) { SetCiphertextBlob(std::move(value)); return *this;} /** *

The plaintext data key. When you use the HTTP API or the AWS CLI, the value * is Base64-encoded. Otherwise, it is not Base64-encoded. Use this data key to * encrypt your data outside of KMS. Then, remove it from memory as soon as * possible.

*/ inline const Aws::Utils::CryptoBuffer& GetPlaintext() const{ return m_plaintext; } /** *

The plaintext data key. When you use the HTTP API or the AWS CLI, the value * is Base64-encoded. Otherwise, it is not Base64-encoded. Use this data key to * encrypt your data outside of KMS. Then, remove it from memory as soon as * possible.

*/ inline void SetPlaintext(const Aws::Utils::CryptoBuffer& value) { m_plaintext = value; } /** *

The plaintext data key. When you use the HTTP API or the AWS CLI, the value * is Base64-encoded. Otherwise, it is not Base64-encoded. Use this data key to * encrypt your data outside of KMS. Then, remove it from memory as soon as * possible.

*/ inline void SetPlaintext(Aws::Utils::CryptoBuffer&& value) { m_plaintext = std::move(value); } /** *

The plaintext data key. When you use the HTTP API or the AWS CLI, the value * is Base64-encoded. Otherwise, it is not Base64-encoded. Use this data key to * encrypt your data outside of KMS. Then, remove it from memory as soon as * possible.

*/ inline GenerateDataKeyResult& WithPlaintext(const Aws::Utils::CryptoBuffer& value) { SetPlaintext(value); return *this;} /** *

The plaintext data key. When you use the HTTP API or the AWS CLI, the value * is Base64-encoded. Otherwise, it is not Base64-encoded. Use this data key to * encrypt your data outside of KMS. Then, remove it from memory as soon as * possible.

*/ inline GenerateDataKeyResult& WithPlaintext(Aws::Utils::CryptoBuffer&& value) { SetPlaintext(std::move(value)); return *this;} /** *

The Amazon Resource Name (key * ARN) of the CMK that encrypted the data key.

*/ inline const Aws::String& GetKeyId() const{ return m_keyId; } /** *

The Amazon Resource Name (key * ARN) of the CMK that encrypted the data key.

*/ inline void SetKeyId(const Aws::String& value) { m_keyId = value; } /** *

The Amazon Resource Name (key * ARN) of the CMK that encrypted the data key.

*/ inline void SetKeyId(Aws::String&& value) { m_keyId = std::move(value); } /** *

The Amazon Resource Name (key * ARN) of the CMK that encrypted the data key.

*/ inline void SetKeyId(const char* value) { m_keyId.assign(value); } /** *

The Amazon Resource Name (key * ARN) of the CMK that encrypted the data key.

*/ inline GenerateDataKeyResult& WithKeyId(const Aws::String& value) { SetKeyId(value); return *this;} /** *

The Amazon Resource Name (key * ARN) of the CMK that encrypted the data key.

*/ inline GenerateDataKeyResult& WithKeyId(Aws::String&& value) { SetKeyId(std::move(value)); return *this;} /** *

The Amazon Resource Name (key * ARN) of the CMK that encrypted the data key.

*/ inline GenerateDataKeyResult& WithKeyId(const char* value) { SetKeyId(value); return *this;} private: Aws::Utils::ByteBuffer m_ciphertextBlob; Aws::Utils::CryptoBuffer m_plaintext; Aws::String m_keyId; }; } // namespace Model } // namespace KMS } // namespace Aws