System Provider
Blazing KRaft gives you the ability to register OpenID Connect Providers directly from the UI, or register a System Default OIDC Provider by injecting the following ENV variables:
BLAZINGKRAFT_OIDC_PROVIDER_CODE: internalProvider # Required
BLAZINGKRAFT_OIDC_PROVIDER_NAME: Internal Provider # Optional (default: $code)
BLAZINGKRAFT_OIDC_PROVIDER_ISSUER: http://keycloak_fqdn/auth/realms/blazingkraft # Required
BLAZINGKRAFT_OIDC_PROVIDER_CLIENT_ID: ui # Required
BLAZINGKRAFT_OIDC_PROVIDER_CLIENT_SECTET: secret # Optional
BLAZINGKRAFT_OIDC_PROVIDER_PKCE_ENABLED: true # Optional (default: false)
BLAZINGKRAFT_OIDC_PROVIDER_PROVIDER_TYPE: Keycloak # Optional
BLAZINGKRAFT_OIDC_PROVIDER_SCOPES: openid;;;offline_access;;;profile;;;email;;;address;;;phone # Optional (default: openid;;;offline_access)
Auth0
Auth0 is a cloud service that provides a set of unified APIs and tools that instantly enable single sign-on and user management for all of your applications.
Create an application and grab the basic configuration and register the callback url
to {blazingkraft_base_url}/login/callback/{oidc_provider_code}
, then head to Blazing KRaft and register the provider.
Auth0 Basic Configuration
data:image/s3,"s3://crabby-images/9445c/9445cf22973f367f1de0d45e4a2a23dc926b76ae" alt="Auth0 Basic Configuration Image"
data:image/s3,"s3://crabby-images/128a0/128a0eb97244acb42b71fd3b7407b07cb03a4494" alt="Auth0 Basic Configuration Image"
Auth0 Basic Configuration
data:image/s3,"s3://crabby-images/01056/010562e398cb9de8de21844d2691eea80b42ec0a" alt="Auth0 Callback Url Image"
data:image/s3,"s3://crabby-images/254dd/254dd9776d858089ea9b945c8620498a91a11842" alt="Auth0 Callback Url Image"
Blazing KRaft Auth0
data:image/s3,"s3://crabby-images/ffffc/ffffc10abe2f95c8814a286ee944f952bd079223" alt="Blazing KRaft Auth0 Image"
data:image/s3,"s3://crabby-images/8a239/8a239124ba1aafa8269a3fef67a01cbb24e018e7" alt="Blazing KRaft Auth0 Image"
Keycloak
Keycloak is an open source software product that allows single sign-on with identity and access management aimed at modern applications and services.
Create a realm, a client, and a user and then grab the basic configuration and register the callback url
to {blazingkraft_base_url}/login/callback/{oidc_provider_code}
, then head to Blazing KRaft and register the provider.
Keycloak Create Realm
data:image/s3,"s3://crabby-images/212aa/212aa8978a105637f969d6790229255cc1977833" alt="Keycloak Create Realm Image"
Keycloak Create Client
data:image/s3,"s3://crabby-images/64070/640708434c5c2a5053f23f44e70c3678f78eaa21" alt="Keycloak Create Client Image"
Keycloak Create User
data:image/s3,"s3://crabby-images/e51b6/e51b668a1fa3d48bd689fe7affbc942173d5224a" alt="Keycloak Create User Image"
Blazing KRaft Keycloak
data:image/s3,"s3://crabby-images/e3521/e352174e1b0374fb3234a55706ee9e9260cc6f4e" alt="Blazing KRaft Keycloak Image"
data:image/s3,"s3://crabby-images/f28b3/f28b323586cbe3ee7499c12ee78edfe62a03f832" alt="Blazing KRaft Keycloak Image"
OIDC Providers Listing
After registring OIDC Providers, you can view them in the listing page.
data:image/s3,"s3://crabby-images/740d4/740d4862e391c65ff587e3f716faf582a7f6e994" alt="OIDC Providers Listing Image"
data:image/s3,"s3://crabby-images/cfbd4/cfbd43e1505d60ebb4f3c7f9bd509d060ae7d61a" alt="OIDC Providers Listing Image"
OIDC Providers Actions
You can delete, edit, and view the details of the OIDC Provider.
Delete OIDC Provider
data:image/s3,"s3://crabby-images/e6b5d/e6b5da72d18609ece5ed1af98e2f9fd011fdc837" alt="OIDC Providers Delete Image"
data:image/s3,"s3://crabby-images/dd4ab/dd4ab8f3d4fe9034588fc9ded48e58afaf884003" alt="OIDC Providers Delete Image"
Edit OIDC Provider
data:image/s3,"s3://crabby-images/16fee/16fee0f433abba511b4f43dc30e6eb6cfc61dc04" alt="OIDC Providers Edit Image"
data:image/s3,"s3://crabby-images/5739b/5739b1fdbb0d1e7fe1fb77ed460ff1c77b6fd4ca" alt="OIDC Providers Edit Image"
OIDC Provider Details
data:image/s3,"s3://crabby-images/bd05d/bd05de37370a99a93422ef368e89f19648372105" alt="OIDC Providers Details Image"
data:image/s3,"s3://crabby-images/9171a/9171a6c92c40f298a027239a90ddfe42bc591140" alt="OIDC Providers Details Image"
OIDC Provider Well Known Configuration
data:image/s3,"s3://crabby-images/61d80/61d806afc564bc3d2241719768c2af50121be3e4" alt="OIDC Providers Well Known Configuration"
data:image/s3,"s3://crabby-images/b3075/b3075af8a475cdbf0925b1875fa9f65fa8290deb" alt="OIDC Providers Well Known Configuration"
Custom Claim
If the idToken issued by the OIDC Provider doesn't contain the blazingkraft_group
,
the connected user will only be restricted by the server permissions.
To create a custom claim in Keycloak, you should add an attribute to the user and create a mapper to add it to the idToken.
Keycloak Attribute
data:image/s3,"s3://crabby-images/d6335/d633544e68eb41dd15fee3d061c39f2ab340a52e" alt="Keycloak Add Attribute Image"
Keycloak Create Protocol Mapper
data:image/s3,"s3://crabby-images/fe0c4/fe0c41306bccea81babf12aa09b3beccd7fe21b1" alt="Keycloak Create Protocol Mapper Image"
ID Token
{
"exp": 1686656138,
"iat": 1686655838,
"auth_time": 1686655832,
"jti": "bc2d72f0-78dd-484d-9172-36d439b4688b",
"iss": "http://localhost:9010/auth/realms/blazingkraft",
"aud": "blazingkraft",
"sub": "57e166ae-1670-42ef-9006-75a080c083b5",
"typ": "ID",
"azp": "blazingkraft",
"session_state": "28179e4c-0828-4575-a4b3-2031d6828268",
"at_hash": "2MyfN2PiciCkzwuuuo7rXA",
"acr": "1",
"sid": "28179e4c-0828-4575-a4b3-2031d6828268",
"email_verified": false,
"preferred_username": "blazingkraft",
"given_name": "",
"blazingkraft_group": "qaTeam",
"email": "blazingkraft@gmail.com"
}
OIDC Provider Login
You can now use your registered providers and login using them.
data:image/s3,"s3://crabby-images/4805f/4805f7bbabad821418d0e68821c7ea5194be3228" alt="OIDC Provider Login Page Image"
data:image/s3,"s3://crabby-images/e6d68/e6d68f0e261763c93fcec1c791fed55d7d034b23" alt="OIDC Provider Login Page Image"
Miscellaneous
When registering OIDC Providers for the first time, if you made a configuration mistake, in some rare cases you might need to clear the session storage on your browser before retrying to login with a provider.
Session Storage
If when logging in with a provider you get a no token provided error,
its most likely because of a configuration mistake.
Make sure that the registered issuer is exactly the same as the one provided in the idToken,
for example the Auth0 domain doesn't contain the trailing slash '/',
but the issuer in the idToken does. Blazing KRaft performs a strict comparison of the issuer contained in the
token and the one you've registered. Therefore, for Blazing KRaft its a InsufficientAuthenticationException
which results in a no token provided error.
These decisions are made on purpose for security reasons, I highly recommend that you always check the logs for more information as the Blazing KRaft provides nicely formatted log entries.
data:image/s3,"s3://crabby-images/88624/8862418bbe45a2facd7dbfb81c1a5a7404daeda8" alt="OIDC Provider Clear Session Storage Image"
data:image/s3,"s3://crabby-images/9a4e8/9a4e8ad5370cb91146b56e78c88293c9c75cf2da" alt="OIDC Provider Logs Image"
Important
For blazingly fast token validation, Blazing KRaft stores OIDC Providers in memory.
For this reason the providers are only invalidated on a single instance, if you have scaled to more than one instance of Blazing KRaft, you'll need to restart them after creating, editing or deleting any OICD Provider.