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

The version of the source object that was copied, if you have enabled * versioning on the source bucket.

*/ inline const Aws::String& GetCopySourceVersionId() const{ return m_copySourceVersionId; } /** *

The version of the source object that was copied, if you have enabled * versioning on the source bucket.

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

The version of the source object that was copied, if you have enabled * versioning on the source bucket.

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

The version of the source object that was copied, if you have enabled * versioning on the source bucket.

*/ inline void SetCopySourceVersionId(const char* value) { m_copySourceVersionId.assign(value); } /** *

The version of the source object that was copied, if you have enabled * versioning on the source bucket.

*/ inline UploadPartCopyResult& WithCopySourceVersionId(const Aws::String& value) { SetCopySourceVersionId(value); return *this;} /** *

The version of the source object that was copied, if you have enabled * versioning on the source bucket.

*/ inline UploadPartCopyResult& WithCopySourceVersionId(Aws::String&& value) { SetCopySourceVersionId(std::move(value)); return *this;} /** *

The version of the source object that was copied, if you have enabled * versioning on the source bucket.

*/ inline UploadPartCopyResult& WithCopySourceVersionId(const char* value) { SetCopySourceVersionId(value); return *this;} /** *

Container for all response elements.

*/ inline const CopyPartResult& GetCopyPartResult() const{ return m_copyPartResult; } /** *

Container for all response elements.

*/ inline void SetCopyPartResult(const CopyPartResult& value) { m_copyPartResult = value; } /** *

Container for all response elements.

*/ inline void SetCopyPartResult(CopyPartResult&& value) { m_copyPartResult = std::move(value); } /** *

Container for all response elements.

*/ inline UploadPartCopyResult& WithCopyPartResult(const CopyPartResult& value) { SetCopyPartResult(value); return *this;} /** *

Container for all response elements.

*/ inline UploadPartCopyResult& WithCopyPartResult(CopyPartResult&& value) { SetCopyPartResult(std::move(value)); return *this;} /** *

The server-side encryption algorithm used when storing this object in Amazon * S3 (for example, AES256, aws:kms).

*/ inline const ServerSideEncryption& GetServerSideEncryption() const{ return m_serverSideEncryption; } /** *

The server-side encryption algorithm used when storing this object in Amazon * S3 (for example, AES256, aws:kms).

*/ inline void SetServerSideEncryption(const ServerSideEncryption& value) { m_serverSideEncryption = value; } /** *

The server-side encryption algorithm used when storing this object in Amazon * S3 (for example, AES256, aws:kms).

*/ inline void SetServerSideEncryption(ServerSideEncryption&& value) { m_serverSideEncryption = std::move(value); } /** *

The server-side encryption algorithm used when storing this object in Amazon * S3 (for example, AES256, aws:kms).

*/ inline UploadPartCopyResult& WithServerSideEncryption(const ServerSideEncryption& value) { SetServerSideEncryption(value); return *this;} /** *

The server-side encryption algorithm used when storing this object in Amazon * S3 (for example, AES256, aws:kms).

*/ inline UploadPartCopyResult& WithServerSideEncryption(ServerSideEncryption&& value) { SetServerSideEncryption(std::move(value)); return *this;} /** *

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.

*/ inline const Aws::String& GetSSECustomerAlgorithm() const{ return m_sSECustomerAlgorithm; } /** *

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.

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

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.

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

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.

*/ inline void SetSSECustomerAlgorithm(const char* value) { m_sSECustomerAlgorithm.assign(value); } /** *

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.

*/ inline UploadPartCopyResult& WithSSECustomerAlgorithm(const Aws::String& value) { SetSSECustomerAlgorithm(value); return *this;} /** *

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.

*/ inline UploadPartCopyResult& WithSSECustomerAlgorithm(Aws::String&& value) { SetSSECustomerAlgorithm(std::move(value)); return *this;} /** *

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.

*/ inline UploadPartCopyResult& WithSSECustomerAlgorithm(const char* value) { SetSSECustomerAlgorithm(value); return *this;} /** *

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header to provide round-trip message * integrity verification of the customer-provided encryption key.

*/ inline const Aws::String& GetSSECustomerKeyMD5() const{ return m_sSECustomerKeyMD5; } /** *

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header to provide round-trip message * integrity verification of the customer-provided encryption key.

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

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header to provide round-trip message * integrity verification of the customer-provided encryption key.

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

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header to provide round-trip message * integrity verification of the customer-provided encryption key.

*/ inline void SetSSECustomerKeyMD5(const char* value) { m_sSECustomerKeyMD5.assign(value); } /** *

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header to provide round-trip message * integrity verification of the customer-provided encryption key.

*/ inline UploadPartCopyResult& WithSSECustomerKeyMD5(const Aws::String& value) { SetSSECustomerKeyMD5(value); return *this;} /** *

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header to provide round-trip message * integrity verification of the customer-provided encryption key.

*/ inline UploadPartCopyResult& WithSSECustomerKeyMD5(Aws::String&& value) { SetSSECustomerKeyMD5(std::move(value)); return *this;} /** *

If server-side encryption with a customer-provided encryption key was * requested, the response will include this header to provide round-trip message * integrity verification of the customer-provided encryption key.

*/ inline UploadPartCopyResult& WithSSECustomerKeyMD5(const char* value) { SetSSECustomerKeyMD5(value); return *this;} /** *

If present, specifies the ID of the Key Management Service (KMS) symmetric * encryption customer managed key that was used for the object.

*/ inline const Aws::String& GetSSEKMSKeyId() const{ return m_sSEKMSKeyId; } /** *

If present, specifies the ID of the Key Management Service (KMS) symmetric * encryption customer managed key that was used for the object.

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

If present, specifies the ID of the Key Management Service (KMS) symmetric * encryption customer managed key that was used for the object.

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

If present, specifies the ID of the Key Management Service (KMS) symmetric * encryption customer managed key that was used for the object.

*/ inline void SetSSEKMSKeyId(const char* value) { m_sSEKMSKeyId.assign(value); } /** *

If present, specifies the ID of the Key Management Service (KMS) symmetric * encryption customer managed key that was used for the object.

*/ inline UploadPartCopyResult& WithSSEKMSKeyId(const Aws::String& value) { SetSSEKMSKeyId(value); return *this;} /** *

If present, specifies the ID of the Key Management Service (KMS) symmetric * encryption customer managed key that was used for the object.

*/ inline UploadPartCopyResult& WithSSEKMSKeyId(Aws::String&& value) { SetSSEKMSKeyId(std::move(value)); return *this;} /** *

If present, specifies the ID of the Key Management Service (KMS) symmetric * encryption customer managed key that was used for the object.

*/ inline UploadPartCopyResult& WithSSEKMSKeyId(const char* value) { SetSSEKMSKeyId(value); return *this;} /** *

Indicates whether the multipart upload uses an S3 Bucket Key for server-side * encryption with Key Management Service (KMS) keys (SSE-KMS).

*/ inline bool GetBucketKeyEnabled() const{ return m_bucketKeyEnabled; } /** *

Indicates whether the multipart upload uses an S3 Bucket Key for server-side * encryption with Key Management Service (KMS) keys (SSE-KMS).

*/ inline void SetBucketKeyEnabled(bool value) { m_bucketKeyEnabled = value; } /** *

Indicates whether the multipart upload uses an S3 Bucket Key for server-side * encryption with Key Management Service (KMS) keys (SSE-KMS).

*/ inline UploadPartCopyResult& WithBucketKeyEnabled(bool value) { SetBucketKeyEnabled(value); return *this;} inline const RequestCharged& GetRequestCharged() const{ return m_requestCharged; } inline void SetRequestCharged(const RequestCharged& value) { m_requestCharged = value; } inline void SetRequestCharged(RequestCharged&& value) { m_requestCharged = std::move(value); } inline UploadPartCopyResult& WithRequestCharged(const RequestCharged& value) { SetRequestCharged(value); return *this;} inline UploadPartCopyResult& WithRequestCharged(RequestCharged&& value) { SetRequestCharged(std::move(value)); return *this;} inline const Aws::String& GetRequestId() const{ return m_requestId; } inline void SetRequestId(const Aws::String& value) { m_requestId = value; } inline void SetRequestId(Aws::String&& value) { m_requestId = std::move(value); } inline void SetRequestId(const char* value) { m_requestId.assign(value); } inline UploadPartCopyResult& WithRequestId(const Aws::String& value) { SetRequestId(value); return *this;} inline UploadPartCopyResult& WithRequestId(Aws::String&& value) { SetRequestId(std::move(value)); return *this;} inline UploadPartCopyResult& WithRequestId(const char* value) { SetRequestId(value); return *this;} private: Aws::String m_copySourceVersionId; CopyPartResult m_copyPartResult; ServerSideEncryption m_serverSideEncryption; Aws::String m_sSECustomerAlgorithm; Aws::String m_sSECustomerKeyMD5; Aws::String m_sSEKMSKeyId; bool m_bucketKeyEnabled; RequestCharged m_requestCharged; Aws::String m_requestId; }; } // namespace Model } // namespace S3 } // namespace Aws