1 | /* |
---|---|
2 | * Copyright 2010-2017 Amazon.com, Inc. or its affiliates. All Rights Reserved. |
3 | * |
4 | * Licensed under the Apache License, Version 2.0 (the "License"). |
5 | * You may not use this file except in compliance with the License. |
6 | * A copy of the License is located at |
7 | * |
8 | * http://aws.amazon.com/apache2.0 |
9 | * |
10 | * or in the "license" file accompanying this file. This file is distributed |
11 | * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either |
12 | * express or implied. See the License for the specific language governing |
13 | * permissions and limitations under the License. |
14 | */ |
15 | |
16 | #include <aws/s3/model/UploadPartResult.h> |
17 | #include <aws/core/utils/xml/XmlSerializer.h> |
18 | #include <aws/core/AmazonWebServiceResult.h> |
19 | #include <aws/core/utils/StringUtils.h> |
20 | #include <aws/core/utils/memory/stl/AWSStringStream.h> |
21 | |
22 | #include <utility> |
23 | |
24 | using namespace Aws::S3::Model; |
25 | using namespace Aws::Utils::Xml; |
26 | using namespace Aws::Utils; |
27 | using namespace Aws; |
28 | |
29 | UploadPartResult::UploadPartResult() : |
30 | m_serverSideEncryption(ServerSideEncryption::NOT_SET), |
31 | m_requestCharged(RequestCharged::NOT_SET) |
32 | { |
33 | } |
34 | |
35 | UploadPartResult::UploadPartResult(const Aws::AmazonWebServiceResult<XmlDocument>& result) : |
36 | m_serverSideEncryption(ServerSideEncryption::NOT_SET), |
37 | m_requestCharged(RequestCharged::NOT_SET) |
38 | { |
39 | *this = result; |
40 | } |
41 | |
42 | UploadPartResult& UploadPartResult::operator =(const Aws::AmazonWebServiceResult<XmlDocument>& result) |
43 | { |
44 | const XmlDocument& xmlDocument = result.GetPayload(); |
45 | XmlNode resultNode = xmlDocument.GetRootElement(); |
46 | |
47 | if(!resultNode.IsNull()) |
48 | { |
49 | } |
50 | |
51 | const auto& headers = result.GetHeaderValueCollection(); |
52 | const auto& serverSideEncryptionIter = headers.find("x-amz-server-side-encryption"); |
53 | if(serverSideEncryptionIter != headers.end()) |
54 | { |
55 | m_serverSideEncryption = ServerSideEncryptionMapper::GetServerSideEncryptionForName(serverSideEncryptionIter->second); |
56 | } |
57 | |
58 | const auto& eTagIter = headers.find("etag"); |
59 | if(eTagIter != headers.end()) |
60 | { |
61 | m_eTag = eTagIter->second; |
62 | } |
63 | |
64 | const auto& sSECustomerAlgorithmIter = headers.find("x-amz-server-side-encryption-customer-algorithm"); |
65 | if(sSECustomerAlgorithmIter != headers.end()) |
66 | { |
67 | m_sSECustomerAlgorithm = sSECustomerAlgorithmIter->second; |
68 | } |
69 | |
70 | const auto& sSECustomerKeyMD5Iter = headers.find("x-amz-server-side-encryption-customer-key-md5"); |
71 | if(sSECustomerKeyMD5Iter != headers.end()) |
72 | { |
73 | m_sSECustomerKeyMD5 = sSECustomerKeyMD5Iter->second; |
74 | } |
75 | |
76 | const auto& sSEKMSKeyIdIter = headers.find("x-amz-server-side-encryption-aws-kms-key-id"); |
77 | if(sSEKMSKeyIdIter != headers.end()) |
78 | { |
79 | m_sSEKMSKeyId = sSEKMSKeyIdIter->second; |
80 | } |
81 | |
82 | const auto& requestChargedIter = headers.find("x-amz-request-charged"); |
83 | if(requestChargedIter != headers.end()) |
84 | { |
85 | m_requestCharged = RequestChargedMapper::GetRequestChargedForName(requestChargedIter->second); |
86 | } |
87 | |
88 | return *this; |
89 | } |
90 |