14#include "azure/core/dll_import_export.hpp"
17#include "azure/core/internal/http/http_sanitizer.hpp"
27#include <shared_mutex>
41namespace Azure {
namespace Core {
namespace Http {
namespace Policies {
43 struct TransportOptions;
45 std::shared_ptr<HttpTransport> GetTransportAdapter(TransportOptions
const& transportOptions);
47 AZ_CORE_DLLEXPORT
extern std::set<std::string>
const g_defaultAllowedHttpQueryParameters;
48 AZ_CORE_DLLEXPORT
extern CaseInsensitiveSet
const g_defaultAllowedHttpHeaders;
52 class TelemetryPolicy;
82 friend class _internal::TelemetryPolicy;
83 long CppStandardVersion =
84#if defined(_azure_BUILDING_SDK)
86#elif defined(_azure_BUILDING_TESTS)
88#elif defined(_azure_BUILDING_SAMPLES)
92#if defined(_MSVC_LANG) && __cplusplus == 199711L
120 std::chrono::milliseconds
RetryDelay = std::chrono::milliseconds(800);
134 HttpStatusCode::RequestTimeout,
135 HttpStatusCode::InternalServerError,
136 HttpStatusCode::BadGateway,
137 HttpStatusCode::ServiceUnavailable,
138 HttpStatusCode::GatewayTimeout,
275 virtual std::unique_ptr<RawResponse>
Send(
278 Context const& context)
const = 0;
290 virtual std::unique_ptr<HttpPolicy>
Clone()
const = 0;
332 const size_t m_index;
333 const std::vector<std::unique_ptr<HttpPolicy>>& m_policies;
344 explicit NextHttpPolicy(
size_t index,
const std::vector<std::unique_ptr<HttpPolicy>>& policies)
345 : m_index(index), m_policies(policies)
361 namespace _internal {
367 class TransportPolicy final :
public HttpPolicy {
369 TransportOptions m_options;
377 explicit TransportPolicy(TransportOptions
const& options = TransportOptions());
379 std::unique_ptr<HttpPolicy> Clone()
const override
381 return std::make_unique<TransportPolicy>(*
this);
384 std::unique_ptr<RawResponse> Send(
386 NextHttpPolicy nextPolicy,
387 Context const& context)
const override;
394#if !defined(_azure_TESTING_BUILD)
397 :
public HttpPolicy {
399 RetryOptions m_retryOptions;
407 explicit RetryPolicy(RetryOptions options) : m_retryOptions(std::move(options)) {}
409 std::unique_ptr<HttpPolicy> Clone()
const override
411 return std::make_unique<RetryPolicy>(*
this);
414 std::unique_ptr<RawResponse>
Send(
416 NextHttpPolicy nextPolicy,
417 Context
const& context)
const final;
430 static int32_t GetRetryCount(Context
const& context);
433 virtual bool ShouldRetryOnTransportFailure(
434 RetryOptions
const& retryOptions,
436 std::chrono::milliseconds& retryAfter,
437 double jitterFactor = -1)
const;
439 virtual bool ShouldRetryOnResponse(
440 RawResponse
const& response,
441 RetryOptions
const& retryOptions,
443 std::chrono::milliseconds& retryAfter,
444 double jitterFactor = -1)
const;
453 class RequestIdPolicy final :
public HttpPolicy {
455 constexpr static const char* RequestIdHeader =
"x-ms-client-request-id";
462 explicit RequestIdPolicy() {}
464 std::unique_ptr<HttpPolicy>
Clone()
const override
466 return std::make_unique<RequestIdPolicy>(*
this);
469 std::unique_ptr<RawResponse>
Send(
471 NextHttpPolicy nextPolicy,
472 Context
const& context)
const override
474 if (!request.GetHeader(RequestIdHeader).HasValue())
477 request.SetHeader(RequestIdHeader, uuid);
480 return nextPolicy.Send(request, context);
492 class RequestActivityPolicy final :
public HttpPolicy {
494 Azure::Core::Http::_internal::HttpSanitizer m_httpSanitizer;
506 explicit RequestActivityPolicy(
507 Azure::Core::Http::_internal::HttpSanitizer
const& httpSanitizer)
508 : m_httpSanitizer(httpSanitizer)
512 std::unique_ptr<HttpPolicy>
Clone()
const override
514 return std::make_unique<RequestActivityPolicy>(*
this);
517 std::unique_ptr<RawResponse>
Send(
519 NextHttpPolicy nextPolicy,
520 Context
const& context)
const override;
536 class TelemetryPolicy final :
public HttpPolicy {
538 std::string
const m_telemetryId;
548 explicit TelemetryPolicy(
549 std::string
const& packageName,
550 std::string
const& packageVersion,
551 TelemetryOptions options = TelemetryOptions())
552 : m_telemetryId(
Azure::Core::Http::_internal::HttpShared::GenerateUserAgent(
555 options.ApplicationId,
556 options.CppStandardVersion))
560 std::unique_ptr<HttpPolicy>
Clone()
const override
562 return std::make_unique<TelemetryPolicy>(*
this);
565 std::unique_ptr<RawResponse>
Send(
567 NextHttpPolicy nextPolicy,
568 Context
const& context)
const override;
575 class BearerTokenAuthenticationPolicy :
public HttpPolicy {
577 std::shared_ptr<Credentials::TokenCredential const>
const m_credential;
578 Credentials::TokenRequestContext m_tokenRequestContext;
580 mutable Credentials::AccessToken m_accessToken;
581 mutable std::shared_timed_mutex m_accessTokenMutex;
582 mutable Credentials::TokenRequestContext m_accessTokenContext;
583 mutable std::atomic<bool> m_invalidateToken = {
false};
592 explicit BearerTokenAuthenticationPolicy(
593 std::shared_ptr<Credentials::TokenCredential const> credential,
594 Credentials::TokenRequestContext tokenRequestContext)
595 : m_credential(std::move(credential)),
596 m_tokenRequestContext(std::move(tokenRequestContext))
600 std::unique_ptr<HttpPolicy>
Clone()
const override
603 return std::unique_ptr<HttpPolicy>(
new BearerTokenAuthenticationPolicy(*
this));
606 std::unique_ptr<RawResponse>
Send(
608 NextHttpPolicy nextPolicy,
609 Context
const& context)
const override;
612 BearerTokenAuthenticationPolicy(BearerTokenAuthenticationPolicy
const& other)
613 : BearerTokenAuthenticationPolicy(other.m_credential, other.m_tokenRequestContext)
615 std::shared_lock<std::shared_timed_mutex> readLock(other.m_accessTokenMutex);
616 m_accessToken = other.m_accessToken;
617 m_accessTokenContext = other.m_accessTokenContext;
618 m_invalidateToken.store(other.m_invalidateToken.load());
621 void operator=(BearerTokenAuthenticationPolicy
const&) =
delete;
623 virtual std::unique_ptr<RawResponse> AuthorizeAndSendRequest(
625 NextHttpPolicy& nextPolicy,
626 Context
const& context)
const;
628 virtual bool AuthorizeRequestOnChallenge(
629 std::string
const& challenge,
631 Context
const& context)
const;
633 void AuthenticateAndAuthorizeRequest(
635 Credentials::TokenRequestContext
const& tokenRequestContext,
636 Context
const& context)
const;
645 class LogPolicy final :
public HttpPolicy {
646 LogOptions m_options;
647 Azure::Core::Http::_internal::HttpSanitizer m_httpSanitizer;
654 explicit LogPolicy(LogOptions options)
655 : m_options(std::move(options)),
656 m_httpSanitizer(m_options.AllowedHttpQueryParameters, m_options.AllowedHttpHeaders)
660 std::unique_ptr<HttpPolicy>
Clone()
const override
662 return std::make_unique<LogPolicy>(*
this);
665 std::unique_ptr<RawResponse>
Send(
667 NextHttpPolicy nextPolicy,
668 Context
const& context)
const override;
A map<string, string> with case-insensitive key comparison.
std::set< std::string, _internal::StringExtensions::CaseInsensitiveComparator > CaseInsensitiveSet
A type alias of std::set<std::string> with case-insensitive element comparison.
Definition case_insensitive_containers.hpp:31
A context is a node within a unidirectional tree that represents deadlines and key/value pairs.
Definition context.hpp:72
HTTP policy base class.
Definition policy.hpp:259
virtual ~HttpPolicy()
Destructs HttpPolicy.
Definition policy.hpp:284
HttpPolicy()=default
Constructs a default instance of HttpPolicy.
HttpPolicy & operator=(const HttpPolicy &other)=default
Assigns this HttpPolicy to copy the other.
virtual std::unique_ptr< HttpPolicy > Clone() const =0
Creates a clone of this HttpPolicy.
HttpPolicy(HttpPolicy &&other)=default
Constructs HttpPolicy by moving other HttpPolicy.
HttpPolicy(const HttpPolicy &other)=default
Constructs a copy of other HttpPolicy.
virtual std::unique_ptr< RawResponse > Send(Request &request, NextHttpPolicy nextPolicy, Context const &context) const =0
Applies this HTTP policy.
The next HTTP policy in the stack sequence of policies.
Definition policy.hpp:331
NextHttpPolicy(size_t index, const std::vector< std::unique_ptr< HttpPolicy > > &policies)
Constructs an abstraction representing a next line in the stack sequence of policies,...
Definition policy.hpp:344
std::unique_ptr< RawResponse > Send(Request &request, Context const &context)
Applies this HTTP policy.
Definition policy.cpp:14
A request message from a client to a server.
Definition http.hpp:183
std::string ToString() const
Gets Uuid as a string.
Definition uuid.cpp:65
static Uuid CreateUuid()
Creates a new random UUID.
Definition uuid.cpp:133
Manages an optional contained value, i.e. a value that may or may not be present.
Definition nullable.hpp:30
Context for canceling long running operations.
Credentials used for authentication with many (not all) Azure SDK client libraries.
HTTP request and response functionality.
Compute the hash value for the input binary data, using SHA256, SHA384 and SHA512.
Definition azure_assert.hpp:57
std::shared_ptr< Azure::Core::Http::HttpTransport > AzureSdkGetCustomHttpTransport()
Log options that parameterize the information being logged.
Definition policy.hpp:148
std::set< std::string > AllowedHttpQueryParameters
HTTP query parameter names that are allowed to be logged.
Definition policy.hpp:153
CaseInsensitiveSet AllowedHttpHeaders
HTTP header names that are allowed to be logged.
Definition policy.hpp:159
The set of options that can be specified to influence how retry attempts are made,...
Definition policy.hpp:108
std::chrono::milliseconds RetryDelay
The minimum permissible delay between retry attempts.
Definition policy.hpp:120
int32_t MaxRetries
The maximum number of retry attempts before giving up.
Definition policy.hpp:113
std::chrono::milliseconds MaxRetryDelay
The maximum permissible delay between retry attempts.
Definition policy.hpp:127
std::set< HttpStatusCode > StatusCodes
The HTTP status codes that indicate when an operation should be retried.
Definition policy.hpp:133
Telemetry options, used to configure telemetry parameters.
Definition policy.hpp:60
std::string ApplicationId
The Application ID is the last part of the user agent for telemetry.
Definition policy.hpp:68
std::shared_ptr< Azure::Core::Tracing::TracerProvider > TracingProvider
Specifies the default distributed tracing provider to use for this client. By default,...
Definition policy.hpp:74
HTTP transport options parameterize the HTTP transport adapter being used.
Definition policy.hpp:166
bool DisableTlsCertificateValidation
Disable SSL/TLS certificate verification. This option allows transport layer to perform insecure SSL/...
Definition policy.hpp:215
std::shared_ptr< HttpTransport > Transport
Azure::Core::Http::HttpTransport that the transport policy will use to send and receive requests and ...
Definition policy.hpp:248
Azure::Nullable< std::string > ProxyPassword
The password to use when authenticating with the proxy server.
Definition policy.hpp:192
bool EnableCertificateRevocationListCheck
Enable TLS Certificate validation against a certificate revocation list.
Definition policy.hpp:202
std::string ExpectedTlsRootCertificate
Base64 encoded DER representation of an X.509 certificate expected in the certificate chain used in T...
Definition policy.hpp:228
Azure::Nullable< std::string > HttpProxy
The URL for the proxy server to use for this connection.
Definition policy.hpp:176
Azure::Nullable< std::string > ProxyUserName
The username to use when authenticating with the proxy server.
Definition policy.hpp:184
Utilities to be used by HTTP transport implementations.
Universally unique identifier.