Keycloak.AuthServices.Authorization 1.4.1

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

// Install Keycloak.AuthServices.Authorization as a Cake Tool
#tool nuget:?package=Keycloak.AuthServices.Authorization&version=1.4.1                

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

Example

Demonstrates how to add JWT-based authentication and custom authorization policy.

var builder = WebApplication.CreateBuilder(args);

var host = builder.Host;
var configuration = builder.Configuration;
var services = builder.Services;

host.ConfigureKeycloakConfigurationSource();
// conventional registration from keycloak.json
services.AddKeycloakAuthentication(configuration);

services.AddAuthorization(options =>
    {
        options.AddPolicy("RequireWorkspaces", builder =>
        {
            builder.RequireProtectedResource("workspaces", "workspaces:read") // HTTP request to Keycloak to check protected resource
                .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()
    .UseAuthorization();

app.MapGet("/workspaces", () => "[]")
    .RequireAuthorization("RequireWorkspaces");

app.Run();

Keycloak.AuthServices.Authentication

Keycloak.AuthServices.Authentication

Add OpenID Connect + JWT Bearer token authentication.

// add configuration from keycloak file
host.ConfigureKeycloakConfigurationSource("keycloak.json");
// add authentication services, OICD JwtBearerDefaults.AuthenticationScheme
services.AddKeycloakAuthentication(configuration, o =>
{
    o.RequireHttpsMetadata = false;
});

Client roles are automatically transformed into user role claims KeycloakRolesClaimsTransformation.

See Keycloak.AuthServices.Authentication - README.md

Keycloak installation file:

// confidential client
{
  "realm": "<realm>",
  "auth-server-url": "http://localhost:8088/auth/",
  "ssl-required": "external", // external | none
  "resource": "<clientId>",
  "verify-token-audience": true,
  "credentials": {
    "secret": ""
  }
}
// public client
{
  "realm": "<realm>",
  "auth-server-url": "http://localhost:8088/auth/",
  "ssl-required": "external",
  "resource": "<clientId>",
  "public-client": true,
  "confidential-port": 0
}

Keycloak.AuthServices.Authorization

Keycloak.AuthServices.Authorization

services.AddAuthorization(authOptions =>
{
    authOptions.AddPolicy("<policyName>", policyBuilder =>
    {
        // configure policies here
    });
}).AddKeycloakAuthorization(configuration);

See Keycloak.AuthServices.Authorization - README.md

Keycloak.AuthServices.Sdk

Keycloak.AuthServices.Sdk

Keycloak API clients.

Service Description
IKeycloakClient Unified HTTP client - IKeycloakRealmClient, IKeycloakProtectedResourceClient
IKeycloakRealmClient Keycloak realm API
IKeycloakProtectedResourceClient Protected resource API
IKeycloakUserClient Keycloak user API
IKeycloakProtectionClient Authorization server API, used by AddKeycloakAuthorization
// requires confidential client
services.AddKeycloakAdminHttpClient(keycloakOptions);

// based on token forwarding HttpClient middleware and IHttpContextAccessor
services.AddKeycloakProtectionHttpClient(keycloakOptions);

See Keycloak.AuthServices.Sdk - README.md

Build and Development

dotnet cake --target build

dotnet pack -o ./Artefacts

Blog Posts

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 (11)

Showing the top 5 NuGet packages that depend on Keycloak.AuthServices.Authorization:

Package Downloads
Gathrr.Framework.Infrastructure

Package Description

Inspire.Framework.Infrastructure

Package Description

Wcz.Layout

Package Description

Feijuca.Auth

Feijuca.Auth simplifies Keycloak integration for user management and multi-tenancy. It features TokenManager for centralized API calls to manage users and auth services for handling multiple tenants using Keycloak realms. Check the documentation for more details!

Iskra.Core.Auth

Настройка авторизации в Keycloak.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.6.1 2,879 3/13/2025
2.6.0 58,366 11/30/2024
2.5.5 5,807 11/27/2024
2.5.3 138,660 8/19/2024
2.5.2 97,785 6/15/2024
2.5.1 3,937 6/11/2024
2.5.0 10,874 6/2/2024
2.4.1 15,318 5/16/2024
2.4.0 1,343 5/12/2024
2.3.0 365 5/10/2024
2.3.0-pre-1 86 5/9/2024
2.2.1 845 5/9/2024
2.2.0 185 5/8/2024
2.1.0 3,121 5/7/2024
2.0.0 3,657 5/5/2024
2.0.0-pre-4 128 5/4/2024
2.0.0-pre-3 199 4/26/2024
2.0.0-pre-2 113 4/25/2024
2.0.0-pre-1 355 4/24/2024
1.6.0 287,172 10/25/2023
1.5.2 178,040 5/27/2023
1.5.1 244,481 1/17/2023
1.5.0 640 1/17/2023
1.4.1 2,623 1/12/2023
1.4.0 5,563 1/4/2023
1.3.0 1,658 12/28/2022
1.2.1 36,536 9/22/2022
1.2.0 2,872 8/24/2022
1.1.0 13,264 1/30/2022
1.0.5 152 1/29/2022
1.0.4 151 1/28/2022
1.0.3 146 1/28/2022
1.0.2 148 1/23/2022
1.0.1 632 1/19/2022
1.0.0 4,763 1/19/2022