/** * 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 AWS_S3_API CreateMultipartUploadResult { public: CreateMultipartUploadResult(); CreateMultipartUploadResult(const Aws::AmazonWebServiceResult& result); CreateMultipartUploadResult& operator=(const Aws::AmazonWebServiceResult& result); /** *

If the bucket has a lifecycle rule configured with an action to abort * incomplete multipart uploads and the prefix in the lifecycle rule matches the * object name in the request, the response includes this header. The header * indicates when the initiated multipart upload becomes eligible for an abort * operation. For more information, see * Aborting Incomplete Multipart Uploads Using a Bucket Lifecycle Policy.

*

The response also includes the x-amz-abort-rule-id header that * provides the ID of the lifecycle configuration rule that defines this * action.

*/ inline const Aws::Utils::DateTime& GetAbortDate() const{ return m_abortDate; } /** *

If the bucket has a lifecycle rule configured with an action to abort * incomplete multipart uploads and the prefix in the lifecycle rule matches the * object name in the request, the response includes this header. The header * indicates when the initiated multipart upload becomes eligible for an abort * operation. For more information, see * Aborting Incomplete Multipart Uploads Using a Bucket Lifecycle Policy.

*

The response also includes the x-amz-abort-rule-id header that * provides the ID of the lifecycle configuration rule that defines this * action.

*/ inline void SetAbortDate(const Aws::Utils::DateTime& value) { m_abortDate = value; } /** *

If the bucket has a lifecycle rule configured with an action to abort * incomplete multipart uploads and the prefix in the lifecycle rule matches the * object name in the request, the response includes this header. The header * indicates when the initiated multipart upload becomes eligible for an abort * operation. For more information, see * Aborting Incomplete Multipart Uploads Using a Bucket Lifecycle Policy.

*

The response also includes the x-amz-abort-rule-id header that * provides the ID of the lifecycle configuration rule that defines this * action.

*/ inline void SetAbortDate(Aws::Utils::DateTime&& value) { m_abortDate = std::move(value); } /** *

If the bucket has a lifecycle rule configured with an action to abort * incomplete multipart uploads and the prefix in the lifecycle rule matches the * object name in the request, the response includes this header. The header * indicates when the initiated multipart upload becomes eligible for an abort * operation. For more information, see * Aborting Incomplete Multipart Uploads Using a Bucket Lifecycle Policy.

*

The response also includes the x-amz-abort-rule-id header that * provides the ID of the lifecycle configuration rule that defines this * action.

*/ inline CreateMultipartUploadResult& WithAbortDate(const Aws::Utils::DateTime& value) { SetAbortDate(value); return *this;} /** *

If the bucket has a lifecycle rule configured with an action to abort * incomplete multipart uploads and the prefix in the lifecycle rule matches the * object name in the request, the response includes this header. The header * indicates when the initiated multipart upload becomes eligible for an abort * operation. For more information, see * Aborting Incomplete Multipart Uploads Using a Bucket Lifecycle Policy.

*

The response also includes the x-amz-abort-rule-id header that * provides the ID of the lifecycle configuration rule that defines this * action.

*/ inline CreateMultipartUploadResult& WithAbortDate(Aws::Utils::DateTime&& value) { SetAbortDate(std::move(value)); return *this;} /** *

This header is returned along with the x-amz-abort-date header. * It identifies the applicable lifecycle configuration rule that defines the * action to abort incomplete multipart uploads.

*/ inline const Aws::String& GetAbortRuleId() const{ return m_abortRuleId; } /** *

This header is returned along with the x-amz-abort-date header. * It identifies the applicable lifecycle configuration rule that defines the * action to abort incomplete multipart uploads.

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

This header is returned along with the x-amz-abort-date header. * It identifies the applicable lifecycle configuration rule that defines the * action to abort incomplete multipart uploads.

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

This header is returned along with the x-amz-abort-date header. * It identifies the applicable lifecycle configuration rule that defines the * action to abort incomplete multipart uploads.

*/ inline void SetAbortRuleId(const char* value) { m_abortRuleId.assign(value); } /** *

This header is returned along with the x-amz-abort-date header. * It identifies the applicable lifecycle configuration rule that defines the * action to abort incomplete multipart uploads.

*/ inline CreateMultipartUploadResult& WithAbortRuleId(const Aws::String& value) { SetAbortRuleId(value); return *this;} /** *

This header is returned along with the x-amz-abort-date header. * It identifies the applicable lifecycle configuration rule that defines the * action to abort incomplete multipart uploads.

*/ inline CreateMultipartUploadResult& WithAbortRuleId(Aws::String&& value) { SetAbortRuleId(std::move(value)); return *this;} /** *

This header is returned along with the x-amz-abort-date header. * It identifies the applicable lifecycle configuration rule that defines the * action to abort incomplete multipart uploads.

*/ inline CreateMultipartUploadResult& WithAbortRuleId(const char* value) { SetAbortRuleId(value); return *this;} /** *

The name of the bucket to which the multipart upload was initiated. Does not * return the access point ARN or access point alias if used.

When using * this action with an access point, you must direct requests to the access point * hostname. The access point hostname takes the form * AccessPointName-AccountId.s3-accesspoint.Region.amazonaws.com. * When using this action with an access point through the Amazon Web Services * SDKs, you provide the access point ARN in place of the bucket name. For more * information about access point ARNs, see Using * access points in the Amazon S3 User Guide.

When using this * action with Amazon S3 on Outposts, you must direct requests to the S3 on * Outposts hostname. The S3 on Outposts hostname takes the form * AccessPointName-AccountId.outpostID.s3-outposts.Region.amazonaws.com. * When using this action using S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts bucket ARN in place of the bucket name. For more * information about S3 on Outposts ARNs, see Using * S3 on Outposts in the Amazon S3 User Guide.

*/ inline const Aws::String& GetBucket() const{ return m_bucket; } /** *

The name of the bucket to which the multipart upload was initiated. Does not * return the access point ARN or access point alias if used.

When using * this action with an access point, you must direct requests to the access point * hostname. The access point hostname takes the form * AccessPointName-AccountId.s3-accesspoint.Region.amazonaws.com. * When using this action with an access point through the Amazon Web Services * SDKs, you provide the access point ARN in place of the bucket name. For more * information about access point ARNs, see Using * access points in the Amazon S3 User Guide.

When using this * action with Amazon S3 on Outposts, you must direct requests to the S3 on * Outposts hostname. The S3 on Outposts hostname takes the form * AccessPointName-AccountId.outpostID.s3-outposts.Region.amazonaws.com. * When using this action using S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts bucket ARN in place of the bucket name. For more * information about S3 on Outposts ARNs, see Using * S3 on Outposts in the Amazon S3 User Guide.

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

The name of the bucket to which the multipart upload was initiated. Does not * return the access point ARN or access point alias if used.

When using * this action with an access point, you must direct requests to the access point * hostname. The access point hostname takes the form * AccessPointName-AccountId.s3-accesspoint.Region.amazonaws.com. * When using this action with an access point through the Amazon Web Services * SDKs, you provide the access point ARN in place of the bucket name. For more * information about access point ARNs, see Using * access points in the Amazon S3 User Guide.

When using this * action with Amazon S3 on Outposts, you must direct requests to the S3 on * Outposts hostname. The S3 on Outposts hostname takes the form * AccessPointName-AccountId.outpostID.s3-outposts.Region.amazonaws.com. * When using this action using S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts bucket ARN in place of the bucket name. For more * information about S3 on Outposts ARNs, see Using * S3 on Outposts in the Amazon S3 User Guide.

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

The name of the bucket to which the multipart upload was initiated. Does not * return the access point ARN or access point alias if used.

When using * this action with an access point, you must direct requests to the access point * hostname. The access point hostname takes the form * AccessPointName-AccountId.s3-accesspoint.Region.amazonaws.com. * When using this action with an access point through the Amazon Web Services * SDKs, you provide the access point ARN in place of the bucket name. For more * information about access point ARNs, see Using * access points in the Amazon S3 User Guide.

When using this * action with Amazon S3 on Outposts, you must direct requests to the S3 on * Outposts hostname. The S3 on Outposts hostname takes the form * AccessPointName-AccountId.outpostID.s3-outposts.Region.amazonaws.com. * When using this action using S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts bucket ARN in place of the bucket name. For more * information about S3 on Outposts ARNs, see Using * S3 on Outposts in the Amazon S3 User Guide.

*/ inline void SetBucket(const char* value) { m_bucket.assign(value); } /** *

The name of the bucket to which the multipart upload was initiated. Does not * return the access point ARN or access point alias if used.

When using * this action with an access point, you must direct requests to the access point * hostname. The access point hostname takes the form * AccessPointName-AccountId.s3-accesspoint.Region.amazonaws.com. * When using this action with an access point through the Amazon Web Services * SDKs, you provide the access point ARN in place of the bucket name. For more * information about access point ARNs, see Using * access points in the Amazon S3 User Guide.

When using this * action with Amazon S3 on Outposts, you must direct requests to the S3 on * Outposts hostname. The S3 on Outposts hostname takes the form * AccessPointName-AccountId.outpostID.s3-outposts.Region.amazonaws.com. * When using this action using S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts bucket ARN in place of the bucket name. For more * information about S3 on Outposts ARNs, see Using * S3 on Outposts in the Amazon S3 User Guide.

*/ inline CreateMultipartUploadResult& WithBucket(const Aws::String& value) { SetBucket(value); return *this;} /** *

The name of the bucket to which the multipart upload was initiated. Does not * return the access point ARN or access point alias if used.

When using * this action with an access point, you must direct requests to the access point * hostname. The access point hostname takes the form * AccessPointName-AccountId.s3-accesspoint.Region.amazonaws.com. * When using this action with an access point through the Amazon Web Services * SDKs, you provide the access point ARN in place of the bucket name. For more * information about access point ARNs, see Using * access points in the Amazon S3 User Guide.

When using this * action with Amazon S3 on Outposts, you must direct requests to the S3 on * Outposts hostname. The S3 on Outposts hostname takes the form * AccessPointName-AccountId.outpostID.s3-outposts.Region.amazonaws.com. * When using this action using S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts bucket ARN in place of the bucket name. For more * information about S3 on Outposts ARNs, see Using * S3 on Outposts in the Amazon S3 User Guide.

*/ inline CreateMultipartUploadResult& WithBucket(Aws::String&& value) { SetBucket(std::move(value)); return *this;} /** *

The name of the bucket to which the multipart upload was initiated. Does not * return the access point ARN or access point alias if used.

When using * this action with an access point, you must direct requests to the access point * hostname. The access point hostname takes the form * AccessPointName-AccountId.s3-accesspoint.Region.amazonaws.com. * When using this action with an access point through the Amazon Web Services * SDKs, you provide the access point ARN in place of the bucket name. For more * information about access point ARNs, see Using * access points in the Amazon S3 User Guide.

When using this * action with Amazon S3 on Outposts, you must direct requests to the S3 on * Outposts hostname. The S3 on Outposts hostname takes the form * AccessPointName-AccountId.outpostID.s3-outposts.Region.amazonaws.com. * When using this action using S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts bucket ARN in place of the bucket name. For more * information about S3 on Outposts ARNs, see Using * S3 on Outposts in the Amazon S3 User Guide.

*/ inline CreateMultipartUploadResult& WithBucket(const char* value) { SetBucket(value); return *this;} /** *

Object key for which the multipart upload was initiated.

*/ inline const Aws::String& GetKey() const{ return m_key; } /** *

Object key for which the multipart upload was initiated.

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

Object key for which the multipart upload was initiated.

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

Object key for which the multipart upload was initiated.

*/ inline void SetKey(const char* value) { m_key.assign(value); } /** *

Object key for which the multipart upload was initiated.

*/ inline CreateMultipartUploadResult& WithKey(const Aws::String& value) { SetKey(value); return *this;} /** *

Object key for which the multipart upload was initiated.

*/ inline CreateMultipartUploadResult& WithKey(Aws::String&& value) { SetKey(std::move(value)); return *this;} /** *

Object key for which the multipart upload was initiated.

*/ inline CreateMultipartUploadResult& WithKey(const char* value) { SetKey(value); return *this;} /** *

ID for the initiated multipart upload.

*/ inline const Aws::String& GetUploadId() const{ return m_uploadId; } /** *

ID for the initiated multipart upload.

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

ID for the initiated multipart upload.

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

ID for the initiated multipart upload.

*/ inline void SetUploadId(const char* value) { m_uploadId.assign(value); } /** *

ID for the initiated multipart upload.

*/ inline CreateMultipartUploadResult& WithUploadId(const Aws::String& value) { SetUploadId(value); return *this;} /** *

ID for the initiated multipart upload.

*/ inline CreateMultipartUploadResult& WithUploadId(Aws::String&& value) { SetUploadId(std::move(value)); return *this;} /** *

ID for the initiated multipart upload.

*/ inline CreateMultipartUploadResult& WithUploadId(const char* value) { SetUploadId(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 CreateMultipartUploadResult& 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 CreateMultipartUploadResult& 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 CreateMultipartUploadResult& 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 CreateMultipartUploadResult& 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 CreateMultipartUploadResult& 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 CreateMultipartUploadResult& 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 CreateMultipartUploadResult& 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 CreateMultipartUploadResult& WithSSECustomerKeyMD5(const char* value) { SetSSECustomerKeyMD5(value); return *this;} /** *

If present, specifies the ID of the Amazon Web Services Key Management * Service (Amazon Web Services KMS) symmetric 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 Amazon Web Services Key Management * Service (Amazon Web Services KMS) symmetric 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 Amazon Web Services Key Management * Service (Amazon Web Services KMS) symmetric 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 Amazon Web Services Key Management * Service (Amazon Web Services KMS) symmetric 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 Amazon Web Services Key Management * Service (Amazon Web Services KMS) symmetric customer managed key that was used * for the object.

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

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

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

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

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

If present, specifies the Amazon Web Services KMS Encryption Context to use * for object encryption. The value of this header is a base64-encoded UTF-8 string * holding JSON with the encryption context key-value pairs.

*/ inline const Aws::String& GetSSEKMSEncryptionContext() const{ return m_sSEKMSEncryptionContext; } /** *

If present, specifies the Amazon Web Services KMS Encryption Context to use * for object encryption. The value of this header is a base64-encoded UTF-8 string * holding JSON with the encryption context key-value pairs.

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

If present, specifies the Amazon Web Services KMS Encryption Context to use * for object encryption. The value of this header is a base64-encoded UTF-8 string * holding JSON with the encryption context key-value pairs.

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

If present, specifies the Amazon Web Services KMS Encryption Context to use * for object encryption. The value of this header is a base64-encoded UTF-8 string * holding JSON with the encryption context key-value pairs.

*/ inline void SetSSEKMSEncryptionContext(const char* value) { m_sSEKMSEncryptionContext.assign(value); } /** *

If present, specifies the Amazon Web Services KMS Encryption Context to use * for object encryption. The value of this header is a base64-encoded UTF-8 string * holding JSON with the encryption context key-value pairs.

*/ inline CreateMultipartUploadResult& WithSSEKMSEncryptionContext(const Aws::String& value) { SetSSEKMSEncryptionContext(value); return *this;} /** *

If present, specifies the Amazon Web Services KMS Encryption Context to use * for object encryption. The value of this header is a base64-encoded UTF-8 string * holding JSON with the encryption context key-value pairs.

*/ inline CreateMultipartUploadResult& WithSSEKMSEncryptionContext(Aws::String&& value) { SetSSEKMSEncryptionContext(std::move(value)); return *this;} /** *

If present, specifies the Amazon Web Services KMS Encryption Context to use * for object encryption. The value of this header is a base64-encoded UTF-8 string * holding JSON with the encryption context key-value pairs.

*/ inline CreateMultipartUploadResult& WithSSEKMSEncryptionContext(const char* value) { SetSSEKMSEncryptionContext(value); return *this;} /** *

Indicates whether the multipart upload uses an S3 Bucket Key for server-side * encryption with Amazon Web Services KMS (SSE-KMS).

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

Indicates whether the multipart upload uses an S3 Bucket Key for server-side * encryption with Amazon Web Services KMS (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 Amazon Web Services KMS (SSE-KMS).

*/ inline CreateMultipartUploadResult& 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 CreateMultipartUploadResult& WithRequestCharged(const RequestCharged& value) { SetRequestCharged(value); return *this;} inline CreateMultipartUploadResult& WithRequestCharged(RequestCharged&& value) { SetRequestCharged(std::move(value)); return *this;} private: Aws::Utils::DateTime m_abortDate; Aws::String m_abortRuleId; Aws::String m_bucket; Aws::String m_key; Aws::String m_uploadId; ServerSideEncryption m_serverSideEncryption; Aws::String m_sSECustomerAlgorithm; Aws::String m_sSECustomerKeyMD5; Aws::String m_sSEKMSKeyId; Aws::String m_sSEKMSEncryptionContext; bool m_bucketKeyEnabled; RequestCharged m_requestCharged; }; } // namespace Model } // namespace S3 } // namespace Aws