keycloak
公開メンバ関数 | 静的公開メンバ関数 | 静的公開変数類 | 限定公開メンバ関数 | 静的限定公開変数類 | 静的関数 | 静的非公開メンバ関数 | 全メンバ一覧
org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory クラス
org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory の継承関係図
Inheritance graph
org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory 連携図
Collaboration graph

公開メンバ関数

void onParentUpdate (RealmModel realm, UserStorageProviderModel oldParent, UserStorageProviderModel newParent, ComponentModel mapperModel)
 
void onCreate (KeycloakSession session, RealmModel realm, ComponentModel model)
 
void onUpdate (KeycloakSession session, RealmModel realm, ComponentModel oldModel, ComponentModel newModel)
 
String getHelpText ()
 
List< ProviderConfigPropertygetConfigProperties ()
 
List< ProviderConfigPropertygetConfigProperties (RealmModel realm, ComponentModel parent)
 
String getId ()
 
Map< String, Object > getTypeMetadata ()
 
void validateConfiguration (KeycloakSession session, RealmModel realm, ComponentModel config) throws ComponentValidationException
 
void init (Config.Scope config)
 
LDAPStorageMapper create (KeycloakSession session, ComponentModel model)
 
void postInit (KeycloakSessionFactory factory)
 
void close ()
 

静的公開メンバ関数

static ProviderConfigProperty createConfigProperty (String name, String label, String helpText, String type, List< String > options)
 

静的公開変数類

static final String PROVIDER_ID = "role-ldap-mapper"
 

限定公開メンバ関数

AbstractLDAPStorageMapper createMapper (ComponentModel mapperModel, LDAPStorageProvider federationProvider)
 
UserRolesRetrieveStrategy getUserRolesRetrieveStrategy (String strategyKey)
 
void checkMandatoryConfigAttribute (String name, String displayName, ComponentModel mapperModel) throws ComponentValidationException
 

静的限定公開変数類

static final List< ProviderConfigPropertyconfigProperties
 
static final Map< String, UserRolesRetrieveStrategyuserRolesStrategies = new LinkedHashMap<>()
 
static final List< String > MEMBERSHIP_TYPES = new LinkedList<>()
 
static final List< String > MODES = new LinkedList<>()
 
static final List< String > NO_IMPORT_MODES = new LinkedList<>()
 
static final List< String > roleRetrievers
 

静的関数

 [static initializer]
 

静的非公開メンバ関数

static List< ProviderConfigPropertygetProps (ComponentModel parent)
 

詳解

著者
Marek Posolda

関数詳解

◆ [static initializer]()

org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.[static initializer] ( )
inlinestaticpackage

◆ checkMandatoryConfigAttribute()

void org.keycloak.storage.ldap.mappers.AbstractLDAPStorageMapperFactory.checkMandatoryConfigAttribute ( String  name,
String  displayName,
ComponentModel  mapperModel 
) throws ComponentValidationException
inlineprotectedinherited
80  {
81  String attrConfigValue = mapperModel.getConfig().getFirst(name);
82  if (attrConfigValue == null || attrConfigValue.trim().isEmpty()) {
83  throw new ComponentValidationException("Missing configuration for '" + displayName + "'");
84  }
85  }

◆ close()

void org.keycloak.storage.ldap.mappers.AbstractLDAPStorageMapperFactory.close ( )
inlineinherited
67  {
68  }

◆ create()

LDAPStorageMapper org.keycloak.storage.ldap.mappers.AbstractLDAPStorageMapperFactory.create ( KeycloakSession  session,
ComponentModel  model 
)
inlineinherited
42  {
43  // LDAPStorageProvider is in the session already as mappers are always called from it
44  String ldapProviderModelId = model.getParentId();
45  LDAPStorageProvider ldapProvider = (LDAPStorageProvider) session.getAttribute(ldapProviderModelId);
46 
47  return createMapper(model, ldapProvider);
48  }
abstract AbstractLDAPStorageMapper createMapper(ComponentModel mapperModel, LDAPStorageProvider federationProvider)

