Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Shared
                                 
                            
                                3.0.0-preview.6
                            
                        
                            
                                
                                
                                    Prefix Reserved
                                
                            
                    dotnet add package Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Shared --version 3.0.0-preview.6
NuGet\Install-Package Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Shared -Version 3.0.0-preview.6
<PackageReference Include="Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Shared" Version="3.0.0-preview.6" />
<PackageVersion Include="Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Shared" Version="3.0.0-preview.6" />
<PackageReference Include="Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Shared" />
paket add Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Shared --version 3.0.0-preview.6
#r "nuget: Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Shared, 3.0.0-preview.6"
#:package Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Shared@3.0.0-preview.6
#addin nuget:?package=Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Shared&version=3.0.0-preview.6&prerelease
#tool nuget:?package=Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Shared&version=3.0.0-preview.6&prerelease
Skoruba.Duende.IdentityServer.Admin π
Admin UI for Duende IdentityServer and ASP.NET Core Identity
Project Status
New release v3 is coming! π
This application uses a modern React frontend (TypeScript, Tailwind CSS and shadcn/ui) and a backend REST API built with .NET 9.
Requirements
- Install the latest .NET SDK (using older versions may lead to 502.5 errors when hosted on IIS or application exiting immediately after starting when self-hosted)
Installation via dotnet new template
π Note:
This project uses default database migrations, which will affect your database.
Always review the migrations for your database provider and create a database backup before proceeding.
1. Install the template
dotnet new install Skoruba.Duende.IdentityServer.Admin.Templates::3.0.0-preview.5
2. Create a new project
dotnet new skoruba.duende.isadmin \
  --name MyProject \
  --title MyProject \
  --adminemail "admin@example.com" \
  --adminpassword "Pa$$word123" \
  --adminrole MyRole \
  --adminclientid MyClientId \
  --adminclientsecret MyClientSecret \
  --dockersupport true
  --requirepushedauthorization true
Template options
| Option | Description | 
|---|---|
| --name | Project name | 
| --adminpassword | Admin password | 
| --adminemail | Admin email | 
| --title | Title and footer for the admin UI | 
| --adminrole | Name of the admin role used for authorization | 
| --adminclientid | Client ID used in Duende IdentityServer configuration for the admin client | 
| --adminclientsecret | Client secret used in Duende IdentityServer configuration for the admin client | 
| --dockersupport | Include Docker support ( true/false) | 
| --requirepushedauthorization | Require Pushed Authorization Requests (PAR) for the admin client ( true/false). Default:true. Licensing note: PAR is available in Duende IdentityServer Business Edition or higher. If you have a license lower than Business, set--requirepushedauthorizationtofalse. More details about PAR here. | 
Administration UI preview
- This administration uses Tailwind CSS and shadcn/ui components.
Admin UI - Light mode βοΈ
Admin UI - Dark mode π
Solution structure:
Cloning
git clone https://github.com/skoruba/Duende.IdentityServer.Admin
Running via Docker
- You can run the Admin UI using Docker.
Docker Setup
DNS
You need local domain resolution for the project to work. This setup uses the domain skoruba.local (a fully qualified domain name, FQDN).
Make sure skoruba.local resolves to your Docker host. For local-only usage, update your hosts file:
- Linux: /etc/hosts
- Windows: C:\Windows\System32\drivers\etc\hosts
Add the following entry:
127.0.0.1 skoruba.local sts.skoruba.local admin.skoruba.local admin-api.skoruba.local
This allows your host machine to resolve skoruba.local and its subdomains to itself.
Certificates
The project requires HTTPS certificates. Use mkcert to generate self-signed local certificates.
If your domain is publicly available via DNS, you can use Let's Encrypt. Nginx-proxy supports this, but it's not included in this setup.
Create the root certificate
On Windows, run mkcert -install as Administrator.
Copy the CA Root certificate to the project to mount it into containers:
cd shared/nginx/certs
mkcert --install
copy $env:LOCALAPPDATA\mkcert\rootCA-key.pem ./cacerts.pem
copy $env:LOCALAPPDATA\mkcert\rootCA.pem ./cacerts.crt
Create the skoruba.local certificates
Generate a wildcard certificate for skoruba.local and subdomains. The certificate file names must match the domain names for nginx-proxy to work correctly. Both crt-key and pfx versions are needed:
cd shared/nginx/certs
mkcert -cert-file skoruba.local.crt -key-file skoruba.local.key skoruba.local *.skoruba.local
mkcert -pkcs12 skoruba.local.pfx skoruba.local *.skoruba.local
This Docker setup is based on bravecobra's repository β thanks to bravecobra! π
Run docker-compose
- The project contains docker-compose.vs.debug.ymlanddocker-compose.override.ymlfor debugging with a seeded environment.
- To start a seeded, debug-enabled environment (for Visual Studio):
docker-compose build
docker-compose up -d
You can also set the
docker-composeproject as your startup project in Visual Studio.
Docker images
- Docker images will be available on Docker Hub.
Publish Docker images to Docker Hub
- Check the script in build/publish-docker-images.ps1and update the profile name as needed.
EF Core & Data Access
- The solution uses these - DbContextclasses:- AdminIdentityDbContext: for ASP.NET Core Identity
- AdminLogDbContext: for logging
- IdentityServerConfigurationDbContext: for IdentityServer configuration store
- IdentityServerPersistedGrantDbContext: for IdentityServer operational store
- AuditLoggingDbContext: for audit logging
- IdentityServerDataProtectionDbContext: for data protection
 
