/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include <aws/s3/S3_EXPORTS.h> #include <aws/core/utils/memory/stl/AWSString.h> #include <aws/s3/model/ServerSideEncryption.h> #include <aws/s3/model/RequestCharged.h> #include <utility> namespace Aws { template<typename RESULT_TYPE> class AmazonWebServiceResult; namespace Utils { namespace Xml { class XmlDocument; } // namespace Xml } // namespace Utils namespace S3 { namespace Model { class PutObjectResult { public: AWS_S3_API PutObjectResult(); AWS_S3_API PutObjectResult(const Aws::AmazonWebServiceResult<Aws::Utils::Xml::XmlDocument>& result); AWS_S3_API PutObjectResult& operator=(const Aws::AmazonWebServiceResult<Aws::Utils::Xml::XmlDocument>& result); /** * <p>If the expiration is configured for the object (see <a * href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutBucketLifecycleConfiguration.html">PutBucketLifecycleConfiguration</a>), * the response includes this header. It includes the <code>expiry-date</code> and * <code>rule-id</code> key-value pairs that provide information about object * expiration. The value of the <code>rule-id</code> is URL-encoded.</p> */ inline const Aws::String& GetExpiration() const{ return m_expiration; } /** * <p>If the expiration is configured for the object (see <a * href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutBucketLifecycleConfiguration.html">PutBucketLifecycleConfiguration</a>), * the response includes this header. It includes the <code>expiry-date</code> and * <code>rule-id</code> key-value pairs that provide information about object * expiration. The value of the <code>rule-id</code> is URL-encoded.</p> */ inline void SetExpiration(const Aws::String& value) { m_expiration = value; } /** * <p>If the expiration is configured for the object (see <a * href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutBucketLifecycleConfiguration.html">PutBucketLifecycleConfiguration</a>), * the response includes this header. It includes the <code>expiry-date</code> and * <code>rule-id</code> key-value pairs that provide information about object * expiration. The value of the <code>rule-id</code> is URL-encoded.</p> */ inline void SetExpiration(Aws::String&& value) { m_expiration = std::move(value); } /** * <p>If the expiration is configured for the object (see <a * href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutBucketLifecycleConfiguration.html">PutBucketLifecycleConfiguration</a>), * the response includes this header. It includes the <code>expiry-date</code> and * <code>rule-id</code> key-value pairs that provide information about object * expiration. The value of the <code>rule-id</code> is URL-encoded.</p> */ inline void SetExpiration(const char* value) { m_expiration.assign(value); } /** * <p>If the expiration is configured for the object (see <a * href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutBucketLifecycleConfiguration.html">PutBucketLifecycleConfiguration</a>), * the response includes this header. It includes the <code>expiry-date</code> and * <code>rule-id</code> key-value pairs that provide information about object * expiration. The value of the <code>rule-id</code> is URL-encoded.</p> */ inline PutObjectResult& WithExpiration(const Aws::String& value) { SetExpiration(value); return *this;} /** * <p>If the expiration is configured for the object (see <a * href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutBucketLifecycleConfiguration.html">PutBucketLifecycleConfiguration</a>), * the response includes this header. It includes the <code>expiry-date</code> and * <code>rule-id</code> key-value pairs that provide information about object * expiration. The value of the <code>rule-id</code> is URL-encoded.</p> */ inline PutObjectResult& WithExpiration(Aws::String&& value) { SetExpiration(std::move(value)); return *this;} /** * <p>If the expiration is configured for the object (see <a * href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutBucketLifecycleConfiguration.html">PutBucketLifecycleConfiguration</a>), * the response includes this header. It includes the <code>expiry-date</code> and * <code>rule-id</code> key-value pairs that provide information about object * expiration. The value of the <code>rule-id</code> is URL-encoded.</p> */ inline PutObjectResult& WithExpiration(const char* value) { SetExpiration(value); return *this;} /** * <p>Entity tag for the uploaded object.</p> */ inline const Aws::String& GetETag() const{ return m_eTag; } /** * <p>Entity tag for the uploaded object.</p> */ inline void SetETag(const Aws::String& value) { m_eTag = value; } /** * <p>Entity tag for the uploaded object.</p> */ inline void SetETag(Aws::String&& value) { m_eTag = std::move(value); } /** * <p>Entity tag for the uploaded object.</p> */ inline void SetETag(const char* value) { m_eTag.assign(value); } /** * <p>Entity tag for the uploaded object.</p> */ inline PutObjectResult& WithETag(const Aws::String& value) { SetETag(value); return *this;} /** * <p>Entity tag for the uploaded object.</p> */ inline PutObjectResult& WithETag(Aws::String&& value) { SetETag(std::move(value)); return *this;} /** * <p>Entity tag for the uploaded object.</p> */ inline PutObjectResult& WithETag(const char* value) { SetETag(value); return *this;} /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline const Aws::String& GetChecksumCRC32() const{ return m_checksumCRC32; } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline void SetChecksumCRC32(const Aws::String& value) { m_checksumCRC32 = value; } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline void SetChecksumCRC32(Aws::String&& value) { m_checksumCRC32 = std::move(value); } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline void SetChecksumCRC32(const char* value) { m_checksumCRC32.assign(value); } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline PutObjectResult& WithChecksumCRC32(const Aws::String& value) { SetChecksumCRC32(value); return *this;} /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline PutObjectResult& WithChecksumCRC32(Aws::String&& value) { SetChecksumCRC32(std::move(value)); return *this;} /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline PutObjectResult& WithChecksumCRC32(const char* value) { SetChecksumCRC32(value); return *this;} /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline const Aws::String& GetChecksumCRC32C() const{ return m_checksumCRC32C; } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline void SetChecksumCRC32C(const Aws::String& value) { m_checksumCRC32C = value; } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline void SetChecksumCRC32C(Aws::String&& value) { m_checksumCRC32C = std::move(value); } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline void SetChecksumCRC32C(const char* value) { m_checksumCRC32C.assign(value); } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline PutObjectResult& WithChecksumCRC32C(const Aws::String& value) { SetChecksumCRC32C(value); return *this;} /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline PutObjectResult& WithChecksumCRC32C(Aws::String&& value) { SetChecksumCRC32C(std::move(value)); return *this;} /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline PutObjectResult& WithChecksumCRC32C(const char* value) { SetChecksumCRC32C(value); return *this;} /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline const Aws::String& GetChecksumSHA1() const{ return m_checksumSHA1; } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline void SetChecksumSHA1(const Aws::String& value) { m_checksumSHA1 = value; } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline void SetChecksumSHA1(Aws::String&& value) { m_checksumSHA1 = std::move(value); } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline void SetChecksumSHA1(const char* value) { m_checksumSHA1.assign(value); } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline PutObjectResult& WithChecksumSHA1(const Aws::String& value) { SetChecksumSHA1(value); return *this;} /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline PutObjectResult& WithChecksumSHA1(Aws::String&& value) { SetChecksumSHA1(std::move(value)); return *this;} /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline PutObjectResult& WithChecksumSHA1(const char* value) { SetChecksumSHA1(value); return *this;} /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline const Aws::String& GetChecksumSHA256() const{ return m_checksumSHA256; } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline void SetChecksumSHA256(const Aws::String& value) { m_checksumSHA256 = value; } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline void SetChecksumSHA256(Aws::String&& value) { m_checksumSHA256 = std::move(value); } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline void SetChecksumSHA256(const char* value) { m_checksumSHA256.assign(value); } /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline PutObjectResult& WithChecksumSHA256(const Aws::String& value) { SetChecksumSHA256(value); return *this;} /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline PutObjectResult& WithChecksumSHA256(Aws::String&& value) { SetChecksumSHA256(std::move(value)); return *this;} /** * <p>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 <a * href="https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html#large-object-checksums"> * Checking object integrity</a> in the <i>Amazon S3 User Guide</i>.</p> */ inline PutObjectResult& WithChecksumSHA256(const char* value) { SetChecksumSHA256(value); return *this;} /** * <p>If you specified server-side encryption either with an Amazon Web Services * KMS key or Amazon S3-managed encryption key in your PUT request, the response * includes this header. It confirms the encryption algorithm that Amazon S3 used * to encrypt the object.</p> */ inline const ServerSideEncryption& GetServerSideEncryption() const{ return m_serverSideEncryption; } /** * <p>If you specified server-side encryption either with an Amazon Web Services * KMS key or Amazon S3-managed encryption key in your PUT request, the response * includes this header. It confirms the encryption algorithm that Amazon S3 used * to encrypt the object.</p> */ inline void SetServerSideEncryption(const ServerSideEncryption& value) { m_serverSideEncryption = value; } /** * <p>If you specified server-side encryption either with an Amazon Web Services * KMS key or Amazon S3-managed encryption key in your PUT request, the response * includes this header. It confirms the encryption algorithm that Amazon S3 used * to encrypt the object.</p> */ inline void SetServerSideEncryption(ServerSideEncryption&& value) { m_serverSideEncryption = std::move(value); } /** * <p>If you specified server-side encryption either with an Amazon Web Services * KMS key or Amazon S3-managed encryption key in your PUT request, the response * includes this header. It confirms the encryption algorithm that Amazon S3 used * to encrypt the object.</p> */ inline PutObjectResult& WithServerSideEncryption(const ServerSideEncryption& value) { SetServerSideEncryption(value); return *this;} /** * <p>If you specified server-side encryption either with an Amazon Web Services * KMS key or Amazon S3-managed encryption key in your PUT request, the response * includes this header. It confirms the encryption algorithm that Amazon S3 used * to encrypt the object.</p> */ inline PutObjectResult& WithServerSideEncryption(ServerSideEncryption&& value) { SetServerSideEncryption(std::move(value)); return *this;} /** * <p>Version of the object.</p> */ inline const Aws::String& GetVersionId() const{ return m_versionId; } /** * <p>Version of the object.</p> */ inline void SetVersionId(const Aws::String& value) { m_versionId = value; } /** * <p>Version of the object.</p> */ inline void SetVersionId(Aws::String&& value) { m_versionId = std::move(value); } /** * <p>Version of the object.</p> */ inline void SetVersionId(const char* value) { m_versionId.assign(value); } /** * <p>Version of the object.</p> */ inline PutObjectResult& WithVersionId(const Aws::String& value) { SetVersionId(value); return *this;} /** * <p>Version of the object.</p> */ inline PutObjectResult& WithVersionId(Aws::String&& value) { SetVersionId(std::move(value)); return *this;} /** * <p>Version of the object.</p> */ inline PutObjectResult& WithVersionId(const char* value) { SetVersionId(value); return *this;} /** * <p>If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.</p> */ inline const Aws::String& GetSSECustomerAlgorithm() const{ return m_sSECustomerAlgorithm; } /** * <p>If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.</p> */ inline void SetSSECustomerAlgorithm(const Aws::String& value) { m_sSECustomerAlgorithm = value; } /** * <p>If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.</p> */ inline void SetSSECustomerAlgorithm(Aws::String&& value) { m_sSECustomerAlgorithm = std::move(value); } /** * <p>If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.</p> */ inline void SetSSECustomerAlgorithm(const char* value) { m_sSECustomerAlgorithm.assign(value); } /** * <p>If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.</p> */ inline PutObjectResult& WithSSECustomerAlgorithm(const Aws::String& value) { SetSSECustomerAlgorithm(value); return *this;} /** * <p>If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.</p> */ inline PutObjectResult& WithSSECustomerAlgorithm(Aws::String&& value) { SetSSECustomerAlgorithm(std::move(value)); return *this;} /** * <p>If server-side encryption with a customer-provided encryption key was * requested, the response will include this header confirming the encryption * algorithm used.</p> */ inline PutObjectResult& WithSSECustomerAlgorithm(const char* value) { SetSSECustomerAlgorithm(value); return *this;} /** * <p>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.</p> */ inline const Aws::String& GetSSECustomerKeyMD5() const{ return m_sSECustomerKeyMD5; } /** * <p>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.</p> */ inline void SetSSECustomerKeyMD5(const Aws::String& value) { m_sSECustomerKeyMD5 = value; } /** * <p>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.</p> */ inline void SetSSECustomerKeyMD5(Aws::String&& value) { m_sSECustomerKeyMD5 = std::move(value); } /** * <p>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.</p> */ inline void SetSSECustomerKeyMD5(const char* value) { m_sSECustomerKeyMD5.assign(value); } /** * <p>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.</p> */ inline PutObjectResult& WithSSECustomerKeyMD5(const Aws::String& value) { SetSSECustomerKeyMD5(value); return *this;} /** * <p>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.</p> */ inline PutObjectResult& WithSSECustomerKeyMD5(Aws::String&& value) { SetSSECustomerKeyMD5(std::move(value)); return *this;} /** * <p>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.</p> */ inline PutObjectResult& WithSSECustomerKeyMD5(const char* value) { SetSSECustomerKeyMD5(value); return *this;} /** * <p>If <code>x-amz-server-side-encryption</code> is present and has the value of * <code>aws:kms</code>, this header 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. </p> */ inline const Aws::String& GetSSEKMSKeyId() const{ return m_sSEKMSKeyId; } /** * <p>If <code>x-amz-server-side-encryption</code> is present and has the value of * <code>aws:kms</code>, this header 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. </p> */ inline void SetSSEKMSKeyId(const Aws::String& value) { m_sSEKMSKeyId = value; } /** * <p>If <code>x-amz-server-side-encryption</code> is present and has the value of * <code>aws:kms</code>, this header 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. </p> */ inline void SetSSEKMSKeyId(Aws::String&& value) { m_sSEKMSKeyId = std::move(value); } /** * <p>If <code>x-amz-server-side-encryption</code> is present and has the value of * <code>aws:kms</code>, this header 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. </p> */ inline void SetSSEKMSKeyId(const char* value) { m_sSEKMSKeyId.assign(value); } /** * <p>If <code>x-amz-server-side-encryption</code> is present and has the value of * <code>aws:kms</code>, this header 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. </p> */ inline PutObjectResult& WithSSEKMSKeyId(const Aws::String& value) { SetSSEKMSKeyId(value); return *this;} /** * <p>If <code>x-amz-server-side-encryption</code> is present and has the value of * <code>aws:kms</code>, this header 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. </p> */ inline PutObjectResult& WithSSEKMSKeyId(Aws::String&& value) { SetSSEKMSKeyId(std::move(value)); return *this;} /** * <p>If <code>x-amz-server-side-encryption</code> is present and has the value of * <code>aws:kms</code>, this header 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. </p> */ inline PutObjectResult& WithSSEKMSKeyId(const char* value) { SetSSEKMSKeyId(value); return *this;} /** * <p>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.</p> */ inline const Aws::String& GetSSEKMSEncryptionContext() const{ return m_sSEKMSEncryptionContext; } /** * <p>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.</p> */ inline void SetSSEKMSEncryptionContext(const Aws::String& value) { m_sSEKMSEncryptionContext = value; } /** * <p>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.</p> */ inline void SetSSEKMSEncryptionContext(Aws::String&& value) { m_sSEKMSEncryptionContext = std::move(value); } /** * <p>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.</p> */ inline void SetSSEKMSEncryptionContext(const char* value) { m_sSEKMSEncryptionContext.assign(value); } /** * <p>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.</p> */ inline PutObjectResult& WithSSEKMSEncryptionContext(const Aws::String& value) { SetSSEKMSEncryptionContext(value); return *this;} /** * <p>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.</p> */ inline PutObjectResult& WithSSEKMSEncryptionContext(Aws::String&& value) { SetSSEKMSEncryptionContext(std::move(value)); return *this;} /** * <p>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.</p> */ inline PutObjectResult& WithSSEKMSEncryptionContext(const char* value) { SetSSEKMSEncryptionContext(value); return *this;} /** * <p>Indicates whether the uploaded object uses an S3 Bucket Key for server-side * encryption with Amazon Web Services KMS (SSE-KMS).</p> */ inline bool GetBucketKeyEnabled() const{ return m_bucketKeyEnabled; } /** * <p>Indicates whether the uploaded object uses an S3 Bucket Key for server-side * encryption with Amazon Web Services KMS (SSE-KMS).</p> */ inline void SetBucketKeyEnabled(bool value) { m_bucketKeyEnabled = value; } /** * <p>Indicates whether the uploaded object uses an S3 Bucket Key for server-side * encryption with Amazon Web Services KMS (SSE-KMS).</p> */ inline PutObjectResult& 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 PutObjectResult& WithRequestCharged(const RequestCharged& value) { SetRequestCharged(value); return *this;} inline PutObjectResult& WithRequestCharged(RequestCharged&& value) { SetRequestCharged(std::move(value)); return *this;} private: 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_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