AspNetCoreIdentity.MongoDriver
0.10.0
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
<PackageReference Include="AspNetCoreIdentity.MongoDriver" Version="0.10.0" />
<PackageVersion Include="AspNetCoreIdentity.MongoDriver" Version="0.10.0" />
<PackageReference Include="AspNetCoreIdentity.MongoDriver" />
paket add AspNetCoreIdentity.MongoDriver --version 0.10.0
#r "nuget: AspNetCoreIdentity.MongoDriver, 0.10.0"
#:package AspNetCoreIdentity.MongoDriver@0.10.0
#addin nuget:?package=AspNetCoreIdentity.MongoDriver&version=0.10.0
#tool nuget:?package=AspNetCoreIdentity.MongoDriver&version=0.10.0
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 onNormalizedEmail, a compound index onLogins.LoginProvider/Logins.ProviderKey, and a unique index on the roleNormalizedName.
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 | Versions 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. |
-
net8.0
- MongoDB.Bson (>= 3.9.0)
- MongoDB.Driver (>= 3.9.0)
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 |