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

The URI that identifies the newly created object.

*/ inline const Aws::String& GetLocation() const{ return m_location; } /** *

The URI that identifies the newly created object.

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

The URI that identifies the newly created object.

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

The URI that identifies the newly created object.

*/ inline void SetLocation(const char* value) { m_location.assign(value); } /** *

The URI that identifies the newly created object.

*/ inline CompleteMultipartUploadResult& WithLocation(const Aws::String& value) { SetLocation(value); return *this;} /** *

The URI that identifies the newly created object.

*/ inline CompleteMultipartUploadResult& WithLocation(Aws::String&& value) { SetLocation(std::move(value)); return *this;} /** *

The URI that identifies the newly created object.

*/ inline CompleteMultipartUploadResult& WithLocation(const char* value) { SetLocation(value); return *this;} /** *

The name of the bucket that contains the newly created object. 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 you use 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 you use this action with S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts access point ARN in place of the bucket name. For * more information about S3 on Outposts ARNs, see What * is S3 on Outposts? in the Amazon S3 User Guide.

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

The name of the bucket that contains the newly created object. 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 you use 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 you use this action with S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts access point ARN in place of the bucket name. For * more information about S3 on Outposts ARNs, see What * is S3 on Outposts? in the Amazon S3 User Guide.

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

The name of the bucket that contains the newly created object. 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 you use 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 you use this action with S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts access point ARN in place of the bucket name. For * more information about S3 on Outposts ARNs, see What * is 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 that contains the newly created object. 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 you use 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 you use this action with S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts access point ARN in place of the bucket name. For * more information about S3 on Outposts ARNs, see What * is S3 on Outposts? in the Amazon S3 User Guide.

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

The name of the bucket that contains the newly created object. 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 you use 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 you use this action with S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts access point ARN in place of the bucket name. For * more information about S3 on Outposts ARNs, see What * is S3 on Outposts? in the Amazon S3 User Guide.

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

The name of the bucket that contains the newly created object. 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 you use 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 you use this action with S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts access point ARN in place of the bucket name. For * more information about S3 on Outposts ARNs, see What * is S3 on Outposts? in the Amazon S3 User Guide.

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

The name of the bucket that contains the newly created object. 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 you use 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 you use this action with S3 on Outposts through the Amazon Web Services * SDKs, you provide the Outposts access point ARN in place of the bucket name. For * more information about S3 on Outposts ARNs, see What * is S3 on Outposts? in the Amazon S3 User Guide.

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

The object key of the newly created object.

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

The object key of the newly created object.

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

The object key of the newly created object.

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

The object key of the newly created object.

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

The object key of the newly created object.

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

The object key of the newly created object.

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

The object key of the newly created object.

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

If the object expiration is configured, this will contain the expiration date * (expiry-date) and rule ID (rule-id). The value of * rule-id is URL-encoded.

*/ inline const Aws::String& GetExpiration() const{ return m_expiration; } /** *

If the object expiration is configured, this will contain the expiration date * (expiry-date) and rule ID (rule-id). The value of * rule-id is URL-encoded.

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

If the object expiration is configured, this will contain the expiration date * (expiry-date) and rule ID (rule-id). The value of * rule-id is URL-encoded.

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

If the object expiration is configured, this will contain the expiration date * (expiry-date) and rule ID (rule-id). The value of * rule-id is URL-encoded.

*/ inline void SetExpiration(const char* value) { m_expiration.assign(value); } /** *

If the object expiration is configured, this will contain the expiration date * (expiry-date) and rule ID (rule-id). The value of * rule-id is URL-encoded.

*/ inline CompleteMultipartUploadResult& WithExpiration(const Aws::String& value) { SetExpiration(value); return *this;} /** *

If the object expiration is configured, this will contain the expiration date * (expiry-date) and rule ID (rule-id). The value of * rule-id is URL-encoded.

*/ inline CompleteMultipartUploadResult& WithExpiration(Aws::String&& value) { SetExpiration(std::move(value)); return *this;} /** *

If the object expiration is configured, this will contain the expiration date * (expiry-date) and rule ID (rule-id). The value of * rule-id is URL-encoded.

*/ inline CompleteMultipartUploadResult& WithExpiration(const char* value) { SetExpiration(value); return *this;} /** *

Entity tag that identifies the newly created object's data. Objects with * different object data will have different entity tags. The entity tag is an * opaque string. The entity tag may or may not be an MD5 digest of the object * data. If the entity tag is not an MD5 digest of the object data, it will contain * one or more nonhexadecimal characters and/or will consist of less than 32 or * more than 32 hexadecimal digits. For more information about how the entity tag * is calculated, see Checking * object integrity in the Amazon S3 User Guide.

*/ inline const Aws::String& GetETag() const{ return m_eTag; } /** *

Entity tag that identifies the newly created object's data. Objects with * different object data will have different entity tags. The entity tag is an * opaque string. The entity tag may or may not be an MD5 digest of the object * data. If the entity tag is not an MD5 digest of the object data, it will contain * one or more nonhexadecimal characters and/or will consist of less than 32 or * more than 32 hexadecimal digits. For more information about how the entity tag * is calculated, see Checking * object integrity in the Amazon S3 User Guide.

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

Entity tag that identifies the newly created object's data. Objects with * different object data will have different entity tags. The entity tag is an * opaque string. The entity tag may or may not be an MD5 digest of the object * data. If the entity tag is not an MD5 digest of the object data, it will contain * one or more nonhexadecimal characters and/or will consist of less than 32 or * more than 32 hexadecimal digits. For more information about how the entity tag * is calculated, see Checking * object integrity in the Amazon S3 User Guide.

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

Entity tag that identifies the newly created object's data. Objects with * different object data will have different entity tags. The entity tag is an * opaque string. The entity tag may or may not be an MD5 digest of the object * data. If the entity tag is not an MD5 digest of the object data, it will contain * one or more nonhexadecimal characters and/or will consist of less than 32 or * more than 32 hexadecimal digits. For more information about how the entity tag * is calculated, see Checking * object integrity in the Amazon S3 User Guide.

*/ inline void SetETag(const char* value) { m_eTag.assign(value); } /** *

Entity tag that identifies the newly created object's data. Objects with * different object data will have different entity tags. The entity tag is an * opaque string. The entity tag may or may not be an MD5 digest of the object * data. If the entity tag is not an MD5 digest of the object data, it will contain * one or more nonhexadecimal characters and/or will consist of less than 32 or * more than 32 hexadecimal digits. For more information about how the entity tag * is calculated, see Checking * object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithETag(const Aws::String& value) { SetETag(value); return *this;} /** *

Entity tag that identifies the newly created object's data. Objects with * different object data will have different entity tags. The entity tag is an * opaque string. The entity tag may or may not be an MD5 digest of the object * data. If the entity tag is not an MD5 digest of the object data, it will contain * one or more nonhexadecimal characters and/or will consist of less than 32 or * more than 32 hexadecimal digits. For more information about how the entity tag * is calculated, see Checking * object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithETag(Aws::String&& value) { SetETag(std::move(value)); return *this;} /** *

Entity tag that identifies the newly created object's data. Objects with * different object data will have different entity tags. The entity tag is an * opaque string. The entity tag may or may not be an MD5 digest of the object * data. If the entity tag is not an MD5 digest of the object data, it will contain * one or more nonhexadecimal characters and/or will consist of less than 32 or * more than 32 hexadecimal digits. For more information about how the entity tag * is calculated, see Checking * object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithETag(const char* value) { SetETag(value); return *this;} /** *

The base64-encoded, 32-bit CRC32 checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline const Aws::String& GetChecksumCRC32() const{ return m_checksumCRC32; } /** *

The base64-encoded, 32-bit CRC32 checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

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

The base64-encoded, 32-bit CRC32 checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

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

The base64-encoded, 32-bit CRC32 checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline void SetChecksumCRC32(const char* value) { m_checksumCRC32.assign(value); } /** *

The base64-encoded, 32-bit CRC32 checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithChecksumCRC32(const Aws::String& value) { SetChecksumCRC32(value); return *this;} /** *

The base64-encoded, 32-bit CRC32 checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithChecksumCRC32(Aws::String&& value) { SetChecksumCRC32(std::move(value)); return *this;} /** *

The base64-encoded, 32-bit CRC32 checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithChecksumCRC32(const char* value) { SetChecksumCRC32(value); return *this;} /** *

The base64-encoded, 32-bit CRC32C checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline const Aws::String& GetChecksumCRC32C() const{ return m_checksumCRC32C; } /** *

The base64-encoded, 32-bit CRC32C checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

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

The base64-encoded, 32-bit CRC32C checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

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

The base64-encoded, 32-bit CRC32C checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline void SetChecksumCRC32C(const char* value) { m_checksumCRC32C.assign(value); } /** *

The base64-encoded, 32-bit CRC32C checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithChecksumCRC32C(const Aws::String& value) { SetChecksumCRC32C(value); return *this;} /** *

The base64-encoded, 32-bit CRC32C checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithChecksumCRC32C(Aws::String&& value) { SetChecksumCRC32C(std::move(value)); return *this;} /** *

The base64-encoded, 32-bit CRC32C checksum of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithChecksumCRC32C(const char* value) { SetChecksumCRC32C(value); return *this;} /** *

The base64-encoded, 160-bit SHA-1 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline const Aws::String& GetChecksumSHA1() const{ return m_checksumSHA1; } /** *

The base64-encoded, 160-bit SHA-1 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

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

The base64-encoded, 160-bit SHA-1 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

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

The base64-encoded, 160-bit SHA-1 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline void SetChecksumSHA1(const char* value) { m_checksumSHA1.assign(value); } /** *

The base64-encoded, 160-bit SHA-1 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithChecksumSHA1(const Aws::String& value) { SetChecksumSHA1(value); return *this;} /** *

The base64-encoded, 160-bit SHA-1 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithChecksumSHA1(Aws::String&& value) { SetChecksumSHA1(std::move(value)); return *this;} /** *

The base64-encoded, 160-bit SHA-1 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithChecksumSHA1(const char* value) { SetChecksumSHA1(value); return *this;} /** *

The base64-encoded, 256-bit SHA-256 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline const Aws::String& GetChecksumSHA256() const{ return m_checksumSHA256; } /** *

The base64-encoded, 256-bit SHA-256 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

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

The base64-encoded, 256-bit SHA-256 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

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

The base64-encoded, 256-bit SHA-256 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline void SetChecksumSHA256(const char* value) { m_checksumSHA256.assign(value); } /** *

The base64-encoded, 256-bit SHA-256 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithChecksumSHA256(const Aws::String& value) { SetChecksumSHA256(value); return *this;} /** *

The base64-encoded, 256-bit SHA-256 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithChecksumSHA256(Aws::String&& value) { SetChecksumSHA256(std::move(value)); return *this;} /** *

The base64-encoded, 256-bit SHA-256 digest of the object. This will only be * present if it was uploaded with the object. With multipart uploads, this may not * be a checksum value of the object. For more information about how checksums are * calculated with multipart uploads, see * Checking object integrity in the Amazon S3 User Guide.

*/ inline CompleteMultipartUploadResult& WithChecksumSHA256(const char* value) { SetChecksumSHA256(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 CompleteMultipartUploadResult& 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 CompleteMultipartUploadResult& WithServerSideEncryption(ServerSideEncryption&& value) { SetServerSideEncryption(std::move(value)); return *this;} /** *

Version ID of the newly created object, in case the bucket has versioning * turned on.

*/ inline const Aws::String& GetVersionId() const{ return m_versionId; } /** *

Version ID of the newly created object, in case the bucket has versioning * turned on.

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

Version ID of the newly created object, in case the bucket has versioning * turned on.

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

Version ID of the newly created object, in case the bucket has versioning * turned on.

*/ inline void SetVersionId(const char* value) { m_versionId.assign(value); } /** *

Version ID of the newly created object, in case the bucket has versioning * turned on.

*/ inline CompleteMultipartUploadResult& WithVersionId(const Aws::String& value) { SetVersionId(value); return *this;} /** *

Version ID of the newly created object, in case the bucket has versioning * turned on.

*/ inline CompleteMultipartUploadResult& WithVersionId(Aws::String&& value) { SetVersionId(std::move(value)); return *this;} /** *

Version ID of the newly created object, in case the bucket has versioning * turned on.

*/ inline CompleteMultipartUploadResult& WithVersionId(const char* value) { SetVersionId(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 CompleteMultipartUploadResult& 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 CompleteMultipartUploadResult& 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 CompleteMultipartUploadResult& 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 CompleteMultipartUploadResult& 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 CompleteMultipartUploadResult& WithRequestCharged(const RequestCharged& value) { SetRequestCharged(value); return *this;} inline CompleteMultipartUploadResult& 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 CompleteMultipartUploadResult& WithRequestId(const Aws::String& value) { SetRequestId(value); return *this;} inline CompleteMultipartUploadResult& WithRequestId(Aws::String&& value) { SetRequestId(std::move(value)); return *this;} inline CompleteMultipartUploadResult& WithRequestId(const char* value) { SetRequestId(value); return *this;} private: Aws::String m_location; Aws::String m_bucket; Aws::String m_key; Aws::String m_expiration; Aws::String m_eTag; Aws::String m_checksumCRC32; Aws::String m_checksumCRC32C; Aws::String m_checksumSHA1; Aws::String m_checksumSHA256; ServerSideEncryption m_serverSideEncryption; Aws::String m_versionId; Aws::String m_sSEKMSKeyId; bool m_bucketKeyEnabled; RequestCharged m_requestCharged; Aws::String m_requestId; }; } // namespace Model } // namespace S3Crt } // namespace Aws