Configure an identity provider
In its default configuration, Domino REST API uses itself as its identity provider (IdP), so it is client and IdP at the same time. This allows you to start evaluating and testing out of the box. To enable this, you need to have an HTTP password configured in Domino and good enough for internal use.
However, for an actual deployment, you might want to configure your own IdP and authentication flow. The only IdP requirements are use of a supported algorithm for signing and a token with the expected format.
Client Ids
When configuring an external IdP using OIDC or OIDC-idpcat, you need to provide a clientId. It's recommended to use Domino, but the admins of your IdP might have other ideas. In any case, that's the clientId for the REST server. It's NOT the one for the Admin UI or the Office Forms Based Authentication (OFBA) for attachment editing. To be fully operational, you need to configure at least three clients on your IdP:
- Dominofor the server (client secret might be handeled by- idpcat.nsf)
- keepadminuifor the Domino REST API admin client
- keepofbafor the Office document round trip experience
- One each for your custom client applications (with clientSecret for servers or PKCE for clients)
Use the internal IdP as learning resource
The application configuration provided by the internal IdP makes it easy to configure and retrieve client-specific JWT that have all the required fields. Test your application with that and use the defined proprties, scopes foremost, to requests the external IdP client configurations.
About this task
The provided information guides you of configuring your own IdP and authentication flow for use in an actual deployment.
Identity providers
Domino REST API supports identity providers that can produce JWT access tokens. Some examples are:
- Microsoft Active Directory
- 
Redhat Keycloak 
- 
Tivoli Federate Identity Manager 
- Okta
- 
Auth0 
Tip
Check out the Keycloak example configuration.
Example For Encode JWT
You can use the official JWT site to decode and inspect the encoded token.

eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJUaGUgRGVtbyBXaXp6YXJkIiwic3ViIjoiQ049RG9jdG9yIE5vdGVzL0
89UHJvamVjdEtlZXAiLCJzY29wZXMiOiJNQUlMICREQVRBIiwiaWF0IjoxNjE4NTA2MzM5LCJleHAiOjE2MTg1MDk5MzksI
mF1ZCI6IkRvbWlubyJ9.HJC2MTu8OPT8KnsZnLWqIIc3CoPaEmzQwnygEaRjapk
When decoded, this translates to:
HEADER: ALGORITHM & TOKEN TYPE
{
  "typ": "JWT",
  "alg": "HS256"
}
PAYLOAD: DATA
{
  "iss": "The Demo Wizzard",
  "sub": "CN=Doctor Notes/O=ProjectKeep",
  "scope": "MAIL $DATA",
  "iat": 1618506339,
  "exp": 1618509939,
  "aud": "Domino"
}
wherein:
- issstands for Issuer and refers to the name of the IdP providing the claim.
- substands for Subject and refers to the full qualified X500 expanded Notes name, which starts with- CN=.
- 
scoperefers to the databases and services that the user accesses. For more information, see Scopes.
- 
iatstands for Issued at and refers to the epoch time of creation.
- expstands for Expiry and refers to the epoch time of expiration. It must fit into- maxJwtDurationnumber of minutes.
- audstands for Audience and MUST have a value of- Domino(case-sensitive).
VERIFY SIGNATURE
HMACSHA256(
  base64UrlEncode(header) + "." +
  base64UrlEncode(payload),
your-256-bit-secret
) secret base64 encoded
Add your own IdP
To add an IdP:
- Create a JSON file in the keepconfig.ddirectory.
- Allow access to the public key from your IdP.
The JSON file looks like this:
{
  "disableJwtExpiryCheck": false,
  "jwt": {
    "my-idp": {
      "active": true,
      "algorithm": "RS256",
      "keyFile": "10-jwt.pubkey"
    }
  }
}
wherein:
- disableJwtExpiryCheck: By setting the value to- true, the enforcement of JWT expiration can be disabled. DO NOT do this on a production system (default is- false).
- jwt: Entry is related to JWT authorization.
- my-idp: The name you give your IdP. It could be- Rumpelstielzchenbut needs to be unique on your server.
- active: True/false.
- algorithm: Currently supported:- RS256.
- keyFile: Path to public key file (PEM format), either relative to- keepconfig.dor an absolute path.
Domino REST API supports more than one IdP, distinguished by the name my-idp in the example. Access checking takes longer the more identity providers you configure since Domino REST API checks every provider's key until it finds a match.
Obtaining the public key directly from the IdP
TO ease configuration and simplify key rollover, the public key for JWT verification can be directly obtained from the key server. You are responsible to only use trusted connections.
{
  "disableJwtExpiryCheck": false,
  "jwt": {
    "somother": {
      "active": true,
      "providerUrl": "https://someidp.your.domain"
    }
  }
The Domino REST API will extend this URL to https://someidp.your.domain/.well-known/openid-configuration and check for a JSON return containing the jwks_uri key. When your IdP doesn't use the .well-known approach, such as Keycloak, you need to directly point to the key URL.
Note
Keycloak's providerUrl is different from the general IdP practice to use /.well-known/openid-configuration, mainly since Keycloak can handle multiple realms while the well-known approach cannot. Hence you need to use /auth/realms/[RealmName].