This lib provides a pedestal interceptor for decoding OIDC tokens, utilities for retrieving and unsigning (inspired by clj-jwt) and for performing simple OIDC discovery.
See the demo for a simple example of usage.
Give com.yetanalytics.pedestal-oidc.interceptor/decode-interceptor
a "get-keyset" function that returns either:
- a map of JWKS key IDs to the keys themselves.
- a function that takes such an ID and (maybe) returns a key. This may be useful if you need to maintain a cache.
Use the resulting interceptor in a pedestal route. Decoded claims will be placed on the request at :com.yetanalytics.pedestal-oidc/claims
.
By default the decode-interceptor
will respond to any failure with a 401. You can customize this behavior by providing a :unauthorized
keyword arg which is a function that will recieve the pedestal context, a failure keyword and possibly an exception. The possible failure keywords are:
:header-missing
- TheAuthorization
header (or whatever is provided forcheck-header
) is not present. No exception.:header-invalid
- The header does not start withBearer
. No exception.:kid-not-found
- The indicated public key is not found by ID. An exception is passed with ex-data containing the:kid
:validation
- The token failed unsigning withbuddy-sign
. The provided exception contains the:cause
in its ex-data.:keyset-invalid
- The keyset function failed to return a map or function.:keyset-error
- (sync only) the keyset function threw an unhandled error.:unknown
- An unknown exception was thrown. See the provided exception for more info.
The default :unauthorized
function will add the failure keyword to the context as :com.yetanalytics.pedestal-oidc/failure
. By default exceptions will not be retained.
com.yetanalytics.pedestal-oidc.jwt/get-keyset
will attempt to fetch a valid keyset from the given jwks-uri
. How this is stored/cached is up to the lib consumer.
com.yetanalytics.pedestal-oidc.discovery
provides facilities for pulling config metadata (like the jwks_uri
) from the IDP per the spec.
To run a demo instance of keycloak:
make keycloak-demo
This will host a JWKS uri of http://0.0.0.0:8080/auth/realms/test/protocol/openid-connect/certs with the realm's public keyset.
You can then run the demo API:
make run-dev
Run the test suite:
make test
Copyright © 2022 Yet Analytics Inc.
Distributed under the Apache License version 2.0.