◆ createConfigProperty()

static ProviderConfigProperty org.keycloak.storage.ldap.mappers.AbstractLDAPStorageMapperFactory.createConfigProperty ( String  name,
String  label,
String  helpText,
String  type,
List< String >  options 
)
inlinestaticinherited
70  {
71  ProviderConfigProperty configProperty = new ProviderConfigProperty();
72  configProperty.setName(name);
73  configProperty.setLabel(label);
74  configProperty.setHelpText(helpText);
75  configProperty.setType(type);
76  configProperty.setOptions(options);
77  return configProperty;
78  }

◆ createMapper()

AbstractLDAPStorageMapper org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.createMapper ( ComponentModel  mapperModel,
LDAPStorageProvider  federationProvider 
)
inlineprotected
268  {
269  return new RoleLDAPStorageMapper(mapperModel, federationProvider, this);
270  }

◆ getConfigProperties() [1/2]

List<ProviderConfigProperty> org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.getConfigProperties ( )
inline
224  {
225  return configProperties;
226  }
static final List< ProviderConfigProperty > configProperties
Definition: RoleLDAPStorageMapperFactory.java:52

◆ getConfigProperties() [2/2]

List<ProviderConfigProperty> org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.getConfigProperties ( RealmModel  realm,
ComponentModel  parent 
)
inline
229  {
230  return getProps(parent);
231  }
static List< ProviderConfigProperty > getProps(ComponentModel parent)
Definition: RoleLDAPStorageMapperFactory.java:79

◆ getHelpText()

String org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.getHelpText ( )
inline
219  {
220  return "Used to map role mappings of roles from some LDAP DN to Keycloak role mappings of either realm roles or client roles of particular client";
221  }

◆ getId()

String org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.getId ( )
inline
234  {
235  return PROVIDER_ID;
236  }
static final String PROVIDER_ID
Definition: RoleLDAPStorageMapperFactory.java:50

◆ getProps()

