QuokkaDev.Middleware.Correlation
0.0.10-alpha0
See the version list below for details.
dotnet add package QuokkaDev.Middleware.Correlation --version 0.0.10-alpha0
NuGet\Install-Package QuokkaDev.Middleware.Correlation -Version 0.0.10-alpha0
<PackageReference Include="QuokkaDev.Middleware.Correlation" Version="0.0.10-alpha0" />
paket add QuokkaDev.Middleware.Correlation --version 0.0.10-alpha0
#r "nuget: QuokkaDev.Middleware.Correlation, 0.0.10-alpha0"
// Install QuokkaDev.Middleware.Correlation as a Cake Addin #addin nuget:?package=QuokkaDev.Middleware.Correlation&version=0.0.10-alpha0&prerelease // Install QuokkaDev.Middleware.Correlation as a Cake Tool #tool nuget:?package=QuokkaDev.Middleware.Correlation&version=0.0.10-alpha0&prerelease
QuokkaDev.Middleware.Correlation
QuokkaDev.Middleware.Correlation is a .NET middleware for correlating HTTP request using a correlationId. It can read a correlationId from the incoming request searching in a set of valid headers; if correlationId is not found in the incoming request it automatically generate a new one. You can enrich your log using using the generated id as a property and you can write the id in the HTTP response. You can also forward the correlationId to other services called through HttpClient.
Installing QuokkaDev.Middleware.Correlation
You should install the package via the .NET command line interface
Install-Package QuokkaDev.Middleware.Correlation
Using QuokkaDev.Middleware.Correlation
For using the middleware you must configure the services and then add it to the pipeline.
startup.cs
//Add default services
services.AddCorrelation();
//Add custom services
services.AddCorrelation<MyCustomCorrelationService, MyCustomCorrelationIdProvider>();
//Add custom ICorrelationService service
services.AddCorrelationWithService<MyCustomCorrelationService>();
//Add custom ICorrelationIdProvider service
services.AddCorrelationWithProvider< MyCustomCorrelationIdProvider>();
//Register the correlation middleware in the pipeline
app.UseCorrelation(options => {
options.TryToUseRequestHeader = true;
options.ValidRequestHeaders = new string[] { "X-Correlation-Id" };
options.EnrichLog = true;
options.LogPropertyName = "CorrelationId";
options.WriteCorrelationIDToResponse = true,
options.DefaultHeaderName = "";
});
Configure middleware
TryToUseRequestHeader (default: true)
Set this property to true if you want to inspect incoming request for searching a correlationId set by the client. middleware search between all request headers comparing them to a list of valid header (see ValidRequestHeaders below). The first matched header value is used as correlationId; if not matches was found a new CorrelationId is generated.
Set this property to false for always generate the correlationId.
ValidRequestHeaders (default: ["X-Correlation-Id"])
An array of valid headers name for searching a correlationId in the incoming request. This property take effect only if TryToUseRequestHeader is set to true.
EnrichLog (default: true)
Setting this property to true add the correlationId to your logger.
LogPropertyName (default: "CorrelationId")
Set the property name used for enrich your log. This property take effect only if EnrichLog is set to true.
WriteCorrelationIDToResponse (default: true)
Set this property to true if you want correlationId to be write in HTTP response. If the correlationId was found in the incoming request it will be write to the response using the same header name used by client in the original request else DefaultHeaderName will be used.
DefaultHeaderName (default: "X-Correlation-Id")
This property is used as header name both when the correlationId is write to the response or is forwarded to other http clients.
Custom services
You can customize the middleware using custom implementations for some interfaces.
ICorrelationService
This service is used for setting and retrieving the correlationId. the default implementation store the correlationId in memory.
ICorrelationIdProvider
This service is used for generating a new correlationId. The default implementation generate use Guid as correlationIds.
Forward correlationId to other services
You can forward your correlationId to other services called using HttpClient. This can help you to trace the same request from the original client through all the services involved.
startup.cs
//Forward the correlationId to MyClient using DefaultHeaderName property
services.AddHttpClient("MyClient").ForwardCorrelationId();
//Forward the correlationId to MyOtherClient using another header name
services.AddHttpClient("MyOtherClient").ForwardCorrelationId("X-Another-Header-Name");
Product | Versions 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. |
-
net6.0
- Microsoft.AspNetCore.Http.Abstractions (>= 2.2.0)
- Microsoft.Extensions.Configuration.Abstractions (>= 6.0.0)
- Microsoft.Extensions.Configuration.Binder (>= 6.0.0)
- Microsoft.Extensions.DependencyInjection (>= 6.0.1)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 6.0.0)
- Microsoft.Extensions.Http (>= 6.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 6.0.3)
- Microsoft.Extensions.Options (>= 6.0.0)
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 |
---|---|---|
1.1.0 | 113 | 7/8/2024 |
1.0.0 | 192 | 5/25/2023 |
0.0.10-alpha0 | 129 | 5/26/2023 |
0.0.9 | 175 | 5/25/2023 |
0.0.8 | 152 | 5/25/2023 |
0.0.7 | 166 | 5/25/2023 |
0.0.6 | 146 | 5/25/2023 |
0.0.5 | 147 | 5/23/2023 |
0.0.4 | 159 | 5/23/2023 |
0.0.3 | 163 | 5/23/2023 |
0.0.3-alpha0 | 141 | 5/24/2023 |
0.0.2 | 161 | 5/22/2023 |
0.0.1 | 155 | 5/22/2023 |