AspNetCoreIdentity.MongoDriver 0.10.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package AspNetCoreIdentity.MongoDriver --version 0.10.0
                    
NuGet\Install-Package AspNetCoreIdentity.MongoDriver -Version 0.10.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="AspNetCoreIdentity.MongoDriver" Version="0.10.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="AspNetCoreIdentity.MongoDriver" Version="0.10.0" />
                    
Directory.Packages.props
<PackageReference Include="AspNetCoreIdentity.MongoDriver" />
                    
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 AspNetCoreIdentity.MongoDriver --version 0.10.0
                    
#r "nuget: AspNetCoreIdentity.MongoDriver, 0.10.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.
#:package AspNetCoreIdentity.MongoDriver@0.10.0
                    
#: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=AspNetCoreIdentity.MongoDriver&version=0.10.0
                    
Install as a Cake Addin
#tool nuget:?package=AspNetCoreIdentity.MongoDriver&version=0.10.0
                    
Install as a Cake Tool

AspNetCoreIdentity.MongoDriver

A provisioner for AspNetCore Identity using MongoDB as the backing store.

Features

This implements all of the interfaces required by the AspNetCore Identity system.

It also includes a UserStore and RoleStore implementation that can be used with the UserManager and RoleManager classes.

A typical connection string for local development would be mongodb://localhost:27017/Identity.

This would create a database called Identity and store the collections in there.

Usage

Register the provider in Program.cs:

builder.Services.AddIdentityMongoDbProvider<MongoUser<Guid>, MongoRole<Guid>, Guid>(identity =>
{
    identity.User.RequireUniqueEmail = true;
}, mongo =>
{
    mongo.ConnectionString = builder.Configuration.GetConnectionString("MongoDb")!;
});

Then take UserManager<MongoUser<Guid>> and RoleManager<MongoRole<Guid>> as constructor or handler parameters wherever you need them; they are registered as scoped services and the container manages their lifetime. Do not call BuildServiceProvider() yourself or cache the managers in long-lived objects.

public class AccountController(UserManager<MongoUser<Guid>> userManager) : Controller
{
    // ...
}

The MongoUser and MongoRole classes are provided by the library and are generic. This allows you to use any type for the key, not just a Guid.

If you want to use a Guid as the key, you need to insert the line BsonSerializer.RegisterSerializer(new GuidSerializer(GuidRepresentation.Standard)); somewhere above this.

If you use string keys and do not assign an Id yourself, the store generates an ObjectId-style string on create.

Initialization, indexes, and migrations

On the first store operation (not during service registration) the library:

  • applies any pending schema migrations, guarded by a distributed lock so multiple application instances starting at once apply them exactly once, and
  • creates its indexes: a unique index on NormalizedUserName, an index on NormalizedEmail, a compound index on Logins.LoginProvider/Logins.ProviderKey, and a unique index on the role NormalizedName.

Because the unique index on NormalizedUserName enforces real uniqueness, index creation will fail if existing data already contains duplicate user names — clean those up before upgrading. Set mongo.DisableIndexCreation = true if you manage indexes yourself, and mongo.DisableAutoMigrations = true if you manage schema upgrades yourself. You can also warm up eagerly at startup by resolving MongoIdentityInitializer from the container and awaiting EnsureInitializedAsync().

Concurrency

Updates and deletes use optimistic concurrency via the Identity ConcurrencyStamp. If the document changed since your copy was loaded, the operation fails with a ConcurrencyFailure error instead of silently overwriting the other write — reload the user/role and retry.

Limitations

options.Stores.ProtectPersonalData is not supported: the store does not encrypt personal data at rest, and enabling that option will throw at runtime by design rather than silently storing data unprotected.

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

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.1 48 6/26/2026
1.0.0 44 6/24/2026
0.10.0 111 6/10/2026
0.9.0.12 103 6/5/2026
0.9.0.11 108 5/14/2026
0.9.0.8 240 10/15/2025
0.9.0.7 231 9/10/2025
0.9.0.6 222 7/2/2025
0.9.0.5 177 5/4/2025
0.9.0.4 245 4/11/2025
0.9.0.2 175 3/29/2025
0.9.0.1 247 3/11/2025
0.9.0 182 2/25/2025