1 /**
2 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3 * SPDX-License-Identifier: Apache-2.0.
4 */
5
6 #include <aws/s3/model/PutObjectAclRequest.h>
7 #include <aws/core/utils/xml/XmlSerializer.h>
8 #include <aws/core/utils/memory/stl/AWSStringStream.h>
9 #include <aws/core/http/URI.h>
10 #include <aws/core/utils/memory/stl/AWSStringStream.h>
11
12 #include <utility>
13
14 using namespace Aws::S3::Model;
15 using namespace Aws::Utils::Xml;
16 using namespace Aws::Utils;
17 using namespace Aws::Http;
18
PutObjectAclRequest()19 PutObjectAclRequest::PutObjectAclRequest() :
20 m_aCL(ObjectCannedACL::NOT_SET),
21 m_aCLHasBeenSet(false),
22 m_accessControlPolicyHasBeenSet(false),
23 m_bucketHasBeenSet(false),
24 m_contentMD5HasBeenSet(false),
25 m_grantFullControlHasBeenSet(false),
26 m_grantReadHasBeenSet(false),
27 m_grantReadACPHasBeenSet(false),
28 m_grantWriteHasBeenSet(false),
29 m_grantWriteACPHasBeenSet(false),
30 m_keyHasBeenSet(false),
31 m_requestPayer(RequestPayer::NOT_SET),
32 m_requestPayerHasBeenSet(false),
33 m_versionIdHasBeenSet(false),
34 m_expectedBucketOwnerHasBeenSet(false),
35 m_customizedAccessLogTagHasBeenSet(false)
36 {
37 }
38
SerializePayload() const39 Aws::String PutObjectAclRequest::SerializePayload() const
40 {
41 XmlDocument payloadDoc = XmlDocument::CreateWithRootNode("AccessControlPolicy");
42
43 XmlNode parentNode = payloadDoc.GetRootElement();
44 parentNode.SetAttributeValue("xmlns", "http://s3.amazonaws.com/doc/2006-03-01/");
45
46 m_accessControlPolicy.AddToNode(parentNode);
47 if(parentNode.HasChildren())
48 {
49 return payloadDoc.ConvertToString();
50 }
51
52 return {};
53 }
54
AddQueryStringParameters(URI & uri) const55 void PutObjectAclRequest::AddQueryStringParameters(URI& uri) const
56 {
57 Aws::StringStream ss;
58 if(m_versionIdHasBeenSet)
59 {
60 ss << m_versionId;
61 uri.AddQueryStringParameter("versionId", ss.str());
62 ss.str("");
63 }
64
65 if(!m_customizedAccessLogTag.empty())
66 {
67 // only accept customized LogTag which starts with "x-"
68 Aws::Map<Aws::String, Aws::String> collectedLogTags;
69 for(const auto& entry: m_customizedAccessLogTag)
70 {
71 if (!entry.first.empty() && !entry.second.empty() && entry.first.substr(0, 2) == "x-")
72 {
73 collectedLogTags.emplace(entry.first, entry.second);
74 }
75 }
76
77 if (!collectedLogTags.empty())
78 {
79 uri.AddQueryStringParameter(collectedLogTags);
80 }
81 }
82 }
83
GetRequestSpecificHeaders() const84 Aws::Http::HeaderValueCollection PutObjectAclRequest::GetRequestSpecificHeaders() const
85 {
86 Aws::Http::HeaderValueCollection headers;
87 Aws::StringStream ss;
88 if(m_aCLHasBeenSet)
89 {
90 headers.emplace("x-amz-acl", ObjectCannedACLMapper::GetNameForObjectCannedACL(m_aCL));
91 }
92
93 if(m_contentMD5HasBeenSet)
94 {
95 ss << m_contentMD5;
96 headers.emplace("content-md5", ss.str());
97 ss.str("");
98 }
99
100 if(m_grantFullControlHasBeenSet)
101 {
102 ss << m_grantFullControl;
103 headers.emplace("x-amz-grant-full-control", ss.str());
104 ss.str("");
105 }
106
107 if(m_grantReadHasBeenSet)
108 {
109 ss << m_grantRead;
110 headers.emplace("x-amz-grant-read", ss.str());
111 ss.str("");
112 }
113
114 if(m_grantReadACPHasBeenSet)
115 {
116 ss << m_grantReadACP;
117 headers.emplace("x-amz-grant-read-acp", ss.str());
118 ss.str("");
119 }
120
121 if(m_grantWriteHasBeenSet)
122 {
123 ss << m_grantWrite;
124 headers.emplace("x-amz-grant-write", ss.str());
125 ss.str("");
126 }
127
128 if(m_grantWriteACPHasBeenSet)
129 {
130 ss << m_grantWriteACP;
131 headers.emplace("x-amz-grant-write-acp", ss.str());
132 ss.str("");
133 }
134
135 if(m_requestPayerHasBeenSet)
136 {
137 headers.emplace("x-amz-request-payer", RequestPayerMapper::GetNameForRequestPayer(m_requestPayer));
138 }
139
140 if(m_expectedBucketOwnerHasBeenSet)
141 {
142 ss << m_expectedBucketOwner;
143 headers.emplace("x-amz-expected-bucket-owner", ss.str());
144 ss.str("");
145 }
146
147 return headers;
148 }
149