Keycloak.AuthServices.Common 2.0.0-pre-2

Prefix Reserved
This is a prerelease version of Keycloak.AuthServices.Common.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Keycloak.AuthServices.Common --version 2.0.0-pre-2                
NuGet\Install-Package Keycloak.AuthServices.Common -Version 2.0.0-pre-2                
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="Keycloak.AuthServices.Common" Version="2.0.0-pre-2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Keycloak.AuthServices.Common --version 2.0.0-pre-2                
#r "nuget: Keycloak.AuthServices.Common, 2.0.0-pre-2"                
#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.
// Install Keycloak.AuthServices.Common as a Cake Addin
#addin nuget:?package=Keycloak.AuthServices.Common&version=2.0.0-pre-2&prerelease

// Install Keycloak.AuthServices.Common as a Cake Tool
#tool nuget:?package=Keycloak.AuthServices.Common&version=2.0.0-pre-2&prerelease                

Keycloak.AuthServices

Build CodeQL NuGet contributionswelcome Conventional Commits License

Easy Authentication and Authorization with Keycloak in .NET and ASP.NET Core.

Package Version Description
Keycloak.AuthServices.Authentication Nuget Keycloak Authentication JWT + OICD
Keycloak.AuthServices.Authorization Nuget Authorization Services. Use Keycloak as authorization server
Keycloak.AuthServices.Sdk Nuget HTTP API integration with Keycloak

GitHub Actions Build History

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

Reference

Product 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.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on Keycloak.AuthServices.Common:

Package Downloads
Keycloak.AuthServices.Sdk

HttpClient integration with Keycloak. Includes HTTP Admin REST API, Protection API.

Keycloak.AuthServices.Sdk.Kiota

Keycloak HTTP Admin API generated by Kiota

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on Keycloak.AuthServices.Common:

Repository Stars
NikiforovAll/keycloak-authorization-services-dotnet
Authentication and Authorization with Keycloak and ASP.NET Core 🔐
Version Downloads Last updated
2.6.0 6,424 11/30/2024
2.5.5 3,177 11/27/2024
2.5.3 49,326 8/19/2024
2.5.2 44,811 6/15/2024
2.5.1 642 6/11/2024
2.5.0 9,014 6/2/2024
2.4.1 7,573 5/16/2024
2.4.0 892 5/12/2024
2.3.0 338 5/10/2024
2.3.0-pre-1 128 5/9/2024
2.2.1 648 5/9/2024
2.2.0 197 5/8/2024
2.1.0 2,642 5/7/2024
2.0.0 718 5/5/2024
2.0.0-pre-4 145 5/4/2024
2.0.0-pre-3 200 4/26/2024
2.0.0-pre-2 136 4/25/2024
2.0.0-pre-1 302 4/24/2024
1.7.0 3,048 4/23/2024
1.6.0 98,311 10/25/2023
1.5.2 74,667 5/27/2023
1.5.1 51,802 1/17/2023
1.5.0 612 1/17/2023
1.4.1 1,021 1/12/2023
1.4.0 509 1/4/2023
1.3.0 1,087 12/28/2022
1.2.1 9,848 9/22/2022
1.2.0 743 8/24/2022
1.1.0 14,827 1/30/2022
1.0.5 151 1/29/2022
1.0.4 3,349 1/28/2022
1.0.3 137 1/28/2022
1.0.2 142 1/23/2022
1.0.1 664 1/19/2022