Zitadel 7.0.12
dotnet add package Zitadel --version 7.0.12
NuGet\Install-Package Zitadel -Version 7.0.12
<PackageReference Include="Zitadel" Version="7.0.12" />
paket add Zitadel --version 7.0.12
#r "nuget: Zitadel, 7.0.12"
// Install Zitadel as a Cake Addin #addin nuget:?package=Zitadel&version=7.0.12 // Install Zitadel as a Cake Tool #tool nuget:?package=Zitadel&version=7.0.12
ZITADEL
The ZITADEL.net library is a collection of tools for building web applications. It supports easy access to the ZITADEL API as well as authentication handlers for .NET web applications and web APIs.
Credentials
There are three credentials that help with the access to ZITADEL:
- "Application": used in web APIs to authenticate the relying party
- "BasicAuthentication": creating normal basic auth credentials
- "ServiceAccount": loads a service account json and authenticates against ZITADEL
The application supports creating a signed JWT token on behalf of the application:
var application = Application.LoadFromJsonString(
@"{
""type"": ""application"",
""keyId"": ""keyid"",
""key"": ""RSA KEY"",
""appId"": ""appid"",
""clientId"": ""client id""
}");
var jwt = await application.GetSignedJwtAsync("issuer");
The service account allows you to load a service account json and authenticate against ZITADEL to fetch a valid access token:
var serviceAccount = ServiceAccount.LoadFromJsonString(
@"{
""type"": ""serviceaccount"",
""keyId"": ""key id"",
""key"": ""RSA KEY"",
""userId"": ""user id""
}");
var token = await serviceAccount.AuthenticateAsync();
Accessing the ZITADEL API
This package also provides the compiled proto files. The ZITADEL library provides helper functions to create the various clients to manage resources.
The ZITADEL API Reference describes the gRPC clients, calls, and how to use them.
As an example, one may use the AuthClient
to fetch the user information.
With a personal access token of a service account
const string apiUrl = "https://zitadel-libraries-l8boqa.zitadel.cloud";
const string personalAccessToken = "TOKEN";
var client = Clients.AuthService(new(apiUrl, ITokenProvider.Static(personalAccessToken)));
var result = await client.GetMyUserAsync(new());
Console.WriteLine($"User: {result.User}");
With a service account JWT profile
const string apiProject = "PROJECT ID";
var serviceAccount = ServiceAccount.LoadFromJsonString(
@"{
""type"": ""serviceaccount"",
""keyId"": ""key id"",
""key"": ""RSA KEY"",
""userId"": ""user id""
}");
client = Clients.AuthService(
new(
apiUrl,
ITokenProvider.ServiceAccount(
apiUrl,
serviceAccount,
new(){ ApiAccess = true })));
result = await client.GetMyUserAsync(new());
Console.WriteLine($"User: {result.User}");
You can also create the clients by yourself:
var accessToken = "fetch it somehow";
var channel = GrpcChannel.ForAddress("https://my-zitadel-api.com");
var client = new AuthService.AuthServiceClient(channel);
var result = await client.GetMyUserAsync(
new(),
new Metadata { { "Authorization", $"Bearer {accessToken}" } });
Console.WriteLine($"User: {result.User}");
Authentication in Web Apps
To authenticate ASP.NET web applications, use the AddZitadel()
extension
method on the IAuthenticationBuilder
. You will need an application
on a ZITADEL instance and a client ID.
// -- snip --
builder.Services
.AddAuthorization()
.AddAuthentication(ZitadelDefaults.AuthenticationScheme)
.AddZitadel(
o =>
{
o.Authority = "https://zitadel-libraries-l8boqa.zitadel.cloud/";
o.ClientId = "170088295403946241@library";
o.SignInScheme = IdentityConstants.ExternalScheme;
})
.AddExternalCookie()
.Configure(
o =>
{
o.Cookie.HttpOnly = true;
o.Cookie.IsEssential = true;
o.Cookie.SameSite = SameSiteMode.None;
o.Cookie.SecurePolicy = CookieSecurePolicy.Always;
});
// -- snip --
The example above allows an ASP.NET web application to authenticate against ZITADEL and use the external cookie scheme to store the access token in a secure cookie.
Authentication in Web APIs
Authenticating web APIs is similar to authenticating web apps. In contrast to a web application, the web API cannot hold a user session with an external application cookie. Instead, web APIs use the introspection endpoint of ZITADEL to fetch information about the presented access token (be it JWT or opaque token). The authentication mechanism is based on the OAuth2Introspection package of "IdentityModel".
In ZITADEL you may use two different authentication methods:
- Basic Auth
- JWT Profile
With basic auth, you need to use client_id
and client_secret
, and
with JWT profile, a special json is generated for you, that is required
to authenticate the web API against ZITADEL.
builder.Services
.AddAuthorization()
.AddAuthentication()
.AddZitadelIntrospection(
o =>
{
o.Authority = "https://zitadel-libraries-l8boqa.zitadel.cloud/";
o.ClientId = "170102032621961473@library";
o.ClientSecret = "KNkKW8nx3rlEKOeHNUcPx80tZTP1uZTjJESfdA3kMEK7urhX3ChFukTMQrtjvG70";
});
The code above uses basic authentication. You need to be sure that your API application in ZITADEL is configured to use basic authentication.
Below, a JWT profile (application credential) is used to authenticate the web API. Note that the client id is no longer required. Using JWT profile is the recommended way to authenticate web APIs.
builder.Services
.AddAuthorization()
.AddAuthentication()
.AddZitadelIntrospection(
o =>
{
o.Authority = "https://zitadel-libraries-l8boqa.zitadel.cloud";
o.JwtProfile = Application.LoadFromJsonString("YOUR APPLICATION JSON");
});
Caching
The OAuth2Introspection
supports caching of the access token for a configured amount of time. This reduces the load on
the issuer and allows faster requests for the same token. To enable caching, you need to configure
caching in the options of AddZitadelIntrospection
and add an implementation of IDistributedCache
.
Faking / Mocking local Authentication
To enable local development or testing without a real world ZITADEL instance, you may use the mocked authentication. It simply adds all provided claims to the constructed identity and lets all calls pass as "authenticated".
You may send a request with two special headers to overwrite the behaviour per request:
x-zitadel-fake-auth
: If this header is set to "false", the request will return as "unauthenticated"x-zitadel-fake-user-id
: If this header is set, the value of the header will be user as user ID.
To enable the fake authentication, simply use the AddZitadelFake
extension method:
builder.Services
.AddAuthorization()
.AddAuthentication()
.AddZitadelFake(o =>
{
o.FakeZitadelId = "1337";
});
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. |
-
net8.0
- BouncyCastle.Cryptography (>= 2.5.0)
- Google.Protobuf (>= 3.29.3)
- Grpc (>= 2.46.6)
- Grpc.Net.ClientFactory (>= 2.67.0)
- Grpc.Net.Common (>= 2.67.0)
- IdentityModel.AspNetCore.OAuth2Introspection (>= 6.2.0)
- jose-jwt (>= 5.1.1)
- Microsoft.AspNetCore.Authentication.JwtBearer (>= 8.0.12)
- Microsoft.AspNetCore.Authentication.OpenIdConnect (>= 8.0.12)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Zitadel:
Package | Downloads |
---|---|
Zitadel.Api
The API library for Zitadel. Implemented with gRPC, it allows access to the API of any Zitadel instance (default: https://api.zitadel.ch). |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
7.0.12 | 43 | 1/23/2025 |
7.0.11 | 512 | 1/15/2025 |
7.0.10 | 687 | 1/8/2025 |
7.0.9 | 1,094 | 12/18/2024 |
7.0.8 | 181 | 12/17/2024 |
7.0.7 | 964 | 12/15/2024 |
7.0.6 | 1,321 | 12/4/2024 |
7.0.5 | 457 | 12/1/2024 |
7.0.4 | 294 | 11/27/2024 |
7.0.3 | 778 | 11/21/2024 |
7.0.2 | 1,009 | 11/13/2024 |
7.0.1 | 485 | 11/8/2024 |
7.0.0 | 1,670 | 10/28/2024 |
6.2.0 | 505 | 10/28/2024 |
6.1.4 | 119 | 10/28/2024 |
6.1.3 | 113 | 10/28/2024 |
6.1.2 | 48,579 | 1/31/2024 |
6.1.1 | 293 | 1/26/2024 |
6.1.0 | 700 | 1/26/2024 |
6.0.0 | 511 | 1/24/2024 |
5.3.3 | 6,361 | 1/10/2024 |
5.3.2 | 692 | 1/9/2024 |
5.3.1 | 1,979 | 1/3/2024 |
5.3.0 | 3,144 | 12/19/2023 |
5.2.26 | 13,635 | 10/4/2023 |
5.2.25 | 5,272 | 9/13/2023 |
5.2.24 | 731 | 9/8/2023 |
5.2.23 | 462 | 9/7/2023 |
5.2.22 | 401 | 9/7/2023 |
5.2.21 | 1,363 | 8/25/2023 |
5.2.20 | 1,774 | 8/19/2023 |
5.2.19 | 1,251 | 8/11/2023 |
5.2.18 | 1,002 | 8/9/2023 |
5.2.17 | 430 | 8/8/2023 |
5.2.16 | 2,097 | 7/17/2023 |
5.2.15 | 472 | 7/17/2023 |
5.2.14 | 621 | 7/11/2023 |
5.2.13 | 1,287 | 7/7/2023 |
5.2.12 | 534 | 7/5/2023 |
5.2.11 | 982 | 6/24/2023 |
5.2.10 | 458 | 6/23/2023 |
5.2.9 | 628 | 6/18/2023 |
5.2.8 | 7,100 | 5/27/2023 |
5.2.7 | 708 | 5/17/2023 |
5.2.6 | 596 | 5/9/2023 |
5.2.5 | 549 | 5/6/2023 |
5.2.4 | 533 | 5/5/2023 |
5.2.3 | 3,477 | 4/27/2023 |
5.2.2 | 624 | 4/22/2023 |
5.2.1 | 561 | 4/17/2023 |
5.2.0 | 695 | 4/14/2023 |
5.2.0-prerelease.3 | 90 | 4/14/2023 |
5.2.0-prerelease.2 | 91 | 4/14/2023 |
5.2.0-prerelease.1 | 94 | 4/13/2023 |
5.1.1 | 496 | 4/14/2023 |
5.1.0 | 512 | 4/13/2023 |
5.0.32 | 514 | 4/13/2023 |
5.0.31 | 477 | 4/12/2023 |
5.0.30 | 869 | 3/31/2023 |
5.0.29 | 578 | 3/26/2023 |
5.0.28 | 1,416 | 3/16/2023 |
5.0.27 | 590 | 3/15/2023 |
5.0.26 | 704 | 3/8/2023 |
5.0.25 | 953 | 3/3/2023 |
5.0.24 | 649 | 2/17/2023 |
5.0.23 | 563 | 2/16/2023 |
5.0.22 | 571 | 2/15/2023 |
5.0.21 | 595 | 2/15/2023 |
5.0.20 | 613 | 2/14/2023 |
5.0.19 | 630 | 2/10/2023 |
5.0.18 | 570 | 2/9/2023 |
5.0.17 | 593 | 2/8/2023 |
5.0.16 | 1,790 | 1/12/2023 |
5.0.15 | 610 | 1/11/2023 |
5.0.14 | 788 | 1/3/2023 |
5.0.13 | 701 | 12/16/2022 |
5.0.12 | 687 | 12/14/2022 |
5.0.11 | 651 | 12/8/2022 |
5.0.10 | 611 | 12/8/2022 |
5.0.9 | 704 | 12/3/2022 |
5.0.8 | 661 | 12/1/2022 |
5.0.7 | 834 | 11/18/2022 |
5.0.6 | 731 | 11/8/2022 |
5.0.5 | 781 | 10/27/2022 |
5.0.4 | 748 | 10/19/2022 |
5.0.3 | 753 | 10/17/2022 |
5.0.2 | 1,285 | 10/12/2022 |
5.0.1 | 738 | 10/6/2022 |
5.0.0 | 720 | 10/6/2022 |
4.0.12 | 763 | 9/30/2022 |
4.0.11 | 749 | 9/28/2022 |
4.0.10 | 778 | 9/27/2022 |
4.0.9 | 842 | 9/14/2022 |
4.0.8 | 849 | 9/2/2022 |
4.0.7 | 877 | 8/25/2022 |
4.0.6 | 773 | 8/19/2022 |
4.0.5 | 764 | 8/17/2022 |
4.0.4 | 768 | 8/10/2022 |
4.0.3 | 992 | 7/26/2022 |
4.0.2 | 870 | 7/22/2022 |
4.0.1 | 837 | 7/18/2022 |
4.0.0 | 813 | 7/18/2022 |
3.4.7 | 2,374 | 4/22/2022 |
3.4.6 | 1,041 | 4/20/2022 |
3.4.5 | 1,062 | 4/12/2022 |
3.4.4 | 1,057 | 4/1/2022 |
3.4.3 | 1,045 | 3/22/2022 |
3.4.2 | 1,088 | 3/8/2022 |
3.4.1 | 1,283 | 2/23/2022 |
3.4.0 | 991 | 2/23/2022 |
3.3.12 | 1,421 | 11/19/2021 |
3.3.11 | 1,049 | 11/8/2021 |
3.3.10 | 997 | 10/29/2021 |
3.3.9 | 961 | 10/26/2021 |
3.3.8 | 1,004 | 10/20/2021 |
3.3.7 | 1,009 | 10/19/2021 |
3.3.6 | 991 | 10/12/2021 |
3.3.5 | 1,016 | 10/11/2021 |
3.3.4 | 964 | 10/5/2021 |
3.3.3 | 1,026 | 9/30/2021 |
3.3.2 | 1,012 | 9/15/2021 |
3.3.1 | 946 | 9/14/2021 |
3.3.0 | 1,085 | 9/8/2021 |
3.2.3 | 958 | 9/7/2021 |
3.2.2 | 998 | 8/18/2021 |
3.2.1 | 969 | 8/13/2021 |
3.2.0 | 971 | 8/4/2021 |
3.1.8 | 1,102 | 6/22/2021 |
3.1.7 | 957 | 6/11/2021 |
3.1.6 | 2,884 | 6/8/2021 |
3.1.5 | 1,016 | 5/26/2021 |
3.1.4 | 885 | 5/25/2021 |
3.1.3 | 891 | 5/24/2021 |
3.1.2 | 919 | 5/13/2021 |
3.1.1 | 902 | 5/11/2021 |
3.1.0 | 956 | 5/7/2021 |
3.0.3 | 934 | 5/7/2021 |
3.0.2 | 983 | 5/1/2021 |
3.0.1 | 909 | 4/21/2021 |
3.0.0 | 914 | 4/16/2021 |
2.2.6 | 998 | 4/13/2021 |
2.2.5 | 933 | 4/9/2021 |
2.2.4 | 981 | 4/8/2021 |
2.2.3 | 995 | 4/6/2021 |
2.2.2 | 871 | 4/2/2021 |
2.2.1 | 928 | 4/1/2021 |
2.2.0 | 886 | 3/30/2021 |
2.1.2 | 1,014 | 3/25/2021 |
2.1.1 | 886 | 3/25/2021 |
2.1.0 | 687 | 3/25/2021 |
2.0.0 | 780 | 3/8/2021 |
1.2.0 | 1,043 | 1/14/2021 |
1.1.0 | 786 | 1/11/2021 |
1.0.0 | 907 | 12/18/2020 |
'## [7.0.12](https://github.com/smartive/zitadel-net/compare/v7.0.11...v7.0.12) (2025-01-23)
### Bug Fixes
* **deps:** update dependency jose-jwt to 5.1.1 ([#956](https://github.com/smartive/zitadel-net/issues/956)) ([a7fcbd6](https://github.com/smartive/zitadel-net/commit/a7fcbd6ece7a8d6c70578cc398b2681a596cfce3))
'