aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/aws-sdk-cpp/aws-cpp-sdk-s3/source/model/Encryption.cpp
diff options
context:
space:
mode:
authorDevtools Arcadia <arcadia-devtools@yandex-team.ru>2022-02-07 18:08:42 +0300
committerDevtools Arcadia <arcadia-devtools@mous.vla.yp-c.yandex.net>2022-02-07 18:08:42 +0300
commit1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch)
treee26c9fed0de5d9873cce7e00bc214573dc2195b7 /contrib/libs/aws-sdk-cpp/aws-cpp-sdk-s3/source/model/Encryption.cpp
downloadydb-1110808a9d39d4b808aef724c861a2e1a38d2a69.tar.gz
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'contrib/libs/aws-sdk-cpp/aws-cpp-sdk-s3/source/model/Encryption.cpp')
-rw-r--r--contrib/libs/aws-sdk-cpp/aws-cpp-sdk-s3/source/model/Encryption.cpp94
1 files changed, 94 insertions, 0 deletions
diff --git a/contrib/libs/aws-sdk-cpp/aws-cpp-sdk-s3/source/model/Encryption.cpp b/contrib/libs/aws-sdk-cpp/aws-cpp-sdk-s3/source/model/Encryption.cpp
new file mode 100644
index 0000000000..3bd7d72fd4
--- /dev/null
+++ b/contrib/libs/aws-sdk-cpp/aws-cpp-sdk-s3/source/model/Encryption.cpp
@@ -0,0 +1,94 @@
+/**
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
+ * SPDX-License-Identifier: Apache-2.0.
+ */
+
+#include <aws/s3/model/Encryption.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
+{
+
+Encryption::Encryption() :
+ m_encryptionType(ServerSideEncryption::NOT_SET),
+ m_encryptionTypeHasBeenSet(false),
+ m_kMSKeyIdHasBeenSet(false),
+ m_kMSContextHasBeenSet(false)
+{
+}
+
+Encryption::Encryption(const XmlNode& xmlNode) :
+ m_encryptionType(ServerSideEncryption::NOT_SET),
+ m_encryptionTypeHasBeenSet(false),
+ m_kMSKeyIdHasBeenSet(false),
+ m_kMSContextHasBeenSet(false)
+{
+ *this = xmlNode;
+}
+
+Encryption& Encryption::operator =(const XmlNode& xmlNode)
+{
+ XmlNode resultNode = xmlNode;
+
+ if(!resultNode.IsNull())
+ {
+ XmlNode encryptionTypeNode = resultNode.FirstChild("EncryptionType");
+ if(!encryptionTypeNode.IsNull())
+ {
+ m_encryptionType = ServerSideEncryptionMapper::GetServerSideEncryptionForName(StringUtils::Trim(Aws::Utils::Xml::DecodeEscapedXmlText(encryptionTypeNode.GetText()).c_str()).c_str());
+ m_encryptionTypeHasBeenSet = true;
+ }
+ XmlNode kMSKeyIdNode = resultNode.FirstChild("KMSKeyId");
+ if(!kMSKeyIdNode.IsNull())
+ {
+ m_kMSKeyId = Aws::Utils::Xml::DecodeEscapedXmlText(kMSKeyIdNode.GetText());
+ m_kMSKeyIdHasBeenSet = true;
+ }
+ XmlNode kMSContextNode = resultNode.FirstChild("KMSContext");
+ if(!kMSContextNode.IsNull())
+ {
+ m_kMSContext = Aws::Utils::Xml::DecodeEscapedXmlText(kMSContextNode.GetText());
+ m_kMSContextHasBeenSet = true;
+ }
+ }
+
+ return *this;
+}
+
+void Encryption::AddToNode(XmlNode& parentNode) const
+{
+ Aws::StringStream ss;
+ if(m_encryptionTypeHasBeenSet)
+ {
+ XmlNode encryptionTypeNode = parentNode.CreateChildElement("EncryptionType");
+ encryptionTypeNode.SetText(ServerSideEncryptionMapper::GetNameForServerSideEncryption(m_encryptionType));
+ }
+
+ if(m_kMSKeyIdHasBeenSet)
+ {
+ XmlNode kMSKeyIdNode = parentNode.CreateChildElement("KMSKeyId");
+ kMSKeyIdNode.SetText(m_kMSKeyId);
+ }
+
+ if(m_kMSContextHasBeenSet)
+ {
+ XmlNode kMSContextNode = parentNode.CreateChildElement("KMSContext");
+ kMSContextNode.SetText(m_kMSContext);
+ }
+
+}
+
+} // namespace Model
+} // namespace S3
+} // namespace Aws