EfCore.GenericServices 3.1.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package EfCore.GenericServices --version 3.1.0                
NuGet\Install-Package EfCore.GenericServices -Version 3.1.0                
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="EfCore.GenericServices" Version="3.1.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add EfCore.GenericServices --version 3.1.0                
#r "nuget: EfCore.GenericServices, 3.1.0"                
#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 EfCore.GenericServices as a Cake Addin
#addin nuget:?package=EfCore.GenericServices&version=3.1.0

// Install EfCore.GenericServices as a Cake Tool
#tool nuget:?package=EfCore.GenericServices&version=3.1.0                

EfCore.GenericServices

This library helps you quickly code Create, Read, Update and Delete (CRUD) accesses for a web/mobile/desktop application. It acts as a adapter and command pattern between a database accessed by Entity Framework Core (EF Core) and the needs of the front-end system.

Useful articles

This readme provides a good overview, but here are some articles that give you a detailed description of what the libraray does.

What the library does

This library takes advantage of the fact that each of the four CRUD database accesses differ in what they do, but they have a common set of data part they all use, which are:

  1. What database class/table do you want to access?
  2. What properties in that class/table do you want to access or change?

This library uses DTOs (data transfer objects, also known as ViewModels) plus a special interface to define the class/table and the properties to access. That allows the library to implement a generic solution for each of the four CRUD accesses, where the only thing that changes is the DTO you use.

Typical web applications have hundreds of CRUD pages - display this, edit that, delete the other - and each CRUD access has to adapt the data in the database to show the user, and then apply the changes to the database. So, you create one set of update code for your specific application and then cut/paste + change one line (the DTO name) for all the other versions.

I personally work with ASP.NET Core, so my examples are from that, but it will work with any NET Core type of application (I do know one person have used this libary with WPF).

NuGet link and link to documentation.

MIT license.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  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. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 is compatible. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on EfCore.GenericServices:

Package Downloads
EfCore.GenericServices.AspNetCore

A support library to the EfCore.GenericServices and EfCore.GenericBizRunner libraries. It converts IStatusGeneric into ASP.NET Core's ModelState or Web API response

EntityServices

Package Description

UZB.ELYORBEK.EF

CRUD operations works.

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on EfCore.GenericServices:

Repository Stars
JonPSmith/AuthPermissions.AspNetCore
This library provides extra authorization and multi-tenant features to an ASP.NET Core application.
JonPSmith/PermissionAccessControl2
Version 2 of example application to go with articles on feature and data authorization
Version Downloads Last updated
9.0.0 47 11/21/2024
8.1.0 5,184 5/4/2024
8.0.0 490 4/10/2024
6.0.0 6,623 11/22/2023
5.2.1 20,949 1/3/2023
5.2.0 3,803 11/15/2022
5.2.0-preview001 683 12/8/2022
5.1.1 17,907 2/2/2022
5.1.0 25,443 11/10/2021
5.1.0-preview001 167 11/4/2021
5.0.1 16,525 7/8/2021
5.0.0 19,379 1/6/2021
3.3.0 1,380 6/21/2021
3.2.2 17,790 5/22/2020
3.2.1 3,514 4/11/2020
3.2.0 1,183 4/10/2020
3.1.0 45,672 1/27/2020
3.0.0 5,188 10/12/2019
2.1.0-preview001 1,072 10/4/2019
2.0.3 3,675 7/29/2019
2.0.2 11,211 4/4/2019
2.0.1 5,017 3/10/2019
2.0.0 7,476 1/2/2019
2.0.0-preview001 2,753 12/24/2018
1.3.3 5,705 10/27/2018
1.3.2 1,905 10/22/2018
1.3.1 2,026 9/26/2018
1.3.0 1,974 9/18/2018
1.2.6 10,457 8/18/2018
1.2.4 2,991 7/29/2018
1.2.3 2,193 7/24/2018
1.2.2 1,455 7/16/2018
1.2.1 1,488 7/14/2018
1.1.0 2,153 6/7/2018
1.0.0 2,353 4/12/2018

- New Feature: GenericServices' UpdateAndSave method will look for IncludeThen Attribute on a DTO and add the specified Include/ThenIncludes before doing the update.
     - Update: Swapped to using GenericServices.StatusGeneric for status. This provides common status handling across my Generic libraries. WARNING: this may require you to install NuGet package GenericServices.StatusGeneric in the project that has the entity classes in.