keycloak-service
公開メンバ関数 | 静的公開メンバ関数 | 静的公開変数類 | 限定公開メンバ関数 | 静的関数 | 静的非公開変数類 | 全メンバ一覧
org.keycloak.broker.oidc.mappers.ClaimToRoleMapper クラス
org.keycloak.broker.oidc.mappers.ClaimToRoleMapper の継承関係図
Inheritance graph
org.keycloak.broker.oidc.mappers.ClaimToRoleMapper 連携図
Collaboration graph

公開メンバ関数

List< ProviderConfigProperty > getConfigProperties ()
 
String getId ()
 
String [] getCompatibleProviders ()
 
String getDisplayCategory ()
 
String getDisplayType ()
 
void importNewUser (KeycloakSession session, RealmModel realm, UserModel user, IdentityProviderMapperModel mapperModel, BrokeredIdentityContext context)
 
void updateBrokeredUser (KeycloakSession session, RealmModel realm, UserModel user, IdentityProviderMapperModel mapperModel, BrokeredIdentityContext context)
 
String getHelpText ()
 
boolean valueEquals (String desiredValue, Object value)
 

静的公開メンバ関数

static Object getClaimValue (JsonWebToken token, String claim)
 
static Object getClaimValue (IdentityProviderMapperModel mapperModel, BrokeredIdentityContext context)
 
static Object getClaimValue (BrokeredIdentityContext context, String claim)
 

静的公開変数類

static final String [] COMPATIBLE_PROVIDERS = {KeycloakOIDCIdentityProviderFactory.PROVIDER_ID, OIDCIdentityProviderFactory.PROVIDER_ID}
 
static final String PROVIDER_ID = "oidc-role-idp-mapper"
 
static final String CLAIM = "claim"
 
static final String CLAIM_VALUE = "claim.value"
 

限定公開メンバ関数

boolean hasClaimValue (IdentityProviderMapperModel mapperModel, BrokeredIdentityContext context)
 

静的関数

 [static initializer]
 

静的非公開変数類

static final List< ProviderConfigProperty > configProperties = new ArrayList<ProviderConfigProperty>()
 

詳解

著者
Bill Burke
バージョン
Revision
1

関数詳解

◆ [static initializer]()

org.keycloak.broker.oidc.mappers.ClaimToRoleMapper.[static initializer] ( )
inlinestaticpackage

◆ getClaimValue() [1/3]

static Object org.keycloak.broker.oidc.mappers.AbstractClaimMapper.getClaimValue ( JsonWebToken  token,
String  claim 
)
inlinestaticinherited
43  {
44  List<String> split = OIDCAttributeMapperHelper.splitClaimPath(claim);
45  Map<String, Object> jsonObject = token.getOtherClaims();
46  final int length = split.size();
47  int i = 0;
48  for (String component : split) {
49  i++;
50  if (i == length) {
51  return jsonObject.get(component);
52  } else {
53  Object val = jsonObject.get(component);
54  if (!(val instanceof Map)) return null;
55  jsonObject = (Map<String, Object>)val;
56  }
57  }
58  return null;
59  }

◆ getClaimValue() [2/3]

static Object org.keycloak.broker.oidc.mappers.AbstractClaimMapper.getClaimValue ( IdentityProviderMapperModel  mapperModel,
BrokeredIdentityContext  context 
)
inlinestaticinherited
61  {
62  String claim = mapperModel.getConfig().get(CLAIM);
63  return getClaimValue(context, claim);
64  }
static final String CLAIM
Definition: AbstractClaimMapper.java:40
static Object getClaimValue(JsonWebToken token, String claim)
Definition: AbstractClaimMapper.java:43

◆ getClaimValue() [3/3]

static Object org.keycloak.broker.oidc.mappers.AbstractClaimMapper.getClaimValue ( BrokeredIdentityContext  context,
String  claim 
)
inlinestaticinherited
66  {
67  { // search access token
68  JsonWebToken token = (JsonWebToken)context.getContextData().get(KeycloakOIDCIdentityProvider.VALIDATED_ACCESS_TOKEN);
69  if (token != null) {
70  Object value = getClaimValue(token, claim);
71  if (value != null) return value;
72  }
73 
74  }
75  { // search ID Token
76  JsonWebToken token = (JsonWebToken)context.getContextData().get(KeycloakOIDCIdentityProvider.VALIDATED_ID_TOKEN);
77  if (token != null) {
78  Object value = getClaimValue(token, claim);
79  if (value != null) return value;
80  }
81 
82  }
83  {
84  // Search the OIDC UserInfo claim set (if any)
85  JsonNode profileJsonNode = (JsonNode) context.getContextData().get(OIDCIdentityProvider.USER_INFO);
86  Object value = AbstractJsonUserAttributeMapper.getJsonValue(profileJsonNode, claim);
87  if (value != null) return value;
88  }
89  return null;
90  }
static Object getClaimValue(JsonWebToken token, String claim)
Definition: AbstractClaimMapper.java:43

◆ getCompatibleProviders()

String [] org.keycloak.broker.oidc.mappers.ClaimToRoleMapper.getCompatibleProviders ( )
inline
83  {
84  return COMPATIBLE_PROVIDERS;
85  }
static final String [] COMPATIBLE_PROVIDERS
Definition: ClaimToRoleMapper.java:42

◆ getConfigProperties()

List<ProviderConfigProperty> org.keycloak.broker.oidc.mappers.ClaimToRoleMapper.getConfigProperties ( )
inline
73  {
74  return configProperties;
75  }
static final List< ProviderConfigProperty > configProperties
Definition: ClaimToRoleMapper.java:44

