/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include namespace Aws { namespace Utils { namespace Xml { class XmlNode; } // namespace Xml } // namespace Utils namespace S3Control { namespace Model { /** *

Contains the configuration parameters for a PUT Object ACL operation. S3 * Batch Operations passes every object to the underlying PutObjectAcl * API operation. For more information about the parameters for this operation, see * PutObjectAcl.

See * Also:

AWS * API Reference

*/ class S3SetObjectAclOperation { public: AWS_S3CONTROL_API S3SetObjectAclOperation(); AWS_S3CONTROL_API S3SetObjectAclOperation(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_S3CONTROL_API S3SetObjectAclOperation& operator=(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_S3CONTROL_API void AddToNode(Aws::Utils::Xml::XmlNode& parentNode) const; /** *

*/ inline const S3AccessControlPolicy& GetAccessControlPolicy() const{ return m_accessControlPolicy; } /** *

*/ inline bool AccessControlPolicyHasBeenSet() const { return m_accessControlPolicyHasBeenSet; } /** *

*/ inline void SetAccessControlPolicy(const S3AccessControlPolicy& value) { m_accessControlPolicyHasBeenSet = true; m_accessControlPolicy = value; } /** *

*/ inline void SetAccessControlPolicy(S3AccessControlPolicy&& value) { m_accessControlPolicyHasBeenSet = true; m_accessControlPolicy = std::move(value); } /** *

*/ inline S3SetObjectAclOperation& WithAccessControlPolicy(const S3AccessControlPolicy& value) { SetAccessControlPolicy(value); return *this;} /** *

*/ inline S3SetObjectAclOperation& WithAccessControlPolicy(S3AccessControlPolicy&& value) { SetAccessControlPolicy(std::move(value)); return *this;} private: S3AccessControlPolicy m_accessControlPolicy; bool m_accessControlPolicyHasBeenSet = false; }; } // namespace Model } // namespace S3Control } // namespace Aws