Vivet.AspNetCore.RequestTimeZone
9.0.0
dotnet add package Vivet.AspNetCore.RequestTimeZone --version 9.0.0
NuGet\Install-Package Vivet.AspNetCore.RequestTimeZone -Version 9.0.0
<PackageReference Include="Vivet.AspNetCore.RequestTimeZone" Version="9.0.0" />
paket add Vivet.AspNetCore.RequestTimeZone --version 9.0.0
#r "nuget: Vivet.AspNetCore.RequestTimeZone, 9.0.0"
// Install Vivet.AspNetCore.RequestTimeZone as a Cake Addin #addin nuget:?package=Vivet.AspNetCore.RequestTimeZone&version=9.0.0 // Install Vivet.AspNetCore.RequestTimeZone as a Cake Tool #tool nuget:?package=Vivet.AspNetCore.RequestTimeZone&version=9.0.0
Vivet.AspNetCore.RequestTimeZone
Middleware to configure request timezone options.
The current timezone on a request is set in the Request TimeZone Middleware. The middleware is enabled in the Startup.Configure method, and on every request the list of providers configured in the RequestTimeZoneOptions
is enumerated, and the first provider in order, that can successfully determine the request timezone is applied. The default providers are:
- QueryStringRequestTimeZoneProvider (
?tz=myTimezone
) - CookieRequestTimeZoneProvider
- HeaderRequestTimeZoneProvider (
tz=myTimezone
)
The default list goes from most specific to least specific. You can change the order and even add a custom timezone provider, similar to the implementation of Microsoft.AspNetCore.Localization
. If none of the providers can determine the request timezone, the DefaultRequestTimeZone
is used.
Registration
To configure the Request TimeZone Middleware, first add the required services to the IServiceCollection
, as shown below.
services
.AddRequestTimeZone("myDefaultTimeZone");
Or,
services
.AddRequestTimeZone(x =>
{
// Configuration.
});
Next, register the middleware in the pipeline, as shown below.
applicationBuilder
.UseRequestTimeZone();
The middleware is now configured in the pipeline, and will register request timezone when suplied by one of the configured providers.
When a request model contains properties of type DateTimeOffset
, those will be converted to utc datetime, based on the request timezone. Subsequently, when a response is serialized, the DateTimeOffset
properties are converted back to local datetime.
Accessors
When a timezone is provided as part of a request, it can be retrieved through the IRequestTimeZoneFeature
from a controller, as follows:
var requestTimeZone = this.HttpContext.Features
.Get<tRequestTimeZoneFeature>()
.RequestTimeZone;
Alternatively, the feature may be accessed through the extension method GetUserTimeZone()
of HttpContext
, as shown below:
var requestTimeZone = httpContext.GetUserTimeZone();
Finally, the library also contains a ThreadStatic
accessor, called DateTimeInfo
.
The implementation exposes the RequestTimezone
, as well an utc and local datetime that is based on the timezone.
var now = DateTimeInfo.Now // Gets datetime
var utc = DateTimeInfo.UtcNow // Gets utc datetime
var timezone = DateTimeInfo.TimeZone.Value // Gets the request timezone.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net9.0 is compatible. |
-
net9.0
- Microsoft.AspNetCore.Mvc.NewtonsoftJson (>= 9.0.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Vivet.AspNetCore.RequestTimeZone:
Package | Downloads |
---|---|
NanoCore
The project is inspired by years of tedious repetitions, continuously re-writing similar code-snippets and libraries, to handle common functionality, not related to the business domain, such as logging, data persistence, message queuing, documentation, validation and similar. |
GitHub repositories
This package is not used by any popular GitHub repositories.
- Updated to .NET 9.