◆ getDisplayCategory()

String org.keycloak.broker.oidc.mappers.ClaimToRoleMapper.getDisplayCategory ( )
inline
88  {
89  return "Role Importer";
90  }

◆ getDisplayType()

String org.keycloak.broker.oidc.mappers.ClaimToRoleMapper.getDisplayType ( )
inline
93  {
94  return "Claim to Role";
95  }

◆ getHelpText()

String org.keycloak.broker.oidc.mappers.ClaimToRoleMapper.getHelpText ( )
inline
119  {
120  return "If a claim exists, grant the user the specified realm or application role.";
121  }

◆ getId()

String org.keycloak.broker.oidc.mappers.ClaimToRoleMapper.getId ( )
inline
78  {
79  return PROVIDER_ID;
80  }
static final String PROVIDER_ID
Definition: ClaimToRoleMapper.java:69

◆ hasClaimValue()

boolean org.keycloak.broker.oidc.mappers.AbstractClaimMapper.hasClaimValue ( IdentityProviderMapperModel  mapperModel,
BrokeredIdentityContext  context 
)
inlineprotectedinherited
93  {
94  Object value = getClaimValue(mapperModel, context);
95  String desiredValue = mapperModel.getConfig().get(CLAIM_VALUE);
96  return valueEquals(desiredValue, value);
97  }
boolean valueEquals(String desiredValue, Object value)
Definition: AbstractClaimMapper.java:99
static final String CLAIM_VALUE
Definition: AbstractClaimMapper.java:41
static Object getClaimValue(JsonWebToken token, String claim)
Definition: AbstractClaimMapper.java:43

◆ importNewUser()

void org.keycloak.broker.oidc.mappers.ClaimToRoleMapper.importNewUser ( KeycloakSession  session,
RealmModel  realm,
UserModel  user,
IdentityProviderMapperModel  mapperModel,
BrokeredIdentityContext  context 
)
inline
98  {
99  String roleName = mapperModel.getConfig().get(ConfigConstants.ROLE);
100  if (hasClaimValue(mapperModel, context)) {
101  RoleModel role = KeycloakModelUtils.getRoleFromString(realm, roleName);
102  if (role == null) throw new IdentityBrokerException("Unable to find role: " + roleName);
103  user.grantRole(role);
104  }
105  }
boolean hasClaimValue(IdentityProviderMapperModel mapperModel, BrokeredIdentityContext context)
Definition: AbstractClaimMapper.java:93

◆ updateBrokeredUser()

void org.keycloak.broker.oidc.mappers.ClaimToRoleMapper.updateBrokeredUser ( KeycloakSession  session,
RealmModel  realm,
UserModel  user,
IdentityProviderMapperModel  mapperModel,
BrokeredIdentityContext  context 
)
inline
108  {
109  String roleName = mapperModel.getConfig().get(ConfigConstants.ROLE);
110  if (!hasClaimValue(mapperModel, context)) {
111  RoleModel role = KeycloakModelUtils.getRoleFromString(realm, roleName);
112  if (role == null) throw new IdentityBrokerException("Unable to find role: " + roleName);
113  user.deleteRoleMapping(role);
114  }
115 
116  }
boolean hasClaimValue(IdentityProviderMapperModel mapperModel, BrokeredIdentityContext context)
Definition: AbstractClaimMapper.java:93

◆ valueEquals()

boolean org.keycloak.broker.oidc.mappers.AbstractClaimMapper.valueEquals ( String  desiredValue,
Object  value 
)
inlineinherited
99  {
100  if (value instanceof String) {
101  if (desiredValue.equals(value)) return true;
102  } else if (value instanceof Double) {
103  try {
104  if (Double.valueOf(desiredValue).equals(value)) return true;
105  } catch (Exception e) {
106 
107  }
108  } else if (value instanceof Integer) {
109  try {
110  if (Integer.valueOf(desiredValue).equals(value)) return true;
111  } catch (Exception e) {
112 
113  }
114  } else if (value instanceof Boolean) {
115  try {
116  if (Boolean.valueOf(desiredValue).equals(value)) return true;
117  } catch (Exception e) {
118 
119  }
120  } else if (value instanceof List) {
121  List list = (List)value;
122  for (Object val : list) {
123  if (valueEquals(desiredValue, val)) return true;
124  }
125  }
126  return false;
127  }
boolean valueEquals(String desiredValue, Object value)
Definition: AbstractClaimMapper.java:99

メンバ詳解

◆ CLAIM

final String org.keycloak.broker.oidc.mappers.AbstractClaimMapper.CLAIM = "claim"
staticinherited

◆ CLAIM_VALUE

final String org.keycloak.broker.oidc.mappers.AbstractClaimMapper.CLAIM_VALUE = "claim.value"
staticinherited

◆ COMPATIBLE_PROVIDERS

final String [] org.keycloak.broker.oidc.mappers.ClaimToRoleMapper.COMPATIBLE_PROVIDERS = {KeycloakOIDCIdentityProviderFactory.PROVIDER_ID, OIDCIdentityProviderFactory.PROVIDER_ID}
static

◆ configProperties

final List<ProviderConfigProperty> org.keycloak.broker.oidc.mappers.ClaimToRoleMapper.configProperties = new ArrayList<ProviderConfigProperty>()
staticprivate

◆ PROVIDER_ID

final String org.keycloak.broker.oidc.mappers.ClaimToRoleMapper.PROVIDER_ID = "oidc-role-idp-mapper"
static

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