Running Entity Framework migrations
Note: Initial migrations are included in the repository.
- You can use the PowerShell script in the build/add-migrations.ps1folder.
- This script takes two arguments:
- --migration(migration name)
- --migrationProviderName(provider type β available choices: All, SqlServer, MySql, PostgreSQL)
 
- Example:
.\add-migrations.ps1 -migration DbInit -migrationProviderName SqlServer
Available database providers
- SqlServer
- MySql
- PostgreSQL
You can switch the database provider via
appsettings.json:
"DatabaseProviderConfiguration": {
  "ProviderType": "SqlServer"
}
Connection string samples
PostgreSQL:
Server=localhost;Port=5432;Database=DuendeIdentityServerAdmin;User Id=sa;Password=#;
MySql:
server=localhost;database=DuendeIdentityServerAdmin;user=root;password=#
Seed data
- In Program.csβMain, uncommentDbMigrationHelpers.EnsureSeedData(host), or use the dotnet CLI (dotnet run /seed), or setSeedConfigurationinappsettings.json.
- The ClientsandResourcessections inidentityserverdata.json(section:IdentityServerData) contain initial data based on the Duende IdentityServer sample.
- The Userssection inidentitydata.json(section:IdentityData) contains the default admin username and password for first login.
Authentication and Authorization
- Change the specific URLs and names for the IdentityServer and Authentication settings in appsettings.json
- In the controllers is used the policy which name is stored in - AuthorizationConsts.AdministrationPolicy. In the policy -AuthorizationConsts.AdministrationPolicyis defined required role stored in -appsettings.json-AdministrationRole.
- With the default configuration, it is necessary to configure and run instance of Duende IdentityServer. It is possible to use initial migration for creating the client as it mentioned above
Azure Key Vault
You can use Azure Key Vault by configuring it in your appsettings.json as follows:
"AzureKeyVaultConfiguration": {
  "AzureKeyVaultEndpoint": "",
  "ClientId": "",
  "ClientSecret": "",
  "UseClientCredentials": true
}
If your application is running in Azure App Service, simply specify AzureKeyVaultEndpoint.
For applications running outside of Azure, use the client credentials flow:
Register a new application in the Azure Portal, connect it to Azure Key Vault, and set up the client secret.
Azure Key Vault can be used for the following parts of the application:
Application Secrets and Database Connection Strings
To store configuration in Azure Key Vault, enable the following setting:
"AzureKeyVaultConfiguration": {
  "ReadConfigurationFromKeyVault": true
}
Data Protection
Enable Azure Key Vault for data protection with:
"DataProtectionConfiguration": {
  "ProtectKeysWithAzureKeyVault": true
}
Then, specify the key identifier:
"AzureKeyVaultConfiguration": {
  "DataProtectionKeyIdentifier": ""
}
IdentityServer Certificate for Signing Tokens
Generate a new certificate in Azure Key Vault and set its name in your configuration:
"AzureKeyVaultConfiguration": {
  "IdentityServerCertificateName": ""
}
Logging
This project uses Serilog for logging. The following sinks are pre-configured (see serilog.json):
- Console
- File
- MSSqlServer
- Seq
Example serilog.json configuration:
{
  "Serilog": {
    "MinimumLevel": {
      "Default": "Error",
      "Override": {
        "Skoruba": "Information"
      }
    },
    "WriteTo": [
      {
        "Name": "Console"
      },
      {
        "Name": "File",
        "Args": {
          "path": "log.txt",
          "rollingInterval": "Day"
        }
      },
      {
        "Name": "MSSqlServer",
        "Args": {
          "connectionString": "...",
          "tableName": "Log",
          "columnOptionsSection": {
            "addStandardColumns": ["LogEvent"],
            "removeStandardColumns": ["Properties"]
          }
        }
      }
      // You can also add Seq or other sinks as needed
    ]
  }
}
You can customize or add sinks as needed by editing the
serilog.jsonfile.
Audit Logging
- This solution uses audit logging via skoruba/AuditLogging. 
 (See the link for more details about the implementation.)
