Keycloak
Learn how to integrate MFA using Authsignal with Keycloak.
Overview
Keycloak is an open-source identity and access management solution that offers a wide range of authentication capabilities. These capabilities can be extended and tailored to specific project requirements using custom providers, which act as modular extensions to Keycloak’s core functionality. In this guide, we will demonstrate how to leverage a Keycloak provider to seamlessly integrate MFA into a traditional username and password login flow using Authsignal’s pre-built UI, enhancing security with minimal disruption to the user experience.
MFA challenge via Authsignal pre-built UI.
Code example
You can find the Keycloak provider code example referenced in this guide on GitHub. For advanced situations, you can modify the provider to meet your specific requirements. However, this provider will work for most use cases.
Authsignal configuration
Enabling authenticators
For the purposes of this example, we have enabled the Authenticator App on our tenant in the Authsignal Portal.
Configuring authenticators
API keys & API URL
We also need to get the API keys and API URL for our tenant from the Authsignal Portal.
Retrieving API keys
We will use the secret and the API URL/API Host in the next section.
Keycloak configuration
Creating a new provider
- Download the pre-built “authsignal-keycloak-*.jar” JAR file. Alternatively, you can build the JAR file yourself using the GitHub repository.
- Download the Authsignal (version 2.0+) Java SDK (dependency) JAR file from Maven.
- Copy the above two JAR files to your Keycloak server
/providers/
directory.
Configuring the Authsignal Authentication flow
After installing the provider JAR files, you’ll need to configure Keycloak to use Authsignal for MFA. This section walks through setting up a custom authentication flow that incorporates the Authsignal Authenticator.
To configure the authentication flow:
- Access your Keycloak Admin panel.
- Navigate to your project’s Realm, and then to the ‘Authentication’ section.
- Select the ‘browser’ flow.
Accessing the browser flow
- Create a copy of this flow using the ‘Action’ dropdown in the top-right.
Creating a copy of the browser flow
- In your new copied flow, remove the existing ‘Conditional OTP’ authentication step.
Removing the existing Conditional OTP step
- Add the Authsignal provider to the flow.
Inside the subflow which already contains the ‘Username Password Form’, we need to add the Authsignal provider as a step.
Adding the Authsignal provider step
- Select the Authsignal Authenticator.
If you successfully added the Authsignal .JAR files to the /providers/
folder in the previous steps, you will see the Authsignal Authenticator listed in the menu - select it to add it to your flow.
Adding the Authsignal provider step
After adding the Authsignal Authenticator step
- Ensure that the Authsignal Authenticator step is required.
Ensuring the Authsignal Authenticator step is required
- Click the settings cog on the Authsignal Authenticator step. Add your API keys and API URL from the Authsignal Portal.
Configuring the Authsignal Authenticator
When Enroll by default
is toggled on, users will be prompted to enroll in an authenticator when they first login.
If toggled off, the user will not be prompted to enroll an authenticator, and you will need to handle enrollment
programmatically.
Conclusion
That’s it! You’ve successfully added MFA by integrating Keycloak with Authsignal. You can now test the flow by logging in - you will be prompted to enroll in an authenticator. The next time you log in, you will be prompted to complete the MFA challenge.
Was this page helpful?