CustomDateTimeOffset 1.0.2

dotnet add package CustomDateTimeOffset --version 1.0.2                
NuGet\Install-Package CustomDateTimeOffset -Version 1.0.2                
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="CustomDateTimeOffset" Version="1.0.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add CustomDateTimeOffset --version 1.0.2                
#r "nuget: CustomDateTimeOffset, 1.0.2"                
#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 CustomDateTimeOffset as a Cake Addin
#addin nuget:?package=CustomDateTimeOffset&version=1.0.2

// Install CustomDateTimeOffset as a Cake Tool
#tool nuget:?package=CustomDateTimeOffset&version=1.0.2                

CustomDateTime Library

CustomDateTime is a library for working with dates and time offsets in databases that do not natively support DateTimeOffset, such as MySQL and PostgreSQL. The library allows preserving and processing time offset information using a custom CustomDateTime class, which is designed to provide functionality similar to DateTimeOffset in databases without native support.

Features

  • CustomDateTime stores information about both the time (DateTime) and the time offset (Offset).
  • It provides methods for converting between DateTimeOffset and CustomDateTime.
  • Includes an Entity Framework Core ValueConverter to integrate CustomDateTime directly into your models.
  • Supports JSON serialization using a custom JsonConverter.

Installation

First, add the library to your project. If you're distributing the library via NuGet, you can install it as follows:

dotnet add package CustomDateTimeLibrary

If you're adding the library manually from GitHub, simply add it as a project reference.

Usage in Entity Framework Core

1. Defining Models

To use CustomDateTime in your Entity Framework Core models, simply replace DateTime or DateTimeOffset properties with CustomDateTime. For example:

using Core.Models.Shared;

public class Event
{
    public int Id { get; set; }
    
    // Using CustomDateTime instead of DateTimeOffset
    public CustomDateTime ValidFrom { get; set; }
}

2. Configuring OnModelCreating in DbContext

If you want to use CustomDateTime with Entity Framework Core, you'll need to add a custom ValueConverter in the OnModelCreating method in your DbContext:

using Microsoft.EntityFrameworkCore;
using Core.Converters;
using Core.Models.Shared;

public class ApplicationDbContext : DbContext
{
    public DbSet<Event> Events { get; set; }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.Entity<Event>()
            .Property(e => e.ValidFrom)
            .HasConversion(new CustomDateTimeConverter());
    }
}

3. Registering in Program.cs or Startup.cs

Depending on which version of ASP.NET Core you're using, you’ll need to register CustomDateTimeSerializer in Program.cs or Startup.cs to enable the correct JSON serialization and deserialization of date-time fields:

Program.cs (for .NET 6 and above):
var builder = WebApplication.CreateBuilder(args);

builder.Services.AddControllers()
    .AddJsonOptions(options =>
    {
        options.JsonSerializerOptions.Converters.Add(new CustomDateTimeSerializer());
    });

var app = builder.Build();

app.UseHttpsRedirection();
app.MapControllers();
app.Run();
Startup.cs (for older versions of .NET Core):
public void ConfigureServices(IServiceCollection services)
{
    services.AddControllers()
        .AddJsonOptions(options =>
        {
            options.JsonSerializerOptions.Converters.Add(new CustomDateTimeSerializer());
        });
}

4. Example Usage in a Controller

Once everything is set up, you can start using CustomDateTime in your ASP.NET Core API controllers. For example:

[ApiController]
[Route("api/[controller]")]
public class EventsController : ControllerBase
{
    private readonly ApplicationDbContext _context;

    public EventsController(ApplicationDbContext context)
    {
        _context = context;
    }

    [HttpGet]
    public async Task<IActionResult> GetEvents()
    {
        var events = await _context.Events.ToListAsync();
        return Ok(events);
    }
}

5. PostgreSQL Configuration

When using PostgreSQL as your database and you want to ensure correct handling of CustomDateTime, you need to apply a custom configuration that maps the CustomDateTime class properties (DateTime and Offset) to individual columns in the database.

To do this, you can use the provided ApplyCustomDateTimeConfiguration method in the OnModelCreating method of your DbContext. This will ensure that both the DateTime and Offset are properly stored in the database, even though PostgreSQL doesn't support DateTimeOffset natively.

Here is how you can apply the configuration in your DbContext:

using Microsoft.EntityFrameworkCore;
using Core.Models.Shared; // Namespace where CustomDateTime is located

public class ApplicationDbContext : DbContext
{
    public DbSet<Event> Events { get; set; }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        // Apply custom configuration for CustomDateTime
        modelBuilder.ApplyCustomDateTimeConfiguration();

        base.OnModelCreating(modelBuilder);
    }
}

This will automatically configure CustomDateTime properties to be stored in PostgreSQL as two separate fields: one for the DateTime and one for the Offset.

Example PostgreSQL Table:

When this configuration is applied, the table for the Event model might look like this:

Id ValidFromDateTime ValidFromOffset
1 2024-09-10 14:30:00.000000 120

Where:

  • ValidFromDateTime represents the DateTime part.
  • ValidFromOffset stores the offset from UTC (in minutes).
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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. 
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
1.0.2 156 9/11/2024
1.0.1 108 9/11/2024
1.0.0 115 9/10/2024