Version 5.x has been out of support since December 13, 2022, and this corresponding section of the documentation is no longer maintained. We strongly recommend upgrading to a supported version.

Overview

Confidential and credentialed clients need to authenticate with your IdentityServer before they can request tokens.

Duende IdentityServer has built-in support for various client credential types and authentication methods, and an extensible infrastructure to customize the authentication system.

All information in this section also applies to API secrets for introspection.

We recommend using asymmetric client credentials like the private key jwt or Mutual TLS authentication method over shared secrets.

Assigning secrets

A client secret is abstracted by the Secret class. It provides properties for setting the value and type as well as a description and expiration date.

var secret = new Secret
{
    Value = "foo",
    Type = "bar",

    Description = "my custom secret",
    Expiration = new DateTime(2021,12,31)
}

You can assign multiple secrets to a client to enable roll-over scenarios, e.g.:

var primary = new Secret("foo");
var secondary = new Secret("bar");

client.ClientSecrets = new[] { primary, secondary };

Secret parsing

During request processing, the secret must be somehow extracted from the incoming request. The various specs describe a couple of options, e.g. as part of the authorization header or the body payload.

It is the job of implementations of the ISecretParser interface to accomplish this. You can add secret parsers by calling the AddSecretParser() DI extension method.

The following secret parsers are part of Duende IdentityServer:

  • Duende.IdentityServer.Validation.BasicAuthenticationSecretParser

    parses an OAuth basic authentication formatted Authorization header. Enabled by default.

  • Duende.IdentityServer.Validation.PostBodySecretParser

    Parses from the client_id and client_secret body fields. Enabled by default.

  • Duende.IdentityServer.Validation.JwtBearerClientAssertionSecretParser

    Parses a JWT on the client_assertion body field. Can be enabled by calling the AddJwtBearerClientAuthentication DI extension method.

  • Duende.IdentityServer.Validation.MutualTlsSecretParser

    Parses the client_id body field and TLS client certificate. Can be enabled by calling the AddMutualTlsSecretValidators DI extension method.

Secret validation

It is the job of implementations of the ISecretValidator interface to validate the extracted credentials.

You can add secret parsers by calling the AddSecretValidator() DI extension method.

The following secret validators are part of Duende IdentityServer:

  • Duende.IdentityServer.Validation.HashedSharedSecretValidator

    Validates shared secrets that are stored hashed. Enabled by default.

  • Duende.IdentityServer.Validation.PlainTextSharedSecretValidator

    Validates shared secrets that are stored in plaintext.

  • Duende.IdentityServer.Validation.PrivateKeyJwtSecretValidator

    Validates JWTs that are signed with either X.509 certificates or keys wrapped in a JWK. Can be enabled by calling the AddJwtBearerClientAuthentication DI extension method.

  • Duende.IdentityServer.Validation.X509ThumbprintSecretValidator

    Validates X.509 client certificates based on a thumbprint. Can be enabled by calling the AddMutualTlsSecretValidators DI extension method.

  • Duende.IdentityServer.Validation.X509NameSecretValidator

    Validates X.509 client certificates based on a common name. Can be enabled by calling the AddMutualTlsSecretValidators DI extension method.