Skip to content

consiglionazionaledellericerche/usermapper

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

UsernMapper

implement a Cnr UserMapper

META-INF/services File with the name org.keycloak.protocol.ProtocolMapper must be available and contains the name of mapper

jboss-deployment-structure.xml need to be available to use keycloak built in classes

Jar File is deployed in /opt/jboss/keycloak/standalone/deployments/

custom Mapper use POM.xml and resolve dependencies Extend AbstractOIDCProtocolMapper and need to implement all abstract methods. If want to have a SAML Protocol Mapper then it's another base class (AbstractSAMLProtocolMapper) one relevant method is transformAccessToken -can implement logic here.

Services File The services File is important for keycloak to find the custom-Implementation. Place a file with the fileName org.keycloak.protocol.ProtocolMapper inside \src\main\resources\META-INF\services\

Inside this file write to Name of your custom Provider - then keycloak knows that this class is available as Protocol Mapper can add multiple file names

it.cnr.si.UserMapper

Deployment Structure XML In custom mapper use files from keycloak. In order to use them it's needed to inform jboss about this dependency. Therefore create a file jboss-deployment-structure.xml inside \src\main\resources\META-INF\ Content:

Build and deploy your Extension Build a jar File of the Extension (mvn clean package) - and place the jar in /opt/jboss/keycloak/standalone/deployments/ and restart keycloak

create a Mapper in keycloak admin ui and select getDisplayType given in the code


Login LDAP:

  • username_cnr: OK
  • username_spid: null

Login SPID 1:

  • username_cnr: OK
  • username_spid: OK

Login SPID 2:

  • username_cnr: null
  • username_spid: OK

About

Keycloak CNR UserMapper

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages