keycloak-service
公開メンバ関数 | 静的公開メンバ関数 | 静的公開変数類 | 限定公開メンバ関数 | 静的関数 | 非公開メンバ関数 | 静的非公開変数類 | 全メンバ一覧
org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper クラス
org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper の継承関係図
Inheritance graph
org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper 連携図
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}
 
static final String PROVIDER_ID = "keycloak-oidc-role-to-role-idp-mapper"
 
static final String CLAIM = "claim"
 
static final String CLAIM_VALUE = "claim.value"
 

限定公開メンバ関数

boolean hasClaimValue (IdentityProviderMapperModel mapperModel, BrokeredIdentityContext context)
 

静的関数

 [static initializer]
 

非公開メンバ関数

RoleModel hasRole (RealmModel realm, IdentityProviderMapperModel mapperModel, BrokeredIdentityContext context)
 

静的非公開変数類

static final List< ProviderConfigProperty > configProperties = new ArrayList<ProviderConfigProperty>()
 
static final String EXTERNAL_ROLE = "external.role"
 

詳解

著者
Bill Burke
バージョン
Revision
1

関数詳解

◆ [static initializer]()

org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper.[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.ExternalKeycloakRoleToRoleMapper.getCompatibleProviders ( )
inline
79  {
80  return COMPATIBLE_PROVIDERS;
81  }
static final String [] COMPATIBLE_PROVIDERS
Definition: ExternalKeycloakRoleToRoleMapper.java:43

◆ getConfigProperties()

List<ProviderConfigProperty> org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper.getConfigProperties ( )
inline
69  {
70  return configProperties;
71  }
static final List< ProviderConfigProperty > configProperties
Definition: ExternalKeycloakRoleToRoleMapper.java:45

◆ getDisplayCategory()

String org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper.getDisplayCategory ( )
inline
84  {
85  return "Role Importer";
86  }

◆ getDisplayType()

String org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper.getDisplayType ( )
inline
89  {
90  return "External Role to Role";
91  }

◆ getHelpText()

String org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper.getHelpText ( )
inline
131  {
132  return "Looks for an external role in a keycloak access token. If external role exists, grant the user the specified realm or application role.";
133  }

◆ getId()

String org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper.getId ( )
inline
74  {
75  return PROVIDER_ID;
76  }
static final String PROVIDER_ID
Definition: ExternalKeycloakRoleToRoleMapper.java:65

◆ 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

◆ hasRole()

RoleModel org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper.hasRole ( RealmModel  realm,
IdentityProviderMapperModel  mapperModel,
BrokeredIdentityContext  context 
)
inlineprivate
101  {
102  JsonWebToken token = (JsonWebToken)context.getContextData().get(KeycloakOIDCIdentityProvider.VALIDATED_ACCESS_TOKEN);
103  //if (token == null) return;
104  String roleName = mapperModel.getConfig().get(ConfigConstants.ROLE);
105  String[] parseRole = KeycloakModelUtils.parseRole(mapperModel.getConfig().get(EXTERNAL_ROLE));
106  String externalRoleName = parseRole[1];
107  String claimName = null;
108  if (parseRole[0] == null) {
109  claimName = "realm_access.roles";
110  } else {
111  claimName = "resource_access." + parseRole[0] + ".roles";
112  }
113  Object claim = getClaimValue(token, claimName);
114  if (valueEquals(externalRoleName, claim)) {
115  RoleModel role = KeycloakModelUtils.getRoleFromString(realm, roleName);
116  if (role == null) throw new IdentityBrokerException("Unable to find role: " + roleName);
117  return role;
118  }
119  return null;
120  }
boolean valueEquals(String desiredValue, Object value)
Definition: AbstractClaimMapper.java:99
static final String EXTERNAL_ROLE
Definition: ExternalKeycloakRoleToRoleMapper.java:46
static Object getClaimValue(JsonWebToken token, String claim)
Definition: AbstractClaimMapper.java:43

◆ importNewUser()

void org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper.importNewUser ( KeycloakSession  session,
RealmModel  realm,
UserModel  user,
IdentityProviderMapperModel  mapperModel,
BrokeredIdentityContext  context 
)
inline
94  {
95  RoleModel role = hasRole(realm, mapperModel, context);
96  if (role != null) {
97  user.grantRole(role);
98  }
99  }
RoleModel hasRole(RealmModel realm, IdentityProviderMapperModel mapperModel, BrokeredIdentityContext context)
Definition: ExternalKeycloakRoleToRoleMapper.java:101

◆ updateBrokeredUser()

void org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper.updateBrokeredUser ( KeycloakSession  session,
RealmModel  realm,
UserModel  user,
IdentityProviderMapperModel  mapperModel,
BrokeredIdentityContext  context 
)
inline
123  {
124  RoleModel role = hasRole(realm, mapperModel, context);
125  if (role == null) {
126  user.deleteRoleMapping(role);
127  }
128  }
RoleModel hasRole(RealmModel realm, IdentityProviderMapperModel mapperModel, BrokeredIdentityContext context)
Definition: ExternalKeycloakRoleToRoleMapper.java:101

◆ 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.ExternalKeycloakRoleToRoleMapper.COMPATIBLE_PROVIDERS = {KeycloakOIDCIdentityProviderFactory.PROVIDER_ID}
static

◆ configProperties

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

◆ EXTERNAL_ROLE

final String org.keycloak.broker.oidc.mappers.ExternalKeycloakRoleToRoleMapper.EXTERNAL_ROLE = "external.role"
staticprivate

◆ PROVIDER_ID

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

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