/**
* 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