Nabu.Data.EntityFramework 1.4.0


Nabû: Standardizing .NET developments with abstractions

.Net C# apache2-license CI Status


Nabû is an open-source suite of libraries designed to organize and standardize .NET applications development through streamlined interactions. The suite is divided into three (for now) components:

  • Nabu.Core: Provides inversion of control (IoC) helpers that streamline services registration by using attribute tagging.
  • Nabu.Data: Provides data manipulation abstraction, encompassing CRUD operations and sophisticated querying using LinQ.
  • Nabu.Storage: Provides standardized file manipulation abstractions, catering to local, remote, and cloud-based files.

Latest packages

Core Nuget
Data Nuget Data.EntityFramework Nuget Data.LiteDb Nuget
Storage Nuget Storage.Local Nuget Storage.Minio Nuget

Installation

Before installing Nabû, make sure to add the custom NuGet source to your configuration.
Open a terminal or command prompt and run the following command:

dotnet nuget add source "https://nuget.kworld.dev/v3/index.json" -n "kworld NuGet"

Now you can install the various components of Nabû with the following commands:

# Nabu.Core
dotnet add package my_awesome_project.csproj Nabu.Core

# Nabu.Data
dotnet add package my_awesome_project.csproj Nabu.Core --version 1.0.0-alpha
dotnet add package my_awesome_project.csproj Nabu.Data.EntityFramework --version 1.0.0-alpha # For EntityFramework implementation
dotnet add package my_awesome_project.csprojNabu.Data.LiteDb --version 1.0.0-alpha# For LiteDB implementation

# Nabu.Storage
dotnet add package my_awesome_project.csproj Nabu.Storage --version 1.0.0-alpha
dotnet add package my_awesome_project.csproj Nabu.Storage.Local --version 1.0.0-alpha # For local storage
dotnet add package my_awesome_project.csproj Nabu.Storage.Minio --version 1.0.0-alpha # For Minio (Amazon S3) storage

Getting started

Automatic Service Discovery

Nabu.Core introduces automatic service discovery. By tagging interfaces and classes with attributes, the ServiceHelper dynamically finds and uses implementations for services.

Usage


// Example of using attribute ServiceAttribute for service registration
[Service]
public interface IMyService
{
    void DoSomething();
}

public class MyService : IMyService
{
    public void DoSomething()
    {
        // Implementation details
    }
}

public class Main
{
    public void ConfigureServices()
    {
        ServiceHelper serviceHelper = new();
        
        //by using serviceHelper.Context it's possible to precise
        //in wich assemblies or type collections search for implementations and definitions
        //by default it will search in AppDomain.GetAssemblies() (beware lazy-loading !)
        Assembly[] servicesImplementationsAssemblies =
        {
            typeof(MyService).Assembly,
        };
        serviceHelper.Context.WhiteListedDefinitionsTypes.Add(typeof(IMyService));
        serviceHelper.Context.ImplementationsAssemblies.AddRange(servicesImplementationsAssemblies); 
        
        
        //Launch the search of service definitions and theirs implement and then register them.
        serviceHelper.RegisterServices();
        
        using IServiceRegisterProvider provider = ServiceRegistry.BuildServiceProvider();
        
       
        IMyService? service = provider.GetService<IMyService>();
        service.DoSomething();
    }
}

IDao: Data manipulation Interface

Nabu.Data provide the IDao interface in order to standardize data CRUD.

Usage


public class User : IEntity
{
    public string Id { get; set; } = Guid.NewGuid().ToString();
    public DateTime Creation { get; set; } = DateTime.UtcNow;
    public DateTime Update { get; set; } = DateTime.UtcNow;
    
    public string? Name { get; set; }
    public int Age { get; set; }
    
    public List<Car> Cars { get; set; } = new();
}


public class Car : IEntity
{
    public string Id { get; set; } = Guid.NewGuid().ToString();
    public DateTime Creation { get; set; } = DateTime.UtcNow;
    public DateTime Update { get; set; } = DateTime.UtcNow;

    public string? Imatriculation { get; set; }
    public string? Model { get; set; }
    
    [ForeignKey("OwnerId")]
    public User? Owner {get;set;}
    public string? OwnerId { get; set; }
}