static List<ProviderConfigProperty> org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.getProps ( ComponentModel  parent)
inlinestaticprivate
79  {
80  String roleObjectClasses = LDAPConstants.GROUP_OF_NAMES;
81  String mode = LDAPGroupMapperMode.LDAP_ONLY.toString();
82  String membershipUserAttribute = LDAPConstants.UID;
83  boolean importEnabled = true;
84  if (parent != null) {
85  LDAPConfig config = new LDAPConfig(parent.getConfig());
86  roleObjectClasses = config.isActiveDirectory() ? LDAPConstants.GROUP : LDAPConstants.GROUP_OF_NAMES;
87  mode = config.getEditMode() == UserStorageProvider.EditMode.WRITABLE ? LDAPGroupMapperMode.LDAP_ONLY.toString() : LDAPGroupMapperMode.READ_ONLY.toString();
88  membershipUserAttribute = config.getUsernameLdapAttribute();
89  importEnabled = new UserStorageProviderModel(parent).isImportEnabled();
90 
91  }
92 
93  ProviderConfigurationBuilder config = ProviderConfigurationBuilder.create()
94  .property().name(RoleMapperConfig.ROLES_DN)
95  .label("LDAP Roles DN")
96  .helpText("LDAP DN where are roles of this tree saved. For example 'ou=finance,dc=example,dc=org' ")
97  .type(ProviderConfigProperty.STRING_TYPE)
98  .add()
99  .property().name(RoleMapperConfig.ROLE_NAME_LDAP_ATTRIBUTE)
100  .label("Role Name LDAP Attribute")
101  .helpText("Name of LDAP attribute, which is used in role objects for name and RDN of role. Usually it will be 'cn' . In this case typical group/role object may have DN like 'cn=role1,ou=finance,dc=example,dc=org' ")
102  .type(ProviderConfigProperty.STRING_TYPE)
103  .defaultValue(LDAPConstants.CN)
104  .add()
105  .property().name(RoleMapperConfig.ROLE_OBJECT_CLASSES)
106  .label("Role Object Classes")
107  .helpText("Object class (or classes) of the role object. It's divided by comma if more classes needed. In typical LDAP deployment it could be 'groupOfNames' . In Active Directory it's usually 'group' ")
108  .type(ProviderConfigProperty.STRING_TYPE)
109  .defaultValue(roleObjectClasses)
110  .add()
111  .property().name(RoleMapperConfig.MEMBERSHIP_LDAP_ATTRIBUTE)
112  .label("Membership LDAP Attribute")
113  .helpText("Name of LDAP attribute on role, which is used for membership mappings. Usually it will be 'member' ." +
114  "However when 'Membership Attribute Type' is 'UID' then 'Membership LDAP Attribute' could be typically 'memberUid' .")
115  .type(ProviderConfigProperty.STRING_TYPE)
116  .defaultValue(LDAPConstants.MEMBER)
117  .add()
118  .property().name(RoleMapperConfig.MEMBERSHIP_ATTRIBUTE_TYPE)
119  .label("Membership Attribute Type")
120  .helpText("DN means that LDAP role has it's members declared in form of their full DN. For example 'member: uid=john,ou=users,dc=example,dc=com' . " +
121  "UID means that LDAP role has it's members declared in form of pure user uids. For example 'memberUid: john' .")
122  .type(ProviderConfigProperty.LIST_TYPE)
123  .options(MEMBERSHIP_TYPES)
124  .defaultValue(MembershipType.DN.toString())
125  .add()
126  .property().name(RoleMapperConfig.MEMBERSHIP_USER_LDAP_ATTRIBUTE)
127  .label("Membership User LDAP Attribute")
128  .helpText("Used just if Membership Attribute Type is UID. It is name of LDAP attribute on user, which is used for membership mappings. Usually it will be 'uid' . For example if value of " +
129  "'Membership User LDAP Attribute' is 'uid' and " +
130  " LDAP group has 'memberUid: john', then it is expected that particular LDAP user will have attribute 'uid: john' .")
131  .type(ProviderConfigProperty.STRING_TYPE)
132  .defaultValue(membershipUserAttribute)
133  .add()
134  .property().name(RoleMapperConfig.ROLES_LDAP_FILTER)
135  .label("LDAP Filter")
136  .helpText("LDAP Filter adds additional custom filter to the whole query for retrieve LDAP roles. Leave this empty if no additional filtering is needed and you want to retrieve all roles from LDAP. Otherwise make sure that filter starts with '(' and ends with ')'")
137  .type(ProviderConfigProperty.STRING_TYPE)
138  .add();
139 
140  if (importEnabled) {
141  config.property().name(RoleMapperConfig.MODE)
142  .label("Mode")
143  .helpText("LDAP_ONLY means that all role mappings are retrieved from LDAP and saved into LDAP. READ_ONLY is Read-only LDAP mode where role mappings are " +
144  "retrieved from both LDAP and DB and merged together. New role grants are not saved to LDAP but to DB. IMPORT is Read-only LDAP mode where role mappings are retrieved from LDAP just at the time when user is imported from LDAP and then " +
145  "they are saved to local keycloak DB.")
146  .type(ProviderConfigProperty.LIST_TYPE)
147  .options(MODES)
148  .defaultValue(mode)
149  .add();
150  } else {
151  config.property().name(RoleMapperConfig.MODE)
152  .label("Mode")
153  .helpText("LDAP_ONLY means that specified role mappings are writable to LDAP. READ_ONLY means LDAP is readonly.")
154  .type(ProviderConfigProperty.LIST_TYPE)
155  .options(NO_IMPORT_MODES)
156  .defaultValue(mode)
157  .add();
158 
159  }
160 
161  config.property().name(RoleMapperConfig.USER_ROLES_RETRIEVE_STRATEGY)
162  .label("User Roles Retrieve Strategy")
163  .helpText("Specify how to retrieve roles of user. LOAD_ROLES_BY_MEMBER_ATTRIBUTE means that roles of user will be retrieved by sending LDAP query to retrieve all roles where 'member' is our user. " +
164  "GET_ROLES_FROM_USER_MEMBEROF_ATTRIBUTE means that roles of user will be retrieved from 'memberOf' attribute of our user. Or from the other attribute specified by 'Member-Of LDAP Attribute' . " +
165  "LOAD_ROLES_BY_MEMBER_ATTRIBUTE_RECURSIVELY is applicable just in Active Directory and it means that roles of user will be retrieved recursively with usage of LDAP_MATCHING_RULE_IN_CHAIN Ldap extension.")
166  .type(ProviderConfigProperty.LIST_TYPE)
167  .options(roleRetrievers)
168  .defaultValue(RoleMapperConfig.LOAD_ROLES_BY_MEMBER_ATTRIBUTE)
169  .add()
170  .property().name(GroupMapperConfig.MEMBEROF_LDAP_ATTRIBUTE)
171  .label("Member-Of LDAP Attribute")
172  .helpText("Used just when 'User Roles Retrieve Strategy' is GET_ROLES_FROM_USER_MEMBEROF_ATTRIBUTE . " +
173  "It specifies the name of the LDAP attribute on the LDAP user, which contains the roles (LDAP Groups), which the user is member of. " +
174  "Usually it will be 'memberOf' and that's also the default value.")
175  .type(ProviderConfigProperty.STRING_TYPE)
176  .defaultValue(LDAPConstants.MEMBER_OF)
177  .add()
178  .property().name(RoleMapperConfig.USE_REALM_ROLES_MAPPING)
179  .label("Use Realm Roles Mapping")
180  .helpText("If true, then LDAP role mappings will be mapped to realm role mappings in Keycloak. Otherwise it will be mapped to client role mappings")
181  .type(ProviderConfigProperty.BOOLEAN_TYPE)
182  .defaultValue("true")
183  .add()
184  .property().name(RoleMapperConfig.CLIENT_ID)
185  .label("Client ID")
186  .helpText("Client ID of client to which LDAP role mappings will be mapped. Applicable just if 'Use Realm Roles Mapping' is false")
187  .type(ProviderConfigProperty.CLIENT_LIST_TYPE)
188  .add();
189  return config.build();
190  }
static final List< String > MEMBERSHIP_TYPES
Definition: RoleLDAPStorageMapperFactory.java:54
static final List< String > roleRetrievers
Definition: RoleLDAPStorageMapperFactory.java:57
static final List< String > NO_IMPORT_MODES
Definition: RoleLDAPStorageMapperFactory.java:56
static final List< String > MODES
Definition: RoleLDAPStorageMapperFactory.java:55

