🚀 Big News: Socket Acquires Coana to Bring Reachability Analysis to Every Appsec Team.Learn more
Socket
Book a DemoInstallSign in
Socket

Vivet.AspNetCore.RequestTimeZone

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

Vivet.AspNetCore.RequestTimeZone

Middleware for handling timezone in http requests. Similar implementation as Microsoft.AspNetCore.Localization.

9.0.0
Source
NuGet
Version published
Maintainers
1
Created
Source

Vivet.AspNetCore.RequestTimeZone

Build status NuGet NuGet

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.

Keywords

asp

FAQs

Package last updated on 10 Dec 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts