/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #include <aws/s3/model/PublicAccessBlockConfiguration.h> #include <aws/core/utils/xml/XmlSerializer.h> #include <aws/core/utils/StringUtils.h> #include <aws/core/utils/memory/stl/AWSStringStream.h> #include <utility> using namespace Aws::Utils::Xml; using namespace Aws::Utils; namespace Aws { namespace S3 { namespace Model { PublicAccessBlockConfiguration::PublicAccessBlockConfiguration() : m_blockPublicAcls(false), m_blockPublicAclsHasBeenSet(false), m_ignorePublicAcls(false), m_ignorePublicAclsHasBeenSet(false), m_blockPublicPolicy(false), m_blockPublicPolicyHasBeenSet(false), m_restrictPublicBuckets(false), m_restrictPublicBucketsHasBeenSet(false) { } PublicAccessBlockConfiguration::PublicAccessBlockConfiguration(const XmlNode& xmlNode) : m_blockPublicAcls(false), m_blockPublicAclsHasBeenSet(false), m_ignorePublicAcls(false), m_ignorePublicAclsHasBeenSet(false), m_blockPublicPolicy(false), m_blockPublicPolicyHasBeenSet(false), m_restrictPublicBuckets(false), m_restrictPublicBucketsHasBeenSet(false) { *this = xmlNode; } PublicAccessBlockConfiguration& PublicAccessBlockConfiguration::operator =(const XmlNode& xmlNode) { XmlNode resultNode = xmlNode; if(!resultNode.IsNull()) { XmlNode blockPublicAclsNode = resultNode.FirstChild("BlockPublicAcls"); if(!blockPublicAclsNode.IsNull()) { m_blockPublicAcls = StringUtils::ConvertToBool(StringUtils::Trim(Aws::Utils::Xml::DecodeEscapedXmlText(blockPublicAclsNode.GetText()).c_str()).c_str()); m_blockPublicAclsHasBeenSet = true; } XmlNode ignorePublicAclsNode = resultNode.FirstChild("IgnorePublicAcls"); if(!ignorePublicAclsNode.IsNull()) { m_ignorePublicAcls = StringUtils::ConvertToBool(StringUtils::Trim(Aws::Utils::Xml::DecodeEscapedXmlText(ignorePublicAclsNode.GetText()).c_str()).c_str()); m_ignorePublicAclsHasBeenSet = true; } XmlNode blockPublicPolicyNode = resultNode.FirstChild("BlockPublicPolicy"); if(!blockPublicPolicyNode.IsNull()) { m_blockPublicPolicy = StringUtils::ConvertToBool(StringUtils::Trim(Aws::Utils::Xml::DecodeEscapedXmlText(blockPublicPolicyNode.GetText()).c_str()).c_str()); m_blockPublicPolicyHasBeenSet = true; } XmlNode restrictPublicBucketsNode = resultNode.FirstChild("RestrictPublicBuckets"); if(!restrictPublicBucketsNode.IsNull()) { m_restrictPublicBuckets = StringUtils::ConvertToBool(StringUtils::Trim(Aws::Utils::Xml::DecodeEscapedXmlText(restrictPublicBucketsNode.GetText()).c_str()).c_str()); m_restrictPublicBucketsHasBeenSet = true; } } return *this; } void PublicAccessBlockConfiguration::AddToNode(XmlNode& parentNode) const { Aws::StringStream ss; if(m_blockPublicAclsHasBeenSet) { XmlNode blockPublicAclsNode = parentNode.CreateChildElement("BlockPublicAcls"); ss << std::boolalpha << m_blockPublicAcls; blockPublicAclsNode.SetText(ss.str()); ss.str(""); } if(m_ignorePublicAclsHasBeenSet) { XmlNode ignorePublicAclsNode = parentNode.CreateChildElement("IgnorePublicAcls"); ss << std::boolalpha << m_ignorePublicAcls; ignorePublicAclsNode.SetText(ss.str()); ss.str(""); } if(m_blockPublicPolicyHasBeenSet) { XmlNode blockPublicPolicyNode = parentNode.CreateChildElement("BlockPublicPolicy"); ss << std::boolalpha << m_blockPublicPolicy; blockPublicPolicyNode.SetText(ss.str()); ss.str(""); } if(m_restrictPublicBucketsHasBeenSet) { XmlNode restrictPublicBucketsNode = parentNode.CreateChildElement("RestrictPublicBuckets"); ss << std::boolalpha << m_restrictPublicBuckets; restrictPublicBucketsNode.SetText(ss.str()); ss.str(""); } } } // namespace Model } // namespace S3 } // namespace Aws