Keycloak.AuthServices.Authentication
2.0.0-pre-2
Prefix Reserved
See the version list below for details.
dotnet add package Keycloak.AuthServices.Authentication --version 2.0.0-pre-2
NuGet\Install-Package Keycloak.AuthServices.Authentication -Version 2.0.0-pre-2
<PackageReference Include="Keycloak.AuthServices.Authentication" Version="2.0.0-pre-2" />
paket add Keycloak.AuthServices.Authentication --version 2.0.0-pre-2
#r "nuget: Keycloak.AuthServices.Authentication, 2.0.0-pre-2"
// Install Keycloak.AuthServices.Authentication as a Cake Addin #addin nuget:?package=Keycloak.AuthServices.Authentication&version=2.0.0-pre-2&prerelease // Install Keycloak.AuthServices.Authentication as a Cake Tool #tool nuget:?package=Keycloak.AuthServices.Authentication&version=2.0.0-pre-2&prerelease
Keycloak.AuthServices
Easy Authentication and Authorization with Keycloak in .NET and ASP.NET Core.
Documentation
See the docs: https://nikiforovall.github.io/keycloak-authorization-services-dotnet/.
Installation
dotnet add package Keycloak.AuthServices.Authentication
dotnet add package Keycloak.AuthServices.Authorization
dotnet add package Keycloak.AuthServices.Sdk
Getting Started
See the docs: https://nikiforovall.github.io/keycloak-authorization-services-dotnet/.
// Program.cs
using Keycloak.AuthServices.Authentication;
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddKeycloakWebApiAuthentication(builder.Configuration);
builder.Services.AddAuthorization();
var app = builder.Build();
app.UseAuthentication();
app.UseAuthorization();
app.MapGet("/", () => "Hello World!").RequireAuthorization();
app.Run();
In this example, configuration is based on appsettings.json
.
//appsettings.json
{
"Keycloak": {
"realm": "Test",
"auth-server-url": "http://localhost:8080/",
"ssl-required": "none",
"resource": "test-client",
"verify-token-audience": false,
"credentials": {
"secret": ""
},
"confidential-port": 0
}
}
You can always fetch the corresponding authentication options like this:
var authenticationOptions = configuration
.GetSection(KeycloakAuthenticationOptions.Section)
.Get<KeycloakAuthenticationOptions>(KeycloakFormatBinder.Instance);
services.AddKeycloakAuthentication(authenticationOptions);
Note, the default case convention for KeycloakAuthenticationOptions
configuration is PascalCase, but you can change it by specifying KeycloakFormatBinder.Instance
binding options to retrieve it based on original kebab-case. See changes in 2.0.0
Example Authorization
With Keycloak.AuthServices.Authorization
, you can implement role-based authorization in your application. This package allows you to define policies based on roles. Also, you can use Keycloak as Authorization Server. It is a powerful way to organize and apply authorization polices centrally.
var builder = WebApplication.CreateBuilder(args);
var host = builder.Host;
var configuration = builder.Configuration;
var services = builder.Services;
services.AddKeycloakWebApiAuthentication(configuration);
services.AddAuthorization(options =>
{
options.AddPolicy("AdminAndUser", builder =>
{
builder
.RequireRealmRoles("User") // Realm role is fetched from token
.RequireResourceRoles("Admin"); // Resource/Client role is fetched from token
});
})
.AddKeycloakAuthorization(configuration);
var app = builder.Build();
app.UseAuthentication();
app.UseAuthorization();
app.MapGet("/hello", () => "[]")
.RequireAuthorization("AdminAndUser");
app.Run();
Build and Development
dotnet cake --target build
dotnet pack -o ./Artefacts
Blog Posts
For more information and real world examples, please see my blog posts related to Keycloak and .NET https://nikiforovall.github.io/tags.html#keycloak-ref
- https://nikiforovall.github.io/aspnetcore/dotnet/2022/08/24/dotnet-keycloak-auth.html
- https://nikiforovall.github.io/dotnet/keycloak/2022/12/28/keycloak-authorization-server.html
- https://nikiforovall.github.io/blazor/dotnet/2022/12/08/dotnet-keycloak-blazorwasm-auth.html
Reference
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. 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. |
-
net6.0
- Microsoft.AspNetCore.Authentication.JwtBearer (>= 6.0.29)
- Microsoft.AspNetCore.Authentication.OpenIdConnect (>= 6.0.29)
- Microsoft.Extensions.Configuration.Abstractions (>= 8.0.0)
- Microsoft.Extensions.Configuration.Json (>= 8.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.1)
NuGet packages (9)
Showing the top 5 NuGet packages that depend on Keycloak.AuthServices.Authentication:
Package | Downloads |
---|---|
Gathrr.Framework.Infrastructure
Package Description |
|
MicroEthos.Common.Endpoints
Package Description |
|
Manjalabs.Library
Package Description |
|
Wcz.Layout
Package Description |
|
Inspire.Framework.Infrastructure
Package Description |
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on Keycloak.AuthServices.Authentication:
Repository | Stars |
---|---|
NikiforovAll/keycloak-authorization-services-dotnet
Authentication and Authorization with Keycloak and ASP.NET Core 🔐
|
Version | Downloads | Last updated |
---|---|---|
2.6.0 | 60 | 11/30/2024 |
2.5.5 | 578 | 11/27/2024 |
2.5.3 | 78,275 | 8/19/2024 |
2.5.2 | 100,895 | 6/15/2024 |
2.5.1 | 15,374 | 6/11/2024 |
2.5.0 | 16,004 | 6/2/2024 |
2.4.1 | 18,266 | 5/16/2024 |
2.4.0 | 2,140 | 5/12/2024 |
2.3.0 | 525 | 5/10/2024 |
2.3.0-pre-1 | 115 | 5/9/2024 |
2.2.1 | 949 | 5/9/2024 |
2.2.0 | 401 | 5/8/2024 |
2.1.0 | 4,516 | 5/7/2024 |
2.0.0 | 3,171 | 5/5/2024 |
2.0.0-pre-4 | 130 | 5/4/2024 |
2.0.0-pre-3 | 204 | 4/26/2024 |
2.0.0-pre-2 | 115 | 4/25/2024 |
2.0.0-pre-1 | 268 | 4/24/2024 |
1.6.0 | 307,981 | 10/25/2023 |
1.5.2 | 268,540 | 5/27/2023 |
1.5.1 | 172,175 | 1/17/2023 |
1.5.0 | 683 | 1/17/2023 |
1.4.1 | 3,568 | 1/12/2023 |
1.4.0 | 5,512 | 1/4/2023 |
1.3.0 | 4,421 | 12/28/2022 |
1.2.1 | 83,912 | 9/22/2022 |
1.2.0 | 6,765 | 8/24/2022 |
1.1.0 | 13,109 | 1/30/2022 |
1.0.5 | 161 | 1/29/2022 |
1.0.4 | 3,373 | 1/28/2022 |
1.0.3 | 136 | 1/28/2022 |
1.0.2 | 134 | 1/23/2022 |
1.0.1 | 684 | 1/19/2022 |
1.0.0 | 2,242 | 1/19/2022 |
The release notes are available at https://github.com/NikiforovAll/keycloak-authorization-services-dotnet/releases