public class Main
{
    public async Task ExempleMethod()
    {
        ServiceHelper serviceHelper = new();
        //Configuration
        //...
        await using IServiceRegisterProvider provider = ServiceRegistry.BuildServiceProvider();
        await using IServiceRegistryScope scope = provider.CreateAsyncScope();
        await using IServiceRegisterProvider scopeProvider = scope.ServiceProvider;
        
        IDao? dao = scopeProvider.GetService<IDao>();
        
        
        User cosette = new() { Name = "Cosette", Age = 25 };
        User jean = new() { Name = "Jean Valjean", Age = 55 };
        
        cosette = await dao.AddAsync(cosette);
        jean = await dao.AddAsync(jean);
        
        Car car = new() { Imatriculation = $"CCC-BBB-1", OwnerId = null};
        await dao.AddAsync(car);
        
        Car car2 = new() { Imatriculation = $"CCC-BBB-2", OwnerId = cosette.Id};
        await dao.AddAsync(car2);
        
        car.OwnerId = cosette.id;
        await dao.UpdateAsync(car);
        
        ISpecification<Car> carSpecification = new Specification<Car> { Criteria = c => c.OwnerId == cosette.Id };
        carSpecification.OrderBy(c => c.Creation).ThenBy(c => c.Update);
        
        var dbCars = await dao.ListAllAsync(carSpecification);
        
    }
}


Documentation

For comprehensive insights into the capabilities and nuances of Nabû, refer to the official documentation:

Documentation Link

Contributing

Join us in enhancing Nabû! We welcome contributions in the form of suggestions, bug reports, and pull requests. Check out the Contribution Guidelines to get involved.

License

This project operates under the Apache 2.0 License. For more details, refer to the LICENSE file.

Why "Nabû" ?

Nabû (Akkadian: cuneiform: 𒀭𒀝) is the name of and old Mesopotamian God.
In ancient cultures, Nabû was revered as a deity associated with wisdom, scholarship, and the recording of informations. Nabû's symbols included a stylus resting on a tablet.

By adopting those name and symbols, this suite of libraries refers, in a cool way, to the the art of writing and recording of informations.

Showing the top 20 packages that depend on Nabu.Data.EntityFramework.

Packages Downloads
Nabu.Data.EntityFramework.Blazor
Package Description
948
Nabu.Data.EntityFramework.Blazor
Package Description
506
Nabu.Data.EntityFramework.Blazor
Package Description
372
Nabu.Data.EntityFramework.Blazor
Package Description
318
Nabu.Data.EntityFramework.Blazor
Package Description
316
Nabu.Data.EntityFramework.Blazor
Package Description
225
Nabu.Data.EntityFramework.Blazor
Package Description
169
Nabu.Data.EntityFramework.Blazor
Package Description
116
Nabu.Data.EntityFramework.Blazor
Package Description
27
Nabu.Data.EntityFramework.Blazor
Package Description
23
Nabu.Data.EntityFramework.Blazor
Package Description
22
Nabu.Data.EntityFramework.Blazor
Package Description
21
Nabu.Data.EntityFramework.Blazor
Package Description
20
Nabu.Data.EntityFramework.Blazor
Package Description
19
Nabu.Data.EntityFramework.Blazor
Package Description
18

add ISelectMapper and ISelectGroupByMapper

Version Downloads Last updated
3.5.0 653 11/12/2025
3.5.0-rc2 315 11/05/2025
3.4.2 1,540 09/09/2025
3.4.1 1,220 08/05/2025
3.4.0 1,637 07/18/2025
3.3.6 279 07/08/2025
3.3.5 447 06/30/2025
3.3.4 1,805 05/13/2025
3.3.3 1,888 04/08/2025
3.3.2 2,026 03/13/2025
3.3.1 432 03/05/2025
3.3.0 17 03/05/2025
3.2.4 872 02/12/2025
3.2.3 90 02/11/2025
3.2.2 1,151 01/17/2025
3.2.1 115 01/14/2025
3.2.0 480 12/28/2024
3.1.0 697 12/11/2024
3.0.2 96 12/09/2024
3.0.1 86 11/26/2024
2.2.4 1,497 09/12/2024
2.2.3 1,592 08/23/2024
2.2.2 28 08/23/2024
2.2.1 242 08/21/2024
2.2.0 19 08/21/2024
2.1.0 79 07/31/2024
2.0.0 510 06/10/2024
1.4.1 317 06/07/2024
1.4.0 112 05/28/2024
1.3.2 387 05/16/2024
1.3.1 20 05/16/2024
1.3.0 19 05/15/2024
1.3.0-beta 18 03/05/2024
1.2.0 64 03/29/2024
1.1.0 19 03/29/2024
1.0.0.1 19 03/29/2024