An Authentication Service Provider that adds the possibility for Keycloak to connect via a user attribute.
If the username entered in the form
- does not match a primary identifier
- does not match email (if this option is enabled for realm)
- respect the desired regular expression
Then the search by attribute is activated
- if this search returns a single user, password verification is activated
Just drop the jar into the /opt/keycloak subdirectory of your Keycloak installation.
For example, you can add this snippet in a Dockerfile
WORKDIR /opt/keycloak
# plugins
ADD --chown=keycloak:keycloak https://repo1.maven.org/maven2/fr/cnieg/keycloak/attribute-login-provider/$PLUGIN_VERSION/attribute-login-provider-$PLUGIN_VERSION.jar providers/attribute-login-provider-$PLUGIN_VERSION.jar
Make sure that you have correctly configured an attribute for your users which can be used as an identifier alternative.
Switch to your realm in the keycloak administration console.
Switch to the "Authentication" configuration and copy the original browser flow, giving the copy it a reasonable name, maybe "Browser with Attribute".
Then replace the "Username Password Form" execution by the new "Attribute Username Password Form" execution.
Configure this new step with your attribute name and choose a regex which can restrict calls and avoid expensives searches by attribute.
Having done so you have to select your copy of the browser in the bindings tab for the browser flow.
Like the Keycloak Login Attribute SPI, AttributeChooseUser adds the possibility for Keycloak to reset credentials via a user attribute.
Make sure that you have correctly configured an attribute for your users which can be used as an identifier alternative.
Switch to your realm in the keycloak administration console.
Switch to the "Authentication" configuration and copy the original reset credential flow, giving the copy it a reasonable name, maybe "Reset Credential with Attribute".
Then replace the "Choose User" execution by the new "Attribute Choose User" execution.
Configure this new step with your attribute name and choose a regex which can restrict calls and avoid expensives searches by attribute.
Having done so you have to select your copy of the browser in the bindings tab for the browser flow.
See LICENSE file