DRN.Framework.EntityFramework 0.4.0-preview002

Prefix Reserved
This is a prerelease version of DRN.Framework.EntityFramework.
There is a newer version of this package available.
See the version list below for details.
dotnet add package DRN.Framework.EntityFramework --version 0.4.0-preview002
                    
NuGet\Install-Package DRN.Framework.EntityFramework -Version 0.4.0-preview002
                    
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="DRN.Framework.EntityFramework" Version="0.4.0-preview002" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="DRN.Framework.EntityFramework" Version="0.4.0-preview002" />
                    
Directory.Packages.props
<PackageReference Include="DRN.Framework.EntityFramework" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add DRN.Framework.EntityFramework --version 0.4.0-preview002
                    
#r "nuget: DRN.Framework.EntityFramework, 0.4.0-preview002"
                    
#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.
#:package DRN.Framework.EntityFramework@0.4.0-preview002
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=DRN.Framework.EntityFramework&version=0.4.0-preview002&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=DRN.Framework.EntityFramework&version=0.4.0-preview002&prerelease
                    
Install as a Cake Tool

master develop Quality Gate Status

Security Rating Maintainability Rating Reliability Rating Vulnerabilities Bugs Lines of Code Coverage

DRN.Framework.EntityFramework provides DrnContext with conventions to develop rapid and effective domain models.

DRNContext

DrnContext has following unique features:

  • Implements IDesignTimeDbContextFactory to enable migrations from dbContext defining projects.
  • Implements IDesignTimeServices to support multi context projects with default output directories in the context specific folder.
  • Uses HasDrnContextServiceCollectionModule attribute for automatic registration with AddServicesWithAttributes service collection extension method.
  • Uses context name (typeof(TContext).Name) as connection string key by convention.
  • Automatically applies IEntityTypeConfiguration implementations from the assembly whose namespace contains the derived context's namespace.
  • Automatically marks Entities derived from DRN.Framework.SharedKernel.Domain.Entity as created, modified or deleted.
  • Enables DRN.Framework.Testing to create easy and effective integration tests with conventions and automatic registrations.
    • Application modules can be registered without any modification to TestContext
    • TestContext's ContainerContext
      • creates a postgresql container then scans TestContext's service collection for inherited DrnContexts.
      • Adds a connection strings to TestContext's configuration for each DrnContext according to convention.
    • TestContext acts as a ServiceProvider and when a service is requested it can build it from service collection with all dependencies.
namespace DRN.Framework.EntityFramework.Context;

[HasDrnContextServiceCollectionModule]
public abstract class DrnContext<TContext> : DbContext, IDesignTimeDbContextFactory<TContext>, IDesignTimeServices where TContext : DbContext, new()
{ 
...

public class HasDrnContextServiceCollectionModuleAttribute : HasServiceCollectionModuleAttribute
{
    static HasDrnContextServiceCollectionModuleAttribute()
    {
        ModuleMethodInfo = typeof(ServiceCollectionExtensions).GetMethod(nameof(ServiceCollectionExtensions.AddDbContextsWithConventions))!;
    }
}

Example Usage

namespace Sample.Infra;

public static class InfraModule
{
    public static IServiceCollection AddSampleInfraServices(this IServiceCollection sc)
    {
        sc.AddServicesWithAttributes();

        return sc;
    }
}

public class QAContext : DrnContext<QAContext>
{
    public QAContext(DbContextOptions<QAContext> options) : base(options)
    {
    }

    public QAContext() : base(null)
    {
    }

    public DbSet<User> Users { get; set; }
    public DbSet<Question> Questions { get; set; }
    public DbSet<Answer> Answers { get; set; }
    public DbSet<QuestionComment> Comments { get; set; }
    public DbSet<Category> Categories { get; set; }
    public DbSet<Tag> Tags { get; set; }
}

Development Environment Configurations

Following configuration options added to minimize development environment creation efforts:

  • DrnContext development connection string will be auto generated when
    • Environment configuration key set as Development and,
    • postgres-password configuration key set and,
    • No other connection string is provided for the DbContexts.
  • Following keys can set optionally according to DbContextConventions;
    • DrnContext_AutoMigrateDevEnvironment
      • When set true applies migrations automatically
    • DrnContext_DevHost
      • default is postgresql
    • DrnContext_DevPort
      • default is 5432
    • DrnContext_DevUsername
      • default is postgres
    • DrnContext_DevDatabase
      • default is drnDb

postgres-password and DrnContext_AutoMigrateDevEnvironment should be enough to start a hosted service that has DrnContext dependencies.

For instance:

  • When a Postgresql helm chart is used for dev environment and it creates a password secret automatically,
  • Then only defining a volume mount should be enough for database configuration.

Global Usings

global using DRN.Framework.EntityFramework.Context;
global using Microsoft.EntityFrameworkCore;
global using DRN.Framework.Utils.DependencyInjection;

Semper Progredi: Always Progressive

Commit Info

Author: Duran Serkan KILIÇ
Date: 2024-05-08 22:32:35 +0300
Hash: 069091e826ac4bed3cfb9db6e2faf9d692231e5e

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.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on DRN.Framework.EntityFramework:

Package Downloads
DRN.Framework.Testing

DRN.Framework.Testing package encapsulates testing dependencies and provides practical, effective helpers such as resourceful data attributes and test context. This package enables a new encouraging testing technique called as DTT(Duran's Testing Technique). With DTT, any developer can write clean and hassle-free unit and integration tests without complexity. ## Commit Info Author: Duran Serkan KILIÇ Date: 2025-12-16 21:31:26 +0300 Hash: 2cb56277b062efbe396af7938ce2e4f16c5b617c

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
0.7.0-preview055 227 12/16/2025
0.7.0-preview054 129 12/13/2025
0.7.0-preview053 80 12/12/2025
0.7.0-preview052 387 12/9/2025
0.7.0-preview051 257 12/7/2025
0.7.0-preview050 169 12/7/2025
0.7.0-preview049 143 11/26/2025
0.7.0-preview048 147 11/24/2025
0.7.0-preview047 139 11/7/2025
0.7.0-preview046 195 11/6/2025
0.7.0-preview045 194 11/3/2025
0.7.0-preview044 206 11/2/2025
0.7.0-preview043 132 11/1/2025
0.7.0-preview042 197 10/29/2025
0.7.0-preview041 114 10/25/2025
0.7.0-preview040 167 10/12/2025
0.7.0-preview039 122 10/11/2025
0.7.0-preview038 183 10/8/2025
0.7.0-preview037 185 9/28/2025
0.7.0-preview036 209 9/22/2025
0.7.0-preview035 197 8/31/2025
0.7.0-preview034 215 8/31/2025
0.7.0-preview033 228 8/28/2025
0.7.0-preview032 225 8/27/2025
0.7.0-preview031 210 8/10/2025
0.7.0-preview030 86 8/1/2025
0.7.0-preview029 110 8/1/2025
0.7.0-preview028 102 8/1/2025
0.7.0-preview027 139 7/31/2025
0.7.0-preview026 137 7/29/2025
0.7.0-preview025 151 7/27/2025
0.7.0-preview024 128 7/11/2025
0.7.0-preview023 130 7/11/2025
0.7.0-preview022 193 6/29/2025
0.7.0-preview021 191 6/23/2025
0.7.0-preview020 148 5/31/2025
0.7.0-preview019 237 3/23/2025
0.7.0-preview018 178 3/2/2025
0.7.0-preview017 162 2/23/2025
0.7.0-preview016 176 2/22/2025
0.7.0-preview015 146 2/21/2025
0.7.0-preview014 157 2/20/2025
0.7.0-preview013 180 2/9/2025
0.7.0-preview012 150 2/8/2025
0.7.0-preview011 153 2/2/2025
0.7.0-preview010 149 1/20/2025
0.7.0-preview009 156 1/19/2025
0.7.0-preview008 122 1/16/2025
0.7.0-preview007 164 12/29/2024
0.7.0-preview006 146 12/23/2024
0.7.0-preview005 150 11/27/2024
0.7.0-preview004 163 11/23/2024
0.7.0-preview003 147 11/20/2024
0.7.0-preview002 162 11/17/2024
0.7.0-preview001 176 11/14/2024
0.6.0 201 11/10/2024
0.6.0-preview002 155 11/10/2024
0.6.0-preview001 174 11/10/2024
0.5.1-preview002 163 9/30/2024
0.5.1-preview001 147 9/22/2024
0.5.0 222 8/30/2024
0.5.0-preview011 148 8/30/2024
0.5.0-preview010 170 8/25/2024
0.5.0-preview009 169 8/8/2024
0.5.0-preview008 162 8/7/2024
0.5.0-preview007 142 8/2/2024
0.5.0-preview006 129 7/30/2024
0.5.0-preview005 159 7/27/2024
0.5.0-preview004 171 7/15/2024
0.5.0-preview003 188 6/6/2024
0.5.0-preview002 162 6/5/2024
0.5.0-preview001 170 6/4/2024
0.4.0 176 5/19/2024
0.4.0-preview006 166 5/19/2024
0.4.0-preview005 196 5/12/2024
0.4.0-preview004 179 5/12/2024
0.4.0-preview003 167 5/11/2024
0.4.0-preview002 179 5/8/2024
0.4.0-preview001 195 5/5/2024
0.3.1-preview001 148 4/26/2024
0.3.0 203 4/23/2024
0.3.0-preview002 169 4/23/2024
0.3.0-preview001 171 4/23/2024
0.2.2-preview010 192 4/11/2024
0.2.2-preview009 156 3/18/2024
0.2.2-preview008 158 3/18/2024
0.2.2-preview007 170 3/16/2024
0.2.2-preview006 147 3/11/2024
0.2.2-preview005 167 3/10/2024
0.2.2-preview004 177 3/10/2024
0.2.2-preview003 244 1/22/2024
0.2.2-preview002 164 1/18/2024
0.2.2-preview001 194 1/14/2024
0.2.1 284 1/7/2024
0.2.0 181 12/31/2023
0.2.0-preview009 153 12/31/2023
0.2.0-preview008 128 12/30/2023
0.2.0-preview007 137 12/28/2023
0.2.0-preview006 151 12/27/2023
0.2.0-preview005 130 12/25/2023
0.2.0-preview004 132 12/23/2023
0.2.0-preview003 135 12/20/2023
0.2.0-preview002 133 12/19/2023

Not every version includes changes, features or bug fixes. This project can increment version to keep consistency with other DRN.Framework projects.

## Version 0.3.0

My family celebrates the enduring legacy of Mustafa Kemal Atatürk's enlightenment ideals. This release is dedicated to 23 April National Sovereignty and Children's Day.

### Breaking Changes

### New Features

* DrnContext development connection string will be auto generated when
   * Environment configuration key set as Development and,
   * postgres-password configuration key set and,
   * No other connection string is provided for the DbContexts.
* Following keys can set optionally according to DbContextConventions;
   * DrnContext_AutoMigrateDevEnvironment
       * When set true applies migrations automatically
   * DrnContext_DevHost
   * DrnContext_DevPort
   * DrnContext_DevUsername
       * default is postgres
   * DrnContext_DevDatabase
       * default is drnDb

### Bug Fixes

## Version 0.2.0

### Breaking Changes

### New Features

* DrnContext added
   * Implemented IDesignTimeDbContextFactory to enable migrations from dbContext defining projects.
   * Implemented IDesignTimeServices to support multi context projects with default output directory in the context specific folder.
   * Uses HasDrnContextServiceCollectionModule to automatic registration with AddServicesWithAttributes service collection extension method.
   * Uses context name (typeof(TContext).Name) as connection string key by convention.
   * Enables DRN.Framework.Testing to create easy and effective integration tests with conventions and automatic registrations.

### Bug Fixes

---
**Semper Progredi: Always Progressive**  
 
## Commit Info  
Author: Duran Serkan KILIÇ  
Date: 2024-05-08 22:32:35 +0300  
Hash: 069091e826ac4bed3cfb9db6e2faf9d692231e5e