- In the Admin UI project, audit logging is set up as follows: 
services.AddAuditLogging(options => { options.Source = auditLoggingConfiguration.Source; })
    .AddDefaultHttpEventData(
        subjectOptions =>
        {
            subjectOptions.SubjectIdentifierClaim = auditLoggingConfiguration.SubjectIdentifierClaim;
            subjectOptions.SubjectNameClaim = auditLoggingConfiguration.SubjectNameClaim;
        },
        actionOptions =>
        {
            actionOptions.IncludeFormVariables = auditLoggingConfiguration.IncludeFormVariables;
        })
    .AddAuditSinks<DatabaseAuditEventLoggerSink<TAuditLog>>();
// repository for library
services.AddTransient<IAuditLoggingRepository<TAuditLog>, AuditLoggingRepository<TAuditLoggingDbContext, TAuditLog>>();
// repository and service for admin
services.AddTransient<IAuditLogRepository<TAuditLog>, AuditLogRepository<TAuditLoggingDbContext, TAuditLog>>();
services.AddTransient<IAuditLogService, AuditLogService<TAuditLog>>();
Admin Configuration
Admin and STS can be customized without editing code, in the appsettings.json under the AdminConfiguration section.
Audit Logging Configuration
In appsettings.json:
"AuditLoggingConfiguration": {
  "Source": "IdentityServer.Admin.Web",
  "SubjectIdentifierClaim": "sub",
  "SubjectNameClaim": "name",
  "IncludeFormVariables": false
}
The Skoruba.Duende.IdentityServer.Admin.BusinessLogic layer contains a folder called Events for audit logging.
In each service method, LogEventAsync is called, for example:
await AuditEventLogger.LogEventAsync(new ClientDeletedEvent(client));
The final audit log is available in the table dbo.AuditLog.
Login Configuration
In Skoruba.Duende.IdentityServer.STS.Identity/appsettings.json you can specify which column will be used for login (Username or Email):
"LoginConfiguration": {
  "ResolutionPolicy": "Username"
}
or
"LoginConfiguration": {
  "ResolutionPolicy": "Email"
}
Register Configuration
In Skoruba.Duende.IdentityServer.STS.Identity/appsettings.json you can disable user registration (default: true):
"RegisterConfiguration": {
  "Enabled": false
}
How to configure API & Swagger
- By default, the API runs on https://localhost:44302and Swagger UI is available athttps://localhost:44302/swagger.
- The Swagger UI is configured with a client and API in STS:
"AdminApiConfiguration": {
  "IdentityServerBaseUrl": "https://localhost:44310",
  "OidcSwaggerUIClientId": "skoruba_identity_admin_api_swaggerui",
  "OidcApiName": "skoruba_identity_admin_api"
}
How to configure an external provider in STS
In Skoruba.Duende.IdentityServer.STS.Identity/Helpers/StartupHelpers.cs, the method AddExternalProviders contains examples for configuring providers like GitHub and AzureAD via appsettings.json:
"ExternalProvidersConfiguration": {
  "UseGitHubProvider": false,
  "GitHubClientId": "",
  "GitHubClientSecret": "",
  "UseAzureAdProvider": false,
  "AzureAdClientId": "",
  "AzureAdTenantId": "",
  "AzureInstance": "",
  "AzureAdSecret": "",
  "AzureAdCallbackPath": "",
  "AzureDomain": ""
}
You can extend ExternalProvidersConfiguration with additional properties as needed.
If you use the DockerHub built image, you can configure these providers via appsettings without code changes:
- GitHub
- AzureAD
List of external providers for ASP.NET Core:
Azure AD
- Great article on setting up Azure AD:
 Quickstart: Sign in users in ASP.NET Core web apps
