Fhi.ClientCredentials.Refit 1.0.3-alpha.1

This is a prerelease version of Fhi.ClientCredentials.Refit.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Fhi.ClientCredentials.Refit --version 1.0.3-alpha.1                
NuGet\Install-Package Fhi.ClientCredentials.Refit -Version 1.0.3-alpha.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Fhi.ClientCredentials.Refit" Version="1.0.3-alpha.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Fhi.ClientCredentials.Refit --version 1.0.3-alpha.1                
#r "nuget: Fhi.ClientCredentials.Refit, 1.0.3-alpha.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Fhi.ClientCredentials.Refit as a Cake Addin
#addin nuget:?package=Fhi.ClientCredentials.Refit&version=1.0.3-alpha.1&prerelease

// Install Fhi.ClientCredentials.Refit as a Cake Tool
#tool nuget:?package=Fhi.ClientCredentials.Refit&version=1.0.3-alpha.1&prerelease                

Fhi.ClientCredentials.Refit

This package contains code to simplify working with Refit and HelseId.

This default setup will add a token handler to your Refit Interface in addition to letting you add multiple delegates if needed (f.ex. logging).

Usage

Include thhis code in your WebApi startup builder:

builder.AddClientCredentialsRefitBuilder()
    .AddRefitClient<IMyRefitClient>();

If you want to add additional loggers add them before "AddRefitClient":

builder.AddClientCredentialsRefitBuilder()
    .AddHandler<MyLoggingDelegationHandler>()
    .AddRefitClient<IMyRefitClient>();

The code loads your configuration from IConfiguration using the section "ClientCredentialsConfiguration". If you want to override which section to use you can pass the correct section to AddClientCredentialsKeypairs:

builder.AddClientCredentialsRefitBuilder("CustomClientCredentialsConfiguration")
    .AddRefitClient<IMyRefitClient>();

The default RefitSettings we are using use SystemTextJsonContentSerializer, is case insensitive and use camelCasing. If you want to override the default RefitSettings to use you can pass the settings to AddClientCredentialsKeypairs:

builder.AddClientCredentialsRefitBuilder(new RefitSettings())
    .AddRefitClient<IMyRefitClient>();

Adding Correlation Id to all requests

Use "AddCorrelationId()" to add header propagation of the default FHI correlation id header.

builder.AddClientCredentialsRefitBuilder()
    .AddCorrelationId()
    .AddRefitClient<IMyRefitClient>();

A new correlation ID will be given to each request and response that does not contain the header when invoked. Remember to add usage of header propagation to your app startup code. It should be placed before any logging middleware:

app.UseCorrelationId();

More!

Add the handler "LoggingDelegationHandler" to automatically log all Refit requets. The logger has to be availible trough dependency injection using Microsoft.Extensions.Logging (ILogger).

builder.AddClientCredentialsRefitBuilder()
    .AddHandler<LoggingDelegationHandler>();
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.0.0 70 11/26/2024
2.0.0-beta2 62 11/26/2024
1.2.3 258 10/7/2024
1.2.2 101 10/2/2024
1.2.1 90 10/1/2024
1.2.0 91 10/1/2024
1.1.3-alpha.1 223 5/6/2024
1.1.2 655 5/2/2024
1.1.1 93 5/2/2024
1.1.0 132 4/26/2024
1.0.3-alpha.2 94 1/10/2024
1.0.3-alpha.1 255 1/10/2024
1.0.2 404 1/10/2024
1.0.1 99 1/10/2024
1.0.0-beta.6 384 1/8/2024
1.0.0-beta.5 62 1/8/2024
1.0.0-beta.4 98 1/4/2024
1.0.0-beta.3 68 1/4/2024
1.0.0-beta.2 72 1/4/2024
1.0.0-beta.1 68 1/4/2024