Configuring Well-Known OpenID Connect Providers
This document explains how to configure well-known social OIDC and OAuth2 providers.
Introducción
If you use OpenID Connect Authorization Code Flow to protect Quarkus endpoints, then you need to configure Quarkus to tell it how to connect to OpenID Connect providers, how to authenticate to such providers, which scopes to use, and so on.
Sometimes you need to use the configuration to work around the fact that some providers do not implement OpenID Connect completely or when they are in fact OAuth2 providers only.
The configuration of such providers can become complex, very technical and difficult to understand.
quarkus.oidc.provider
configuration property has been introduced to refer to well-known OpenID Connect and OAuth2 providers. This property can be used to refer to a provider such as github
with only a minimum number of customizations required, typically, an account specific client id
, client secret
and some properties have to be set to complete the configuration.
This property can be used in application.properties
, in multi-tenant set-ups if more than one provider has to be configured (for example, see Quarkus Renarde security documentation), in custom TenantConfigResolvers if the tenant configurations are created dynamically.
Well Known Providers
Apple
In order to set up OIDC for Apple you need to create a developer account, and sign up for the 99$/year program, but you cannot test your application on localhost
like most other OIDC providers:
you will need to run it over HTTPS and make it publicly accessible, so for development purposes
you may want to use a service such as https://ngrok.com.
Go to Create a new identifier and press +
data:image/s3,"s3://crabby-images/dffb5/dffb5688e8fae5828ec3fca8f2225060a2c09a77" alt="oidc apple 1"
Don’t touch anything, keep App IDs
selected, and press Continue
:
data:image/s3,"s3://crabby-images/da3bb/da3bb38bf6ee73fdf8c0337250ea49cd6a788375" alt="oidc apple 2"
Don’t touch anything, keep App
selected, and press Continue
:
data:image/s3,"s3://crabby-images/eeb8a/eeb8a8db233293d1e0b86e0acd64a835da06b144" alt="oidc apple 3"
Enter a description and a Bundle ID (use your application package name):
data:image/s3,"s3://crabby-images/73383/73383cc99fec56db8a76fae9c1abeb9650b9efb4" alt="oidc apple 4"
Then scroll down to find the Sign in with Apple
Capability, select it, and press Continue
:
data:image/s3,"s3://crabby-images/0dc81/0dc815aeddd55b4741609497bcf9a5dc3107079a" alt="oidc apple 5"
Write down your App ID Prefix, then press Register
:
data:image/s3,"s3://crabby-images/8657a/8657abae0ac04ea7137f55ad716435c8d2413a2d" alt="oidc apple 6"
Back on the Identifiers
page, press +
:
data:image/s3,"s3://crabby-images/ce02e/ce02e6b54dea5ad04511457b18a7cb832267eee3" alt="oidc apple 7"
Select Service IDs
and press Continue
:
data:image/s3,"s3://crabby-images/b4964/b4964b6468f5c09cbd9015d1502d3f0200a0e138" alt="oidc apple 8"
Enter a description and Bundle ID (use your application package name), then press Continue
:
data:image/s3,"s3://crabby-images/b03b4/b03b457b1f0b458b62377b0ac9e71e507ddea61e" alt="oidc apple 9"
Now press Register
:
data:image/s3,"s3://crabby-images/4cb40/4cb408123dd072313b5630c24ae09fd5e258f06f" alt="oidc apple 10"
Back on the service list, click on your newly created service:
data:image/s3,"s3://crabby-images/b92ce/b92cee9aaff82e6f9aaad31459ec168b8648fbd6" alt="oidc apple 11"
Enable Sign in with Apple
and press Configure
:
data:image/s3,"s3://crabby-images/72e61/72e6132bef99d9e85baca3a242954716643135ea" alt="oidc apple 12"
Add your domain and return URL (set to <host>/apple
) and press Next
:
data:image/s3,"s3://crabby-images/bb0c9/bb0c9e813a87e7fbed389af110e88c94ecb0ba81" alt="oidc apple 13"
Now press Done
:
data:image/s3,"s3://crabby-images/581a3/581a31254618289ecd013e65dc78f69cb0e099de" alt="oidc apple 14"
Now press Continue
:
data:image/s3,"s3://crabby-images/43b16/43b1612794f80bc08741028ea9f4f2513a4eb594" alt="oidc apple 15"
And now press Save
:
data:image/s3,"s3://crabby-images/2039e/2039e2398e0a2868b4378a99400aade82461da0c" alt="oidc apple 16"
Go to the Keys page on the left menu, and press +
:
data:image/s3,"s3://crabby-images/eb646/eb646d5eabba92f7031c4fbb0ac8e3d8ae98cb1a" alt="oidc apple 17"
Fill in a key name, enable Sign in with Apple
, and press Configure
:
data:image/s3,"s3://crabby-images/66280/66280ea3e1a6705249485861d3b17f542b645fed" alt="oidc apple 18"
Select your Primary App ID and press Save
:
data:image/s3,"s3://crabby-images/add23/add23d03783c3770dfb48cc680a6d22e2f12a656" alt="oidc apple 19"
Back on the key page, press Continue
:
data:image/s3,"s3://crabby-images/60c56/60c56cef038c3799f35ee5d8cab4fc2b21d96758" alt="oidc apple 20"
Now press Register
:
data:image/s3,"s3://crabby-images/72578/72578c1b276610b0cebaf217fc173f44781bcb13" alt="oidc apple 21"
Write down your Key ID
, download your key and save it to your Quarkus application in src/main/resources/AuthKey_<KEYID>.p8
:
data:image/s3,"s3://crabby-images/5c9a2/5c9a2e22ef24c7516fcc65e8ddd20af401e17640" alt="oidc apple 22"
You can now configure your application.properties
:
quarkus.oidc.provider=apple
quarkus.oidc.client-id=<Bundle ID>
quarkus.oidc.credentials.jwt.key-file=AuthKey_<Key ID>.p8
quarkus.oidc.credentials.jwt.token-key-id=<Key ID>
quarkus.oidc.credentials.jwt.issuer=<App ID Prefix>
quarkus.oidc.credentials.jwt.subject=<Bundle ID}
quarkus.oidc.provider=apple
will request Apple to add openid
, email
and name
scopes to issued access tokens. For information about overriding these scopes or requesting more scopes, see the Provider scopes section.
Discord
Create a Discord application:
data:image/s3,"s3://crabby-images/f76aa/f76aaba7cc5c56bda02164322d9c46f8b8b0b8f1" alt="oidc discord 1"
You now can get your client id and secret:
data:image/s3,"s3://crabby-images/cb4a6/cb4a63f2e80210c29cf25808e9d720b715f741d5" alt="oidc discord 2"
You can now configure your application.properties
:
quarkus.oidc.provider=discord
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.client-secret=<Client Secret>
Facebook you will not be let you test your application on localhost
like most other OIDC providers:
you will need to run it over HTTPS and make it publicly accessible, so for development purposes
you may want to use a service such as https://ngrok.com.
In order to set up OIDC for Facebook start by Creating an application, select Other
as an app type, and click Next
.
data:image/s3,"s3://crabby-images/396a9/396a9fc2d4f1816fede88b4defb49e2108f7d3c4" alt="oidc facebook 1"
Now choose your application type. For this guide choose Consumer
and click Next
until you reach the screen below. Now enter an application name, and contact email, and press Create app
:
data:image/s3,"s3://crabby-images/3a281/3a281be200a457566ba7a96e5251d19fdbb7999d" alt="oidc facebook 2"
On the app page, click Set up
on the Facebook login
product:
data:image/s3,"s3://crabby-images/81ba7/81ba7fe9640d2fcf09fed77c0880b247e4ce5399" alt="oidc facebook 3"
On the Quickstart
page click on Facebook login > Settings
on the left menu:
data:image/s3,"s3://crabby-images/7d166/7d1662aa6dcfbc473ac4c6413b76a3b4f3362754" alt="oidc facebook 4"
First click on Get Advanced Access
to switch public_profile
to advanced access.
Then enter your Redirect URIs
(set to <host>/facebook
) and press Save changes
:
data:image/s3,"s3://crabby-images/fd200/fd20093a2346a4da4631ed28be4085f419f3b265" alt="oidc facebook 5"
Now go to Settings > Basic
on the left-hand menu, and write down your App ID
and App secret
:
data:image/s3,"s3://crabby-images/cb42e/cb42e6432dcdc949bd8bceec9d8f667dcfb0f6e6" alt="oidc facebook 6"
You can now configure your application.properties
:
quarkus.oidc.provider=facebook
quarkus.oidc.client-id=<App ID>
quarkus.oidc.credentials.secret=<App secret>
quarkus.oidc.provider=facebook
will request Facebook to add email
and public_profile
scopes to issued access tokens. For information about overriding these scopes or requesting more scopes, see the Provider scopes section.
GitHub
In order to set up OIDC for GitHub you need to create a new OAuth application in your GitHub developer settings:
data:image/s3,"s3://crabby-images/86caf/86caf0d25f2c05a9ccbb7fdb672a63a06a398d90" alt="oidc github 1"
Make sure to fill in the appropriate details, but more importantly the Authorization Callback URL, set to http://localhost:8080/github
(if you intend to test this using the Quarkus dev mode).
Now click on Register application
and you’ll be shown your application page:
data:image/s3,"s3://crabby-images/c5573/c55735ef660926625f151682c45307d5d376ec97" alt="oidc github 2"
You need to click on Generate a new client secret
, confirm your credentials, and write down
your Client ID and Client secret (especially that one, because you will not be able to see it again
later from that page, but you can always recreate one, do don’t worry too much):
data:image/s3,"s3://crabby-images/cc370/cc37059389015db22fd46d25acc1998de8513098" alt="oidc github 3"
Now add the following configuration to your application.properties
:
quarkus.oidc.provider=github
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.secret=<Secret>
quarkus.oidc.provider=github
will request GitHub to add a user:email
scope to issued access tokens. For information about overriding this scope or requesting more scopes, see the Provider scopes section.
You can also send access tokens issued by GitHub to quarkus.oidc.application-type=service or quarkus.oidc.application-type=hybrid Quarkus applications.
|
In order to set up OIDC for Google you need to create a new project in your Google Cloud Platform console:
Pick a project name and click on CREATE
.
data:image/s3,"s3://crabby-images/365c8/365c8e654607218c6e060281354e298f6fc01c40" alt="oidc google 1"
Now make sure you select your project in the top selector, and click on the left-hand bar menu on APIs and Services > OAuth consent screen
:
data:image/s3,"s3://crabby-images/73e1b/73e1bf83539fc7cfbd667230a5d27d9f19c964fd" alt="oidc google 2"
Select External
to authorise any Google user to log in to your application and press CREATE
:
data:image/s3,"s3://crabby-images/d1257/d12579aa14c14ba3c74f2550e06c245904017c90" alt="oidc google 3"
Now you can fill in your application name, your support email, your developer contact information and press SAVE AND CONTINUE
:
data:image/s3,"s3://crabby-images/48c46/48c464fe65c95ea4d7a3e033f8ef35ff545dd9ce" alt="oidc google 4"
Do not add any scopes on the next page, and press SAVE AND CONTINUE
:
data:image/s3,"s3://crabby-images/16fa5/16fa5f890eef58164d4d1449f2e24bb20197f87b" alt="oidc google 5"
Do not add any test user on the next page, and press SAVE AND CONTINUE
:
data:image/s3,"s3://crabby-images/33ef6/33ef61821e559dd616305e72a6f945936e0a966c" alt="oidc google 6"
Click on the top menu CREATE CREDENTIALS
> OAuth client ID
:
data:image/s3,"s3://crabby-images/e9f9c/e9f9c1c42a53e4db4d7a80da120bc66ffeffd4c9" alt="oidc google 7"
Select Web application
as Application type
, and add http://localhost:8080/google
in
the Authorised redirect URIs
list, then press CREATE
:
data:image/s3,"s3://crabby-images/baba5/baba58f16c358b84f5524cfa130d274219ce9a8a" alt="oidc google 8"
Copy your Client ID and Client Secret:
data:image/s3,"s3://crabby-images/5b531/5b531d809c5db6a58b7828a156fa0d235e13078b" alt="oidc google 9"
You can now configure your application.properties
:
quarkus.oidc.provider=google
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.secret=<Secret>
quarkus.oidc.provider=google
will request Google to add openid
, email
and profile
scopes to issued access tokens. For information about overriding these scopes or requesting more scopes, see the Provider scopes section.
You can also send access tokens issued by Google to quarkus.oidc.application-type=service or quarkus.oidc.application-type=hybrid Quarkus applications.
|
Create a LinkedIn application:
data:image/s3,"s3://crabby-images/efbbb/efbbb63828af6dde18e65b23b05da79a99581219" alt="oidc linkedin 1"
Add the Sign In with LinkedIn using OpenId Connect
product:
data:image/s3,"s3://crabby-images/f65c1/f65c1ee11d89650f3244fd59b850c45bf88cc717" alt="oidc linkedin 2"
You now can get your client id and secret. Don’t forget to also add the authorized redirect URLs for your application:
data:image/s3,"s3://crabby-images/1562f/1562f4ad5b8370f6d089d70d81993bade5365c34" alt="oidc linkedin 3"
You can now configure your application.properties
:
quarkus.oidc.provider=linkedin
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.client-secret=<Client Secret>
Mastodon
Create a Mastodon account. You must pick a server, for example, mastodon.social
.
Select a Development
option in your account and register an application, for example:
data:image/s3,"s3://crabby-images/5b487/5b487c9d74801ac7f0b776b1cabbdee8f084d335" alt="oidc mastodon register app"
Select the registered application:
data:image/s3,"s3://crabby-images/7dace/7dace1c46666ca19b53d271bf6e32c5c07895b57" alt="oidc mastodon registered apps"
and note its client id and client secret properties, use them to configure your application.properties
:
quarkus.oidc.provider=mastodon
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.client-secret.value=<Client Secret>
By default, quarkus.oidc.provider=mastodon
sets quarkus.oidc.auth-server-url
to the https://mastodon.social
Mastodon server address.
You can override quarkus.oidc.auth-server-url
if you have created your account in another Mastodon server, for example:
quarkus.oidc.provider=mastodon
quarkus.oidc.auth-server-url=https://infosec.exchange
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.client-secret.value=<Client Secret>
Microsoft
In order to set up OIDC for Microsoft you need to go to your Microsoft Azure Portal,
and search for Microsoft Entra ID
formerly known as Azure Active Directory
, then click on it:
data:image/s3,"s3://crabby-images/f0233/f02333830734a269c839a1d4fcf9787120559dea" alt="oidc microsoft 1"
Once there, on the left side under Manage
, click on App registrations
then click on New registration
:
data:image/s3,"s3://crabby-images/9213d/9213d540cdb544bf19c1cc7f31531edcf73f50c3" alt="oidc microsoft 2"
Fill in your application name, select Accounts in any organizational directory (Any Azure AD directory - Multitenant) and personal Microsoft accounts (e.g. Skype, Xbox)
to allow anyone to log in, and add a Web
Redirect URI as http://localhost:8080/microsoft
,
then click on Register
:
data:image/s3,"s3://crabby-images/c172e/c172e2214eb18d155d3cd52fec4e061d1f604651" alt="oidc microsoft 3"
On that resulting page, copy the Client Id
(under Application (client) ID
, then click on Add a certificate or secret
:
data:image/s3,"s3://crabby-images/36107/36107f6bb9521907d2d705544639799bdc1552b3" alt="oidc microsoft 4"
Now, under Client secrets (0)
, click on New client secret
:
data:image/s3,"s3://crabby-images/02630/026300b223fb09e4d19c57a31b3b4c6be10e31a5" alt="oidc microsoft 5"
Click on Add
in that dialog without changing anything:
data:image/s3,"s3://crabby-images/b8433/b843367b4aa0dd04149f1cd64bdd0b78b20f8399" alt="oidc microsoft 6"
On the resulting page, copy your Secret Value
:
data:image/s3,"s3://crabby-images/b9a3b/b9a3bd04ea951a6b56da27d5fb86fdd2fb7ab75c" alt="oidc microsoft 7"
You can now configure your application.properties
:
quarkus.oidc.provider=microsoft
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.secret=<Secret>
quarkus.oidc.provider=microsoft
will request Microsoft to add openid
, email
and profile
scopes to issued access tokens. For information about overriding these scopes or requesting more scopes, see the Provider scopes section.
You can also send access tokens issued by Microsoft to quarkus.oidc.application-type=service or quarkus.oidc.application-type=hybrid Quarkus applications but you may need to set quarkus.oidc.verify-access-token-with-user-info configuration property to true if access tokens issued by Microsoft are not in JWT format.
|
Some Microsoft services may issue tokens whose signatures can only be verified if the current token’s
|
Slack
Create a Slack application:
data:image/s3,"s3://crabby-images/2c849/2c84947c11d9a373ed197c9f4753dcd4b08d5b88" alt="oidc slack 1"
Select application name, workspace, and remember it, you will need it later:
data:image/s3,"s3://crabby-images/1add7/1add71213045189e9288de1cdf930bfa7955b015" alt="oidc slack 2"
Please save client id and secret displayed on the next page, you will need them later:
data:image/s3,"s3://crabby-images/e2eae/e2eaec5e4298cee11563aee328bd8f825ce4e884" alt="oidc slack 3"
Configure redirect URLs. Slack provider requires HTTPS protocol, for development purposes, you can use ngrok:
data:image/s3,"s3://crabby-images/5e9d6/5e9d67c9fffd8345cccfd25f4423e8de35f0c3c7" alt="oidc slack 4"
You can now configure your application.properties
:
quarkus.oidc.provider=slack
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.secret=<Client Secret>
quarkus.oidc.authentication.extra-params.team=quarkus-slack (1)
1 | Use the team parameter to refer to the workspace you chose during the Slack OIDC application registration. |
Open your browser and navigate to your application https://<your ngrok instance>.ngrok-free.app/
.
Quarkus will redirect you to Slack provider on the first request where you can grant required permissions:
data:image/s3,"s3://crabby-images/b4403/b4403c748a3074b29543c61f32a4660a7764cc9c" alt="oidc slack 5"
Spotify
Create a Spotify application:
data:image/s3,"s3://crabby-images/b9264/b9264afc36e7b47f3271bcfc64ec04cbc78fe406" alt="oidc spotify 1"
Don’t forget to add http://localhost:8080
as a redirect URI for testing during development purposes. You should get a client id and secret generated once a Spotify application setup has been complete, for example:
data:image/s3,"s3://crabby-images/31d9f/31d9f19b06c3689f5344a924e80d8c70462156ac" alt="oidc spotify 2"
You can now configure your application.properties
:
quarkus.oidc.provider=spotify
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.secret=<Client Secret>
quarkus.oidc.provider=spotify
will request Spotify to add user-read-private
and user-read-email
scopes to issued access tokens. For information about overriding these scopes or requesting more scopes, see the Provider scopes section.
Strava
Create a Strava application:
data:image/s3,"s3://crabby-images/cbe53/cbe53f0e0868c09b432a5e8fc5fe56e62462dc4f" alt="oidc strava 1"
For example, set Category
to SocialMotivation
, and set ApplicationCallbackDomain
to either localhost
or the domain name provided by Ngrok, see the HTTPS Redirect URI for more information.
You can now configure your application.properties
:
quarkus.oidc.provider=strava
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.client-secret=<Client Secret>
# default value is '/strava'
quarkus.oidc.authentication.redirect-path=/fitness/welcome (1)
1 | Strava does not enforce that the redirect (callback) URI which is provided as an authorization code flow parameter is equal to the URI registered in the Strava application because it only requires configuring ApplicationCallbackDomain . For example, if ApplicationCallbackDomain is set to www.my-strava-example.com , Strava will accept redirect URIs such as www.my-strava-example.com/a , www.my-strava-example.com/path/a , which is not recommended by OAuth2 best security practices, see Insufficient redirect_uri validation for more information.
Therefore you must configure a redirect path when working with the Strava provider and Quarkus will enforce that the current request path matches the configured quarkus.oidc.authentication.redirect-path value before completing the authorization code flow. See the Exact redirect URI match for more information. |
Twitch
Create a Twitch application:
data:image/s3,"s3://crabby-images/73707/737079456b44ec348012a554ff768ed4ecb6b881" alt="oidc twitch 1"
You can now configure your application.properties
:
quarkus.oidc.provider=twitch
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.client-secret.value=<Client Secret>
X (formerly Twitter)
You can use X (formerly Twitter) for OIDC login, but at the moment, it restricts access to the user’s email, which means you will have to obtain it and verify it yourself.
In order to set up OIDC for X, start by Creating a project, enter a project name, and press Next
:
data:image/s3,"s3://crabby-images/d6119/d61193752988f58aab441047d7eba52609f95b4f" alt="oidc twitter 1"
Enter a use case, and press Next
:
data:image/s3,"s3://crabby-images/ab538/ab53895ff834f079cbed6dd568482d068a511a8a" alt="oidc twitter 2"
Enter a project description, and press Next
:
data:image/s3,"s3://crabby-images/ef9b6/ef9b66bbf7e870f2d3dd3e1b7555c8bad5548db0" alt="oidc twitter 3"
Now enter an application name, and press Next
:
data:image/s3,"s3://crabby-images/4a447/4a447cbc3baa506443d9da9f954455c16515e52d" alt="oidc twitter 4"
Write down your keys, because they will not be displayed again, and press App Settings
:
data:image/s3,"s3://crabby-images/8944e/8944eac9570373799ab9fead5209945b5a8eb4fa" alt="oidc twitter 5"
Navigate down to the User authentication settings
section and press Set up
:
data:image/s3,"s3://crabby-images/96e78/96e781483a5de1f02892d1ed4f28181da0502330" alt="oidc twitter 6"
Check the OAuth 2.0
check box:
data:image/s3,"s3://crabby-images/76240/76240a882849c9ce858a3c70529d610c07d301c3" alt="oidc twitter 7"
Select Web App
as application type, then fill in your application details (use <host>/_renarde/security/twitter-success
for the Callback URI
).
X doesn’t require https usage in practice, but won’t accept your Website URL without it, so
you can still use ngrok for it.
|
Now press Save
:
data:image/s3,"s3://crabby-images/30626/306269f2521898c9011edc7718a22d9a9c7ce624" alt="oidc twitter 8"
You can now copy your Client ID
and Client Secret
and press Done
:
data:image/s3,"s3://crabby-images/b07e5/b07e57d898e36c03e13b41a33961007688d8c976" alt="oidc twitter 9"
You can now configure your application.properties
:
quarkus.oidc.provider=x
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.secret=<Client Secret>
quarkus.oidc.provider=x
will request X to add offline.access
, tweet.read
and users.read
scopes to issued access tokens. For information about overriding these scopes or requesting more scopes, see the Provider scopes section.
X provider requires Proof Key for Code Exchange (PKCE) which is supported by the You can provide your own secret key for encrypting the PKCE code verifier if you prefer with the |
X is the new name of Twitter. You can continue using |
Provider scopes
Each provider declaration will request one or more token scopes added to access tokens issued by a given provider. For example, quarkus.oidc.provider=google
will request Google
to add openid
, email
and profile
scopes.
You can override these scopes with quarkus.oidc.authentication.scopes
property, for example, if you work with Google
and would not like to have an email
scope added to access tokens:
quarkus.oidc.provider=google
quarkus.oidc.authentication.scopes=oidc,profile
You may also want to add one or more scopes in addition to the scopes requested by default. For example, if you would like to use an access token issued by Google
to access Google Calendar
service, you can do it like this:
quarkus.oidc.provider=google
quarkus.oidc.authentication.extra-params.scope=https://www.googleapis.com/auth/calendar
It is simpler than using quarkus.oidc.authentication.scopes
to add a new scope, because quarkus.oidc.authentication.scopes
overrides the scopes already set by the provider declaration, which is why you need to list all the required scopes in this case:
quarkus.oidc.provider=google
quarkus.oidc.authentication.scopes=oidc,email,profile,https://www.googleapis.com/auth/calendar
Support for multiple providers
If you would like to support authenticating users with more than one provider then a provider-specific tenant configuration resolution must be supported.
For more information, see the Quarkus Using OpenID Connect (OIDC) Multi-Tenancy guide.
Access provider services with token propagation
Sometimes, only authenticating users with a social provider is not enough.
A provider-specific service also needs to be accessed for the Quarkus OIDC web-app
application to fetch or update data from the provider service on behalf of the currently authenticated user.
As mentioned in the OIDC code flow mechanism for protecting web applications guide, ID and access tokens are returned after the authorization code flow has been completed, with some providers like GitHub
returning an access token only.
It is this access token that has to be propagated to services such as Google Calendar
, or Spotify Playlists
for the currently authenticated user to be able to use such services.
You do not have to bring provider-specific libraries in order to achieve this, but instead you can use a reactive Token Propagation
filter, which can be bound to a given REST client with a simple annotation.
For more information, see the Quarkus Access token propagation guide.
For example, after you have configured the Google provider, you can have events added to the user’s Google Calendar by using a REST client as shown in the following example:
package org.acme.calendar;
import org.eclipse.microprofile.rest.client.inject.RegisterRestClient;
import io.quarkus.oidc.token.propagation.AccessToken;
import io.smallrye.mutiny.Uni;
import jakarta.ws.rs.Consumes;
import jakarta.ws.rs.POST;
import jakarta.ws.rs.Path;
import jakarta.ws.rs.Produces;
import jakarta.ws.rs.core.MediaType;
@RegisterRestClient(configKey="google-calendar-api")
@AccessToken (1)
@Path("/calendars/primary")
public interface GoogleCalendarClient {
@POST
@Path("events")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
Uni<String> addEvent(Event event);
public static class Event {
public String summary;
public String kind = "calendar#event";
public Time start;
public Time end
}
public static class Time {
public String dateTime;
public String timeZone = "Europe/CET";
public Time() {
}
public Time(String value) {
dateTime = value;
}
}
}
1 | The @AccessToken annotation enables an access token propagation to the target service. |
Finally, you need to configure the Google Calendar address and request the Google Calendar scope for an access token, as outlined in the following example:
quarkus.oidc.provider=google
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.secret=<Secret>
# Add a required calendar scope
quarkus.oidc.authentication.extra-params.scope=https://www.googleapis.com/auth/calendar
# Point REST client to Google Calendar endpoint
quarkus.rest-client.google-calendar-api.url=https://www.googleapis.com/calendar/v3
Now you are ready to have users authenticated with Google and support updating their Google
calendars on their behalf, for example:
package org.acme.calendar;
import org.eclipse.microprofile.jwt.JsonWebToken;
import org.eclipse.microprofile.rest.client.inject.RestClient;
import io.quarkus.oidc.IdToken;
import io.quarkus.security.Authenticated;
import io.smallrye.mutiny.Uni;
import jakarta.inject.Inject;
import jakarta.ws.rs.GET;
import jakarta.ws.rs.Path;
import jakarta.ws.rs.Produces;
@Path("/calendar")
@Authenticated
public class CalendarService {
@Inject
@IdToken
JsonWebToken jwt;
@Inject
@RestClient
GoogleCalendarClient calendarClient;
@GET
@Path("/event")
@Produces("text/plain")
public Uni<String> get() {
return calendarClient.addEvent(new Event()).onItem()
.transform(c -> ("Hello " + jwt.getName() + ", new event: " + c));
}
}
You must update the application registered with the Google provider to list http://localhost:8080/calendar/event
as one of the authorized redirect URIs if you would like to test this endpoint on the local host, for example:
data:image/s3,"s3://crabby-images/11f32/11f323133e592f9eda05e5d28a9f393bfa354d52" alt="oidc google authorized redirects"
You might also have to register one or more test users:
data:image/s3,"s3://crabby-images/e2571/e2571d14dbd1922e1d5ebf29f87a8fc16dc0b4fa" alt="oidc google test users"
Follow the same approach if the endpoint must access other Google services.
The pattern of authenticating with a given provider, where the endpoint uses either an ID token or UserInfo (especially if an OAuth2-only provider such as GitHub
is used) to get some information about the currently authenticated user and using an access token to access some downstream services (provider or application specific ones) on behalf of this user can be universally applied, irrespectively of which provider is used to secure the application.
Exact redirect URI match
Most OIDC and OAuth2 providers with the exception of Strava will enforce that the authorization code flow can be completed only if the redirect URI matches precisely the redirect URI configured in a given provider’s dashboard.
From the practical point of view, your Quarkus endpoint will most likely need to have the quarkus.oidc.authentication.redirect-path
relative path property set to an initial entry path for all the authenticated users, for example, quarkus.oidc.authentication.redirect-path=/authenticated
, which means that newly authenticated users will land on the /authenticated
page, irrespectively of how many secured entry points your application has and which secured resource they initially accessed.
It is a typical flow for many OIDC web-app
applications. Once the user lands on the initial secured page, your application can return an HTML page which uses links to guide users to other parts of the application or users can be immediately redirected to other application resources with the help of JAX-RS API.
If necessary, you can configure Quarkus to restore the original request URI after the authentication has been completed. For example:
quarkus.oidc.provider=strava (1)
quarkus.oidc.client-id=<Client ID>
quarkus.oidc.credentials.secret=<Secret>
quarkus.oidc.authentication.restore-path-after-redirect=true (2)
1 | strava provider configuration is the only supported configuration which enforces the quarkus.oidc.authentication.redirect-path property with the /strava path which you can override with another path such as /fitness . |
2 | If the users access the /run endpoint before the authentication, then, once they have authenticated and been redirected to the configured redirect path such as /strava , they will land on the original request /run path. |
You do not have to set quarkus.oidc.authentication.redirect-path
immediately because Quarkus assumes the current request URL is an authorization code flow redirect URL if no quarkus.oidc.authentication.redirect-path
is configured. For example, to test that a Google authentication is working, you can have a Quarkus endpoint listening on /google
and update the Google dashboard that http://localhost:8080/google
redirect URI is supported. Setting quarkus.oidc.authentication.redirect-path
property will be required once your secured application URL space grows.
HTTPS Redirect URI
Some providers will only accept HTTPS-based redirect URIs. Tools such as ngrok can be set up to help testing such providers with Quarkus endpoints running on localhost in dev mode.
Rate Limiting
Depending on your developer API subscription level, some providers may enforce a rather strict request rate limiting policy.
It may not be a problem when Quarkus fetches public verification keys from OIDC-compliant providers like the Google provider and keeps verifying the user session with these keys locally. However, for pure OAuth2 providers where only an access token is available and which has to be verified indirectly by requesting UserInfo from the provider endpoint on every request done by an already authenticated user, it can become a problem.
Therefore, UserInfo is embedded in an internally generated ID token and is encrypted in the session cookie. You can disable it with quarkus.oidc.cache-user-info-in-idtoken=false
.
Alternatively, use a default or custom UserInfo cache provider, please see the Token Introspection and UserInfo cache section of the "OpenID Connect (OIDC) Bearer token authentication" guide.