◆ getTypeMetadata()

Map<String, Object> org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.getTypeMetadata ( )
inline
239  {
240  Map<String, Object> metadata = new HashMap<>();
241  metadata.put("fedToKeycloakSyncSupported", true);
242  metadata.put("fedToKeycloakSyncMessage", "sync-ldap-roles-to-keycloak");
243  metadata.put("keycloakToFedSyncSupported", true);
244  metadata.put("keycloakToFedSyncMessage", "sync-keycloak-roles-to-ldap");
245 
246  return metadata;
247  }

◆ getUserRolesRetrieveStrategy()

UserRolesRetrieveStrategy org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.getUserRolesRetrieveStrategy ( String  strategyKey)
inlineprotected
272  {
273  return userRolesStrategies.get(strategyKey);
274  }
static final Map< String, UserRolesRetrieveStrategy > userRolesStrategies
Definition: RoleLDAPStorageMapperFactory.java:53

◆ init()

void org.keycloak.storage.ldap.mappers.AbstractLDAPStorageMapperFactory.init ( Config.Scope  config)
inlineinherited
38  {
39  }

◆ onCreate()

void org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.onCreate ( KeycloakSession  session,
RealmModel  realm,
ComponentModel  model 
)
inline
204  {
205  ComponentModel parentModel = realm.getComponent(model.getParentId());
206  UserStorageProviderModel parent = new UserStorageProviderModel(parentModel);
207  onParentUpdate(realm, parent, parent, model);
208 
209  }
void onParentUpdate(RealmModel realm, UserStorageProviderModel oldParent, UserStorageProviderModel newParent, ComponentModel mapperModel)
Definition: RoleLDAPStorageMapperFactory.java:193