Email Service
You can configure email delivery via:
SendGrid
In the STS project (appsettings.json):
"SendgridConfiguration": {
  "ApiKey": "",
  "SourceEmail": "",
  "SourceName": ""
}
SMTP
"SmtpConfiguration": {
  "From": "",
  "Host": "",
  "Login": "",
  "Password": ""
}
Health checks
- AdminUI, AdminUI Api and STS contain endpoint health, which check databases and IdentityServer.
Localizations - labels, messages
- The project has following translations:
- English
 
Feel free to send a PR with your translation. βΊοΈ
- All labels and messages are stored in the translations.json - locatated in /i18n
Tests
- The solution contains unit and integration tests.
Overview
- STS: - Skoruba.Duende.IdentityServer.STS.Identity- project that contains the instance of Duende.IdentityServer and combine these samples - Quickstart UI for the Duende.IdentityServer with Asp.Net Core Identitye and Quickstart UI for the Duende.IdentityServer with EF Core storage and damienbod - IdentityServer4 and Identity template
 
Admin UI API
- Skoruba.Duende.IdentityServer.Admin.Apiβ Provides a REST API for managing Duende IdentityServer and ASP.NET Core Identity data, with integrated Swagger support.
Admin UI
- Skoruba.Duende.IdentityServer.Adminβ Main .NET project that references the SPA and UI packages.
- Skoruba.Duende.IdentityServer.Admin.UIβ Provides services and configuration for the Admin UI application.
- Skoruba.Duende.IdentityServer.Admin.UI.Spaβ Contains precompiled Admin UI assets.
Business Logic
- Skoruba.Duende.IdentityServer.Admin.BusinessLogicβ Contains DTOs, repositories, services, and mappers for Duende IdentityServer.
- Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Identityβ Contains DTOs, repositories, services, and mappers for ASP.NET Core Identity.
- Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Sharedβ Contains shared DTOs and exception handling for Duende IdentityServer and ASP.NET Core Identity.
Shared
- Skoruba.Duende.IdentityServer.Sharedβ Provides shared Identity DTOs for the Admin UI, Admin UI API, and STS.
- Skoruba.Duende.IdentityServer.Shared.Configurationβ Provides shared configuration for the Admin UI, Admin UI API, and STS.
Entity Framework
- Skoruba.Duende.IdentityServer.Admin.EntityFrameworkβ EF Core data layer containing entities for Duende IdentityServer.
- Skoruba.Duende.IdentityServer.Admin.EntityFramework.Configurationβ EF Core data layer containing entity configurations.
- Skoruba.Duende.IdentityServer.Admin.EntityFramework.Identityβ EF Core data layer containing repositories for ASP.NET Core Identity.
- Skoruba.Duende.IdentityServer.Admin.EntityFramework.Extensionsβ Provides extensions related to Entity Framework.
- Skoruba.Duende.IdentityServer.Admin.EntityFramework.Sharedβ Provides DbContexts for Duende IdentityServer, logging, and ASP.NET Core Identity, including shared Identity entities.
- Skoruba.Duende.IdentityServer.Admin.EntityFramework.SqlServerβ Contains database migrations for SQL Server.
- Skoruba.Duende.IdentityServer.Admin.EntityFramework.MySqlβ Contains database migrations for MySQL.
- Skoruba.Duende.IdentityServer.Admin.EntityFramework.PostgreSQLβ Contains database migrations for PostgreSQL.
Tests
- Skoruba.Duende.IdentityServer.Admin.Api.IntegrationTestsβ xUnit project providing integration tests for the Admin UI API.
- Skoruba.Duende.IdentityServer.Admin.UnitTestsβ xUnit project providing unit tests for the Admin UI.
- Skoruba.Duende.IdentityServer.STS.IntegrationTestsβ xUnit project providing integration tests for the STS.
Duende.IdentityServer
Clients
It is possible to define the configuration according the client type - by default the client types are used:
- Web Application - Authorization Code Flow with PKCE 
- Machine/Robot - Client Credentials flow 
- Entities: - Client Cors Origins
- Client Grant Types
- Client IdP Restrictions
- Client Post Logout Redirect Uris
- Client Properties
- Client Redirect Uris
- Client Scopes
- Client Secrets
 
