GDAL
cpl_aws.h
1/**********************************************************************
2 * $Id: cpl_aws.h 6df253b7cb1bb04d8fa847106b60ff190f23235b 2019-06-07 20:50:53 +0200 Even Rouault $
3 *
4 * Name: cpl_aws.h
5 * Project: CPL - Common Portability Library
6 * Purpose: Amazon Web Services routines
7 * Author: Even Rouault <even.rouault at spatialys.com>
8 *
9 **********************************************************************
10 * Copyright (c) 2015, Even Rouault <even.rouault at spatialys.com>
11 *
12 * Permission is hereby granted, free of charge, to any person obtaining a
13 * copy of this software and associated documentation files (the "Software"),
14 * to deal in the Software without restriction, including without limitation
15 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
16 * and/or sell copies of the Software, and to permit persons to whom the
17 * Software is furnished to do so, subject to the following conditions:
18 *
19 * The above copyright notice and this permission notice shall be included
20 * in all copies or substantial portions of the Software.
21 *
22 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
23 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
24 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
25 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
26 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
27 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
28 * DEALINGS IN THE SOFTWARE.
29 ****************************************************************************/
30
31#ifndef CPL_AWS_INCLUDED_H
32#define CPL_AWS_INCLUDED_H
33
34#ifndef DOXYGEN_SKIP
35
36#ifdef HAVE_CURL
37
38#include <cstddef>
39
40#include "cpl_string.h"
41
42#include <curl/curl.h>
43#include <map>
44
45CPLString CPLGetLowerCaseHexSHA256( const void *pabyData, size_t nBytes );
46CPLString CPLGetLowerCaseHexSHA256( const CPLString& osStr );
47
48CPLString CPLGetAWS_SIGN4_Timestamp();
49
50CPLString CPLAWSURLEncode(const CPLString& osURL, bool bEncodeSlash = true);
51
52CPLString CPLAWSGetHeaderVal(const struct curl_slist* psExistingHeaders,
53 const char* pszKey);
54
56CPLGetAWS_SIGN4_Signature( const CPLString& osSecretAccessKey,
57 const CPLString& osAccessToken,
58 const CPLString& osRegion,
59 const CPLString& osRequestPayer,
60 const CPLString& osService,
61 const CPLString& osVerb,
62 const struct curl_slist* psExistingHeaders,
63 const CPLString& osHost,
64 const CPLString& osCanonicalURI,
65 const CPLString& osCanonicalQueryString,
66 const CPLString& osXAMZContentSHA256,
67 const CPLString& osTimestamp,
68 CPLString& osSignedHeaders );
69
70CPLString CPLGetAWS_SIGN4_Authorization(const CPLString& osSecretAccessKey,
71 const CPLString& osAccessKeyId,
72 const CPLString& osAccessToken,
73 const CPLString& osRegion,
74 const CPLString& osRequestPayer,
75 const CPLString& osService,
76 const CPLString& osVerb,
77 const struct curl_slist* psExistingHeaders,
78 const CPLString& osHost,
79 const CPLString& osCanonicalURI,
80 const CPLString& osCanonicalQueryString,
81 const CPLString& osXAMZContentSHA256,
82 const CPLString& osTimestamp);
83
84class IVSIS3LikeHandleHelper
85{
86 CPL_DISALLOW_COPY_ASSIGN(IVSIS3LikeHandleHelper)
87
88protected:
89 std::map<CPLString, CPLString> m_oMapQueryParameters{};
90
91 virtual void RebuildURL() = 0;
92 CPLString GetQueryString(bool bAddEmptyValueAfterEqual) const;
93
94public:
95 IVSIS3LikeHandleHelper() = default;
96 virtual ~IVSIS3LikeHandleHelper() = default;
97
98 void ResetQueryParameters();
99 void AddQueryParameter(const CPLString& osKey, const CPLString& osValue);
100
101 virtual struct curl_slist* GetCurlHeaders(const CPLString& osVerb,
102 const struct curl_slist* psExistingHeaders,
103 const void *pabyDataContent = nullptr,
104 size_t nBytesContent = 0) const = 0;
105
106 virtual bool AllowAutomaticRedirection() { return true; }
107 virtual bool CanRestartOnError(const char*, const char* /* pszHeaders*/,
108 bool /*bSetError*/, bool* /*pbUpdateMap*/ = nullptr) { return false;}
109
110 virtual const CPLString& GetURL() const = 0;
111
112 static bool GetBucketAndObjectKey(const char* pszURI,
113 const char* pszFSPrefix,
114 bool bAllowNoObject,
115 CPLString &osBucketOut,
116 CPLString &osObjectKeyOut);
117
118 static CPLString BuildCanonicalizedHeaders(
119 std::map<CPLString, CPLString>& oSortedMapHeaders,
120 const struct curl_slist* psExistingHeaders,
121 const char* pszHeaderPrefix);
122
123 static CPLString GetRFC822DateTime();
124};
125
126class VSIS3HandleHelper final: public IVSIS3LikeHandleHelper
127{
128 CPL_DISALLOW_COPY_ASSIGN(VSIS3HandleHelper)
129
130 CPLString m_osURL{};
131 mutable CPLString m_osSecretAccessKey{};
132 mutable CPLString m_osAccessKeyId{};
133 mutable CPLString m_osSessionToken{};
134 CPLString m_osEndpoint{};
135 CPLString m_osRegion{};
136 CPLString m_osRequestPayer{};
137 CPLString m_osBucket{};
138 CPLString m_osObjectKey{};
139 bool m_bUseHTTPS = false;
140 bool m_bUseVirtualHosting = false;
141 bool m_bFromEC2 = false;
142
143 void RebuildURL() override;
144
145 static bool GetConfigurationFromEC2(CPLString& osSecretAccessKey,
146 CPLString& osAccessKeyId,
147 CPLString& osSessionToken);
148
149 static bool GetConfigurationFromAWSConfigFiles(
150 CPLString& osSecretAccessKey,
151 CPLString& osAccessKeyId,
152 CPLString& osSessionToken,
153 CPLString& osRegion,
154 CPLString& osCredentials);
155
156 static bool GetConfiguration(CSLConstList papszOptions,
157 CPLString& osSecretAccessKey,
158 CPLString& osAccessKeyId,
159 CPLString& osSessionToken,
160 CPLString& osRegion,
161 bool& bFromEC2);
162 protected:
163
164 public:
165 VSIS3HandleHelper(const CPLString& osSecretAccessKey,
166 const CPLString& osAccessKeyId,
167 const CPLString& osSessionToken,
168 const CPLString& osEndpoint,
169 const CPLString& osRegion,
170 const CPLString& osRequestPayer,
171 const CPLString& osBucket,
172 const CPLString& osObjectKey,
173 bool bUseHTTPS, bool bUseVirtualHosting, bool bFromEC2);
174 ~VSIS3HandleHelper();
175
176 static VSIS3HandleHelper* BuildFromURI(const char* pszURI,
177 const char* pszFSPrefix,
178 bool bAllowNoObject,
179 CSLConstList papszOptions = nullptr);
180 static CPLString BuildURL(const CPLString& osEndpoint,
181 const CPLString& osBucket,
182 const CPLString& osObjectKey,
183 bool bUseHTTPS, bool bUseVirtualHosting);
184
185 struct curl_slist* GetCurlHeaders(
186 const CPLString& osVerb,
187 const struct curl_slist* psExistingHeaders,
188 const void *pabyDataContent = nullptr,
189 size_t nBytesContent = 0) const override;
190
191 bool AllowAutomaticRedirection() override { return false; }
192 bool CanRestartOnError(const char*, const char* pszHeaders,
193 bool bSetError,
194 bool* pbUpdateMap = nullptr) override;
195
196 const CPLString& GetURL() const override { return m_osURL; }
197 const CPLString& GetBucket() const { return m_osBucket; }
198 const CPLString& GetObjectKey() const { return m_osObjectKey; }
199 const CPLString& GetEndpoint()const { return m_osEndpoint; }
200 const CPLString& GetRegion() const { return m_osRegion; }
201 const CPLString& GetRequestPayer() const { return m_osRequestPayer; }
202 bool GetVirtualHosting() const { return m_bUseVirtualHosting; }
203 void SetEndpoint(const CPLString &osStr);
204 void SetRegion(const CPLString &osStr);
205 void SetRequestPayer(const CPLString &osStr);
206 void SetVirtualHosting(bool b);
207
208 CPLString GetSignedURL(CSLConstList papszOptions);
209
210 static void CleanMutex();
211 static void ClearCache();
212};
213
214class VSIS3UpdateParams
215{
216 public:
217 CPLString m_osRegion{};
218 CPLString m_osEndpoint{};
219 CPLString m_osRequestPayer{};
220 bool m_bUseVirtualHosting = false;
221
222 VSIS3UpdateParams() = default;
223
224 explicit VSIS3UpdateParams(const VSIS3HandleHelper* poHelper) :
225 m_osRegion(poHelper->GetRegion()),
226 m_osEndpoint(poHelper->GetEndpoint()),
227 m_osRequestPayer(poHelper->GetRequestPayer()),
228 m_bUseVirtualHosting(poHelper->GetVirtualHosting()) {}
229
230 void UpdateHandlerHelper(VSIS3HandleHelper* poHelper) {
231 poHelper->SetRegion(m_osRegion);
232 poHelper->SetEndpoint(m_osEndpoint);
233 poHelper->SetRequestPayer(m_osRequestPayer);
234 poHelper->SetVirtualHosting(m_bUseVirtualHosting);
235 }
236};
237
238#endif /* HAVE_CURL */
239
240#endif /* #ifndef DOXYGEN_SKIP */
241
242#endif /* CPL_AWS_INCLUDED_H */
Convenient string class based on std::string.
Definition: cpl_string.h:330
#define CPL_DISALLOW_COPY_ASSIGN(ClassName)
Helper to remove the copy and assignment constructors so that the compiler will not generate the defa...
Definition: cpl_port.h:997
char ** CSLConstList
Type of a constant null-terminated list of nul terminated strings.
Definition: cpl_port.h:1194
Various convenience functions for working with strings and string lists.

Generated for GDAL by doxygen 1.9.4.