◆ onParentUpdate()

void org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.onParentUpdate ( RealmModel  realm,
UserStorageProviderModel  oldParent,
UserStorageProviderModel  newParent,
ComponentModel  mapperModel 
)
inline
193  {
194  if (!newParent.isImportEnabled()) {
195  if (new RoleMapperConfig(mapperModel).getMode() == LDAPGroupMapperMode.IMPORT) {
196  mapperModel.getConfig().putSingle(RoleMapperConfig.MODE, LDAPGroupMapperMode.READ_ONLY.toString());
197  realm.updateComponent(mapperModel);
198 
199  }
200  }
201  }

◆ onUpdate()

void org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.onUpdate ( KeycloakSession  session,
RealmModel  realm,
ComponentModel  oldModel,
ComponentModel  newModel 
)
inline
212  {
213  ComponentModel parentModel = realm.getComponent(newModel.getParentId());
214  UserStorageProviderModel parent = new UserStorageProviderModel(parentModel);
215  onParentUpdate(realm, parent, parent, newModel);
216  }
void onParentUpdate(RealmModel realm, UserStorageProviderModel oldParent, UserStorageProviderModel newParent, ComponentModel mapperModel)
Definition: RoleLDAPStorageMapperFactory.java:193

◆ postInit()

void org.keycloak.storage.ldap.mappers.AbstractLDAPStorageMapperFactory.postInit ( KeycloakSessionFactory  factory)
inlineinherited
54  {
55  }

◆ validateConfiguration()

void org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.validateConfiguration ( KeycloakSession  session,
RealmModel  realm,
ComponentModel  config 
) throws ComponentValidationException
inline
251  {
252  checkMandatoryConfigAttribute(RoleMapperConfig.ROLES_DN, "LDAP Roles DN", config);
253  checkMandatoryConfigAttribute(RoleMapperConfig.MODE, "Mode", config);
254 
255  String realmMappings = config.getConfig().getFirst(RoleMapperConfig.USE_REALM_ROLES_MAPPING);
256  boolean useRealmMappings = Boolean.parseBoolean(realmMappings);
257  if (!useRealmMappings) {
258  String clientId = config.getConfig().getFirst(RoleMapperConfig.CLIENT_ID);
259  if (clientId == null || clientId.trim().isEmpty()) {
260  throw new ComponentValidationException("ldapErrorMissingClientId");
261  }
262  }
263 
264  LDAPUtils.validateCustomLdapFilter(config.getConfig().getFirst(RoleMapperConfig.ROLES_LDAP_FILTER));
265  }
void checkMandatoryConfigAttribute(String name, String displayName, ComponentModel mapperModel)
Definition: AbstractLDAPStorageMapperFactory.java:80

メンバ詳解

◆ configProperties

final List<ProviderConfigProperty> org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.configProperties
staticprotected

◆ MEMBERSHIP_TYPES

final List<String> org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.MEMBERSHIP_TYPES = new LinkedList<>()
staticprotected

◆ MODES

final List<String> org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.MODES = new LinkedList<>()
staticprotected

◆ NO_IMPORT_MODES

final List<String> org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.NO_IMPORT_MODES = new LinkedList<>()
staticprotected

◆ PROVIDER_ID

final String org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.PROVIDER_ID = "role-ldap-mapper"
static

◆ roleRetrievers

final List<String> org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.roleRetrievers
staticprotected

◆ userRolesStrategies

final Map<String, UserRolesRetrieveStrategy> org.keycloak.storage.ldap.mappers.membership.role.RoleLDAPStorageMapperFactory.userRolesStrategies = new LinkedHashMap<>()
staticprotected

このクラス詳解は次のファイルから抽出されました: