PoliNorError.Extensions.Http
0.1.1
dotnet add package PoliNorError.Extensions.Http --version 0.1.1
NuGet\Install-Package PoliNorError.Extensions.Http -Version 0.1.1
<PackageReference Include="PoliNorError.Extensions.Http" Version="0.1.1" />
<PackageVersion Include="PoliNorError.Extensions.Http" Version="0.1.1" />
<PackageReference Include="PoliNorError.Extensions.Http" />
paket add PoliNorError.Extensions.Http --version 0.1.1
#r "nuget: PoliNorError.Extensions.Http, 0.1.1"
#addin nuget:?package=PoliNorError.Extensions.Http&version=0.1.1
#tool nuget:?package=PoliNorError.Extensions.Http&version=0.1.1
The library provides an outgoing request resiliency pipeline for HttpClient
, using policies from the PoliNorError library.
Key Features
- Provides the ability to create a pipeline to handle typical transient HTTP failures (including the
HttpRequestException
exception). - Flexible transient failure filter for the final
DelegatingHandler
in the pipeline for the response. - Additionally, custom failure status codes or categories can be added to the final handler filter.
- Other exception types (besides
HttpRequestException
) can also be included in the final handler filter. - Inclusion in the outer handler filter of any
Exception
type thrown by the inner handler is also supported. - Both typed and named
HttpClient
, as well asIHttpClientFactory
, can be used. - Targets .NET Standard 2.0.
Usage
- Configure typed or named
HttpClient
:
services.AddHttpClient<IAskCatService, AskCatService>((sp, config) =>
{
...
config.BaseAddress = new Uri(settings.BaseUri);
...
})...
, where AskCatService
is a service that implements IAskCatService
, with HttpClient
or IHttpClientFactory
injected.
- Use the library's
IHttpClientBuilder.WithResiliencePipeline
extension method and configure the pipeline ofDelegatingHandler
s by using theAddPolicyHandler
method with the policy you want to apply in this handler:
services.AddHttpClient<IAskCatService, AskCatService>((spForClient, client) =>
{
...
})
.WithResiliencePipeline((pb) =>
pb
.AddPolicyHandler(PolicyJustCreated)
.AddPolicyHandler((IServiceProvider sp) => funcThatUsesServiceProviderToCreatePolicy(sp))
...
)
Or use the WithResiliencePipeline
method overload that includes an additional context parameter:
services.AddHttpClient<IAskCatService, AskCatService>((spForClient, client) =>
{
...
})
.WithResiliencePipeline<SomeContextType>((pb) =>
pb
.AddPolicyHandler((SomeContextType ctx, IServiceProvider sp) =>
funcThatUsesContextAndServiceProviderToCreatePolicy(ctx, sp))
.AddPolicyHandler((IServiceProvider sp) => funcThatUsesServiceProviderToCreatePolicy(sp))
...
, context)
, where
pb
- represents the pipeline builder.PolicyJustCreated
- a policy from the PoliNorError library.funcThatUsesServiceProviderToCreatePolicy
-Func
that uses theIServiceProvider
to create a policy.funcThatUsesContextAndServiceProviderToCreatePolicy
-Func
that uses theIServiceProvider
and context to create a policy.
- When you want to complete the pipeline, call the
AsFinalHandler
method for the last added handler and configureHttpErrorFilter
to filter transient http errors and/or any non-successful status codes or categories:
services.AddHttpClient<IAskCatService, AskCatService>((sp, config) =>
{
...
})
.WithResiliencePipeline((pb) =>
pb
...
.AddPolicyHandler(PolicyForFinalHandler)
//Adds transient http errors to the response handling filter.
.AsFinalHandler(HttpErrorFilter.HandleTransientHttpErrors())
...
)
Additionally, you can include custom failure status codes or categories in the final handler filter:
...
.AsFinalHandler(HttpErrorFilter.HandleHttpRequestException()
//Also adds 5XX status codes to the response handling filter.
.OrServerError())
...
You can also include in the filter any exception type thrown by an inner handler:
...
.AsFinalHandler(HttpErrorFilter.HandleTransientHttpErrors())
//Include 'SomeExceptionFromNonPipelineHandler' exceptions in the filter
//when thrown by a non-pipeline handler (in this case).
.IncludeException<SomeExceptionFromNonPipelineHandler>()
...
- In a service that uses
HttpClient
orHttpClientFactory
, wrap the call toHttpClient
in a catch block that handles the specialHttpPolicyResultException
exception. If the request was not successful, examine theHttpPolicyResultException
properties in this handler for details of the response:
try
{
...
using var response = await _client.GetAsync(uri, token);
...
}
catch (OperationCanceledException oe)
{
...
}
catch (HttpPolicyResultException hpre)
{
//If the response status code matches the handling filter status code:
if (hpre.HasFailedResponse)
{
//For example, log a failed status code.
logger.LogError("Failed status code: {StatusCode}.", hpre.FailedResponseData.StatusCode);
}
}
catch (Exception ex)
{
...
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Microsoft.Extensions.Http (>= 9.0.2)
- PoliNorError (>= 2.21.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.