API Resources
- Entities:
- Api Claims
- Api Scopes
- Api Scope Claims
- Api Secrets
- Api Properties
 
Identity Resources
- Entities:
- Identity Claims
- Identity Properties
 
Asp.Net Core Identity
Users
- Entities:
- User Roles
- User Logins
- User Claims
 
Roles
- Entities:
- Role Claims
 
Roadmap
1.0.0:
- Create the Business Logic & EF layers - available as a nuget package
-  Create a project template using dotnet CLI - dotnet new template- First template: The administration of the Duende.IdentityServer and Asp.Net Core Identity
 
-  Add logging into
- Database
- File
- Seq
 
-  Add localization for other languages
- English
- Chinese
- Russian
- Persian
- Swedish
- Danish
- Spanish
- French
- Finish
 
- Manage profile
- Password reset
- Link account to an external provider (example with Github)
- Two-Factor Authentication (2FA)
- User registration
-  Email service
- SendGrid
 
-  Add API
- Duende.IdentityServer
- Asp.Net Core Identity
- Add swagger support
 
- Add audit logs to track changes (#61)
- Docker support (#121)
- Health Checks (Databases and IdentityServer)
- Support for multiple database providers (SqlServer, Mysql, PostgreSQL)
- Simplify Admin Identity middleware (#430)
- Add support for loading signing key from Azure Key Vault (#533)
- Protect keys for dataprotection from Azure Key Vault (#715)
- Update to Duende.IdentityServer version 4 (#633)
- Add support for themes (#725)
- Extract UI part into nuget package (#770, #409, #55, #322, #28, #133)
1.1.0
- Update to .NET 6
- Update to Duende IdentityServer v6
1.2.0
- Update to Duende IdentityServer 6.2.1
- Add support for Dynamic Identity Providers
2.0.0
2.1.0
- Role users pagination (#169) 
- Add secure secret generation with 'secret_' prefix (#153) 
- Increase client name prominence (#154) 
- Added support for generation typescript client definition for API endpoints (#215) 
- Add new endpoints to API for client, api resource, api scopes validations and lists (#213) 
- Use named arguments in .AddIdentityServer() healthchecks (#201) 
- Change the AdminIdentityDbContext tablenames to be derived from appsettings (#196) 
- Raise UserLoginSuccessEvent when logging in with 2fa or recovery code (#202) 
2.2.2
-  Create a New Project Skoruba.Duende.IdentityServer.Admin.UI.Apito be Shipped as a NuGet Package
-  Fix DockerFile for All Projects for Multiplatform Builds (linux/amd64, linux/arm64)(#194)
- Add a New API Endpoint for Dashboard View
- Fix Import of dayjs for NSwag TypeScript Definition
2.3.0
- Fix Dashboard endpoint for getting Identity data
-  Update solution to the latest version of all nuget packages, including Duende.IdentityServerversion7.0.5
2.4.0
- Method CanInsert..Property of the controllers always return true (#235)
- Skoruba.Duende.IdentityServer.Shared.Configuration - replace deprecated Microsoft.Extensions.Configuration.AzureKeyVault package with Azure.Extensions.AspNetCore.Configuration.Secrets (#234)
- Can't update client because "Client Id clientId already exists" (#227)
- Migrate from Microsoft.Azure.KeyVault to the new Azure Key Vault API (#224)
- Docker Compose NGINX targeting wrong port (#222)
- Update all nuget packages to the latest versions, including Duende IdentityServer version 7.0.7. (fixed CVE-2024-39694) - (#236)
2.5.0
- Delete user from admin panel of admin app returns an error (#214)
2.6.0
- Update to .NET 9 and the latest version of Duende IdentityServer 7.2.1 (#250)
3.0.0
3.1.0
- Migrate STS from Bootstrap to Tailwind CSS (align with Admin UI design π¨), replace Gulp with modern tooling.
3.2.0
- Refactoring DTOs and ApiDTOs β consider removing AutoMapper
- Add more translations to new frontend pages
3.3.0
- Add management for claims (#22)
4.0.0
- Rewrite API controllers as Minimal API endpoints using VSA (Vertical Slice Architecture)
Licence
This repository is licensed under the terms of the Apache License 2.0.
Duende.IdentityServer License π
Duende.IdentityServer is available under both a FOSS (RPL) and a commercial license.
For the production environment is necessary to get the specific license. For more information about licensing of Duende.IdentityServer - please check this link.
This repository uses the source code from https://github.com/DuendeSoftware/IdentityServer.Quickstart.UI which is under the terms of the following license.
Acknowledgements
Thanks to TomΓ‘Ε‘ HΓΌbelbauer for the initial code review.
Thanks to Dominick Baier and Brock Allen - the creators of Duende.IdentityServer.
Contributors
Thanks goes to these wonderful people https://github.com/skoruba/Duende.IdentityServer.Admin/graphs/contributors. ππ»
Contributions of any kind are welcome!
Contact and Suggestion
I am happy to share my implementation of the administration for Duende.IdentityServer and ASP.NET Core Identity.
Any feedback is welcome - feel free to create an issue or send me an email - jan@skoruba.com. Thank you βΊοΈ
Support and Donation ποΈ
If you like my work, you can support me by donation. π
Github
https://github.com/sponsors/skoruba
Paypal
Patreon
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET | net9.0 is compatible. 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. | 
- 
                                                    net9.0- No dependencies.
 
NuGet packages (2)
Showing the top 2 NuGet packages that depend on Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Shared:
| Package | Downloads | 
|---|---|
| Skoruba.Duende.IdentityServer.Admin.BusinessLogic.Identity Business Logic layer for the administration of the Asp.Net Core Identity and Duende IdentityServer | |
| Skoruba.Duende.IdentityServer.Admin.BusinessLogic Business Logic layer for the administration of the Duende IdentityServer | 
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated | 
|---|---|---|
| 3.0.0-preview.6 | 86 | 10/17/2025 | 
| 3.0.0-preview.5 | 118 | 10/8/2025 | 
| 3.0.0-preview.4 | 133 | 9/24/2025 | 
| 3.0.0-preview.2 | 113 | 8/9/2025 | 
| 3.0.0-preview.1 | 98 | 7/30/2025 | 
| 2.7.0 | 297 | 10/16/2025 | 
| 2.6.0 | 3,672 | 4/22/2025 | 
| 2.5.0 | 20,930 | 10/6/2024 | 
| 2.4.0 | 666 | 9/29/2024 | 
| 2.3.0 | 10,557 | 6/17/2024 | 
| 2.2.2 | 276 | 6/16/2024 | 
| 2.2.1 | 247 | 6/16/2024 | 
| 2.2.0 | 295 | 6/16/2024 | 
| 2.1.0 | 1,150 | 5/23/2024 | 
| 2.0.0 | 7,625 | 2/7/2024 | 
| 2.0.0-rc1 | 191 | 2/7/2024 | 
| 1.2.0 | 28,267 | 1/19/2023 | 
| 1.2.0-rc2 | 336 | 1/19/2023 | 
| 1.2.0-rc1 | 372 | 1/19/2023 | 
| 1.1.0 | 57,192 | 1/26/2022 | 
| 1.1.0-rc3 | 428 | 1/26/2022 | 
| 1.1.0-rc2 | 439 | 1/3/2022 | 
| 1.1.0-rc1 | 397 | 12/22/2021 | 
| 1.0.1 | 2,306 | 12/19/2021 | 
| 1.0.0 | 1,139 | 12/17/2021 | 
| 1.0.0-rc1 | 445 | 12/17/2021 | 
| 1.0.0-preview5 | 7,091 | 5/1/2021 | 
| 1.0.0-preview4 | 483 | 3/27/2021 | 
| 1.0.0-preview3 | 713 | 3/24/2021 | 
| 1.0.0-preview2 | 657 | 3/23/2021 | 
| 1.0.0-preview1 | 687 | 3/20/2021 |