LinqToDB Identity store provider for ASP.NET Core Identity
- Release builds can be found on NuGet
- MyGet
- V2
https://www.myget.org/F/linq2db/api/v2
- V3
https://www.myget.org/F/linq2db/api/v3/index.json
- V2
Install package:
PM> Install-Package linq2db.Identity
In general this is the same as for Entity Framework, just call AddLinqToDBStores
instead of AddEntityFrameworkStores
in your Startup.cs
like here:
services.AddIdentity<ApplicationUser, IdentityRole>(options => {
options.Cookies.ApplicationCookie.AuthenticationScheme = "ApplicationCookie";
options.Cookies.ApplicationCookie.CookieName = "Interop";
options.Cookies.ApplicationCookie.DataProtectionProvider = DataProtectionProvider.Create(new DirectoryInfo("C:\\Github\\Identity\\artifacts"));
})
.AddLinqToDBStores(new DefaultConnectionFactory()) //here
.AddDefaultTokenProviders();
The main difference with Entity Framework Core storage provider are:
- We do not use hardcoded classes - interfaces like
IIdentityUser<TKey>
are used (but yes, we do have default implementation) - Data connection factory is used for calling to database
We do not use any default mapping attributes on default POCOs (IdentityUser
, IdentityRole
and so on). This is because this types can be used on different environvents.
If in some reason you prefere using default POCOs you can use fluent mapping in your Startup.cs
to define needed attributes.
For example to treat Id
as identity:
LinqToDB.Mapping.MappingSchema.Default.GetFluentMappingBuilder()
.Entity<IdentityUser<int>>()
.HasIdentity(_ => _.Id);
All source code is based on original Microsoft Entity Framework Core storage provider for ASP.NET Core Identity.
Tests and sample are just adopted for using LinqToDB. For inmemory storage tests SQLite inmemory database is used.