Package org.keycloak.storage
Class UserStorageManager
java.lang.Object
org.keycloak.storage.AbstractStorageManager<UserStorageProvider,UserStorageProviderModel>
 
org.keycloak.storage.UserStorageManager
- All Implemented Interfaces:
- OnUserCache,- UserProvider,- Provider,- OnCreateComponent,- OnUpdateComponent,- UserBulkUpdateProvider,- UserCountMethodsProvider,- UserLookupProvider,- UserQueryMethodsProvider,- UserQueryProvider,- UserRegistrationProvider,- UserProfileDecorator
public class UserStorageManager
extends AbstractStorageManager<UserStorageProvider,UserStorageProviderModel>
implements UserProvider, OnUserCache, OnCreateComponent, OnUpdateComponent, UserProfileDecorator 
- Version:
- $Revision: 1 $
- Author:
- Bill Burke
- 
Field SummaryFields inherited from class org.keycloak.storage.AbstractStorageManagersession
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddConsent(RealmModel realm, String userId, UserConsentModel consent) Add user consent for the user.voidaddFederatedIdentity(RealmModel realm, UserModel user, FederatedIdentityModel socialLink) Adds a federated identity link for the user within the realmaddUser(RealmModel realm, String username) UserRegistrationProvidermethods implementations start hereaddUser(RealmModel realm, String id, String username, boolean addDefaultRoles, boolean addDefaultRequiredActions) UserStorageProvidermethods implementation end hereUserProvidermethods implementations start here -> no StorageProviders involvedvoidclose()UserProvidermethods implementations end heredecorateUserProfile(String providerId, UserProfileMetadata metadata) Decorates user profile with additional metadata.protected voiddeleteInvalidUser(RealmModel realm, UserModel user) protected voiddeleteInvalidUserCache(RealmModel realm, UserModel user) getConsentByClient(RealmModel realm, String userId, String clientInternalId) Returns UserConsentModel given by a user with the userId for the client with clientInternalIdgetConsentsStream(RealmModel realm, String userId) Obtains the consents associated with the user identified by the specifieduserId.getFederatedIdentitiesStream(RealmModel realm, UserModel user) Obtains the federated identities of the specified user.getFederatedIdentity(RealmModel realm, UserModel user, String socialProvider) Returns details of the association between the user and the socialProvider.getGroupMembersStream(RealmModel realm, GroupModel group, Integer firstResult, Integer maxResults) UserLookupProvidermethods implementations end hereUserQueryProvidermethods implementation start heregetGroupMembersStream(RealmModel realm, GroupModel group, String search, Boolean exact, Integer firstResult, Integer maxResults) Obtains users that belong to a specific group, filtered according to the search parameters.intgetNotBeforeOfUser(RealmModel realm, UserModel user) Gets the notBefore value for the given usergetRoleMembersStream(RealmModel realm, RoleModel role, Integer firstResult, Integer maxResults) Searches for users that have the specified role.getServiceAccount(ClientModel client) Return a UserModel representing service account of the clientgetUserByCredential(RealmModel realm, CredentialInput input) getUserByEmail(RealmModel realm, String email) Returns a user with the given email belonging to the realmgetUserByFederatedIdentity(RealmModel realm, FederatedIdentityModel socialLink) Returns a userModel that corresponds to the given socialLink.getUserById(RealmModel realm, String id) UserRegistrationProvidermethods implementations end hereUserLookupProvidermethods implementations start heregetUserByUsername(RealmModel realm, String username) Exact search for a user by its username.intgetUsersCount(RealmModel realm) Returns the number of users, without consider any service account.intgetUsersCount(RealmModel realm, boolean includeServiceAccount) Returns the number of users.intgetUsersCount(RealmModel realm, String search) Returns the number of users that would be returned by a call tosearchForUserStreamintgetUsersCount(RealmModel realm, String search, Set<String> groupIds) Returns the number of users that would be returned by a call tosearchForUserStreamand are members of at least one of the groups given by thegroupIdsset.intgetUsersCount(RealmModel realm, Map<String, String> params) Returns the number of users that match the given filter parameters.intgetUsersCount(RealmModel realm, Map<String, String> params, Set<String> groupIds) Returns the number of users that match the given filter parameters and is in at least one of the given groups.intgetUsersCount(RealmModel realm, Set<String> groupIds) Returns the number of users that are in at least one of the groups given.voidgrantToAllUsers(RealmModel realm, RoleModel role) UserQueryProvidermethods implementation end hereUserBulkUpdateProvidermethods implementation start hereimportValidation(RealmModel realm, Stream<UserModel> users) protected UserProvidervoidonCache(RealmModel realm, CachedUserModel user, UserModel delegate) voidonCreate(KeycloakSession session, RealmModel realm, ComponentModel model) voidonUpdate(KeycloakSession session, RealmModel realm, ComponentModel oldModel, ComponentModel newModel) voidpreRemove(ClientScopeModel clientScope) Called when a client scope is removed.voidpreRemove(ProtocolMapperModel protocolMapper) Called when a protocolMapper is removedvoidpreRemove(RealmModel realm) UserBulkUpdateProvidermethods implementation end hereUserStorageProvidermethods implementations start here -> no StorageProviders involvedvoidpreRemove(RealmModel realm, ComponentModel component) Called when a component is removed.voidpreRemove(RealmModel realm, ClientModel client) Called when a client is removed.voidpreRemove(RealmModel realm, GroupModel group) Called when a group is removed.voidpreRemove(RealmModel realm, IdentityProviderModel provider) Called when an identity provider is removed.voidpreRemove(RealmModel realm, RoleModel role) Called when a role is removed.query(org.keycloak.storage.UserStorageManager.PaginatedQuery pagedQuery, RealmModel realm, Integer firstResult, Integer maxResults) query(org.keycloak.storage.UserStorageManager.PaginatedQuery pagedQuery, org.keycloak.storage.UserStorageManager.CountQuery countQuery, RealmModel realm, Integer firstResult, Integer maxResults) booleanremoveFederatedIdentity(RealmModel realm, UserModel user, String socialProvider) Removes federation link between the user and the identity provider given by its idvoidremoveImportedUsers(RealmModel realm, String storageProviderId) Removes any imported users from a specific User Storage Provider.booleanremoveUser(RealmModel realm, UserModel user) Called if user originated from this provider.booleanrevokeConsentForClient(RealmModel realm, String userId, String clientInternalId) Remove a user consent given by the user id and client idsearchForUserByUserAttributeStream(RealmModel realm, String attrName, String attrValue) Searches for users that have a specific attribute with a specific value.searchForUserStream(RealmModel realm, Map<String, String> attributes, Integer firstResult, Integer maxResults) Searches for user by parameter.voidsetNotBeforeForUser(RealmModel realm, UserModel user, int notBefore) Sets the notBefore value for the given uservoidunlinkUsers(RealmModel realm, String storageProviderId) Set federation link tonullto imported users of a specific User Storage ProvidervoidupdateConsent(RealmModel realm, String userId, UserConsentModel consent) Update client scopes in the stored user consentvoidupdateFederatedIdentity(RealmModel realm, UserModel federatedUser, FederatedIdentityModel federatedIdentityModel) Update details of association between the federatedUser and the idp given by the federatedIdentityModelprotected UserModelvalidateUser(RealmModel realm, UserModel user) Allows a UserStorageProvider to proxy and/or synchronize an imported user.Methods inherited from class org.keycloak.storage.AbstractStorageManagerconsumeEnabledStorageProvidersWithTimeout, flatMapEnabledStorageProvidersWithTimeout, getEnabledStorageProviders, getStorageProviderFactory, getStorageProviderInstance, getStorageProviderInstance, getStorageProviderInstance, getStorageProviderInstance, getStorageProviderModel, getStorageProviderModels, getStorageProviderTimeout, mapEnabledStorageProvidersWithTimeoutMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.keycloak.storage.user.UserQueryMethodsProvidergetGroupMembersStream, getRoleMembersStream, searchForUserStream, searchForUserStream, searchForUserStream
- 
Constructor Details- 
UserStorageManager
 
- 
- 
Method Details- 
localStorage
- 
validateUserAllows a UserStorageProvider to proxy and/or synchronize an imported user.- Parameters:
- realm-
- user-
- Returns:
 
- 
getUserByCredential- Specified by:
- getUserByCredentialin interface- UserLookupProvider
 
- 
deleteInvalidUserCache
- 
deleteInvalidUser
- 
importValidation
- 
queryprotected Stream<UserModel> query(org.keycloak.storage.UserStorageManager.PaginatedQuery pagedQuery, RealmModel realm, Integer firstResult, Integer maxResults) 
- 
queryprotected Stream<UserModel> query(org.keycloak.storage.UserStorageManager.PaginatedQuery pagedQuery, org.keycloak.storage.UserStorageManager.CountQuery countQuery, RealmModel realm, Integer firstResult, Integer maxResults) 
- 
addUserUserRegistrationProvidermethods implementations start here- Specified by:
- addUserin interface- UserRegistrationProvider
- Parameters:
- realm- a reference to the realm
- username- a username the created user will be assigned
- Returns:
- a model of created user
 
- 
removeUserDescription copied from interface:UserRegistrationProviderCalled if user originated from this provider. If a local user is linked to this provider, this method will be called before local storage's removeUser() method is invoked. If you are using an import strategy, and this is a local user linked to this provider, this method will be called before local storage's removeUser() method is invoked. Also, you DO NOT need to remove the imported user. The runtime will handle this for you.- Specified by:
- removeUserin interface- UserRegistrationProvider
- Parameters:
- realm- a reference to the realm
- user- a reference to the user that is removed
- Returns:
- true if the user was removed, false otherwise
 
- 
getUserByIdUserRegistrationProvidermethods implementations end hereUserLookupProvidermethods implementations start here- Specified by:
- getUserByIdin interface- UserLookupProvider
- Parameters:
- realm- the realm model
- id- id of the user
- Returns:
- found user model, or nullif no such user exists
 
- 
getUserByUsernameDescription copied from interface:UserLookupProviderExact search for a user by its username. Returns a user with the given username belonging to the realm- Specified by:
- getUserByUsernamein interface- UserLookupProvider
- Parameters:
- realm- the realm model
- username- (case-sensitivity is controlled by storage)
- Returns:
- found user model, or nullif no such user exists
 
- 
getUserByEmailDescription copied from interface:UserLookupProviderReturns a user with the given email belonging to the realm- Specified by:
- getUserByEmailin interface- UserLookupProvider
- Parameters:
- realm- the realm model
- email- email address
- Returns:
- found user model, or nullif no such user exists
 
- 
getGroupMembersStreampublic Stream<UserModel> getGroupMembersStream(RealmModel realm, GroupModel group, Integer firstResult, Integer maxResults) UserLookupProvidermethods implementations end hereUserQueryProvidermethods implementation start here- Specified by:
- getGroupMembersStreamin interface- UserQueryMethodsProvider
- Parameters:
- realm- a reference to the realm.
- group- a reference to the group.
- firstResult- first result to return. Ignored if negative, zero, or- null.
- maxResults- maximum number of results to return. Ignored if negative or- null.
- Returns:
- a non-null Streamof users that belong to the group.
 
- 
getGroupMembersStreampublic Stream<UserModel> getGroupMembersStream(RealmModel realm, GroupModel group, String search, Boolean exact, Integer firstResult, Integer maxResults) Description copied from interface:UserQueryMethodsProviderObtains users that belong to a specific group, filtered according to the search parameters.- Specified by:
- getGroupMembersStreamin interface- UserQueryMethodsProvider
- Parameters:
- realm- a reference to the realm.
- group- a reference to the group.
- search- the search string. It can represent either the user's username, e-mail, first name, or last name.
- exact- a boolean indicating if the search should be exact or not. If- true, it selects only users whose main attributes (username, e-mail, first name, or last name) exactly match the search string. If- false, it selects the users whose main attributes partially match the search string.
- firstResult- the position of the first result to be processed (pagination offset). Ignored if negative or- null.
- maxResults- the maximum number of results to be returned. Ignored if negative or- null.
- Returns:
- a non-null Streamof filtered users that belong to the group.
 
- 
getRoleMembersStreampublic Stream<UserModel> getRoleMembersStream(RealmModel realm, RoleModel role, Integer firstResult, Integer maxResults) Description copied from interface:UserQueryMethodsProviderSearches for users that have the specified role.- Specified by:
- getRoleMembersStreamin interface- UserQueryMethodsProvider
- Parameters:
- realm- a reference to the realm.
- role- a reference to the role.
- firstResult- first result to return. Ignored if negative or- null.
- maxResults- maximum number of results to return. Ignored if negative or- null.
- Returns:
- a non-null Streamof users that have the specified role.
 
- 
getUsersCountDescription copied from interface:UserCountMethodsProviderReturns the number of users.- Specified by:
- getUsersCountin interface- UserCountMethodsProvider
- Parameters:
- realm- the realm
- includeServiceAccount- if true, the number of users will also include service accounts. Otherwise, only the number of users.
- Returns:
- the number of users
 
- 
getUsersCountDescription copied from interface:UserCountMethodsProviderReturns the number of users, without consider any service account.- Specified by:
- getUsersCountin interface- UserCountMethodsProvider
- Parameters:
- realm- the realm
- Returns:
- the number of users
 
- 
getUsersCountDescription copied from interface:UserCountMethodsProviderReturns the number of users that are in at least one of the groups given.- Specified by:
- getUsersCountin interface- UserCountMethodsProvider
- Parameters:
- realm- the realm
- groupIds- set of groups IDs, the returned user needs to belong to at least one of them
- Returns:
- the number of users that are in at least one of the groups
 
- 
getUsersCountDescription copied from interface:UserCountMethodsProviderReturns the number of users that would be returned by a call tosearchForUserStream- Specified by:
- getUsersCountin interface- UserCountMethodsProvider
- Parameters:
- realm- the realm
- search- case insensitive list of strings separated by whitespaces.
- Returns:
- number of users that match the search
 
- 
getUsersCountDescription copied from interface:UserCountMethodsProviderReturns the number of users that would be returned by a call tosearchForUserStreamand are members of at least one of the groups given by thegroupIdsset.- Specified by:
- getUsersCountin interface- UserCountMethodsProvider
- Parameters:
- realm- the realm
- search- case insensitive list of strings separated by whitespaces.
- groupIds- set of groups IDs, the returned user needs to belong to at least one of them
- Returns:
- number of users that match the search and given groups
 
- 
getUsersCountDescription copied from interface:UserCountMethodsProviderReturns the number of users that match the given filter parameters.- Specified by:
- getUsersCountin interface- UserCountMethodsProvider
- Parameters:
- realm- the realm
- params- filter parameters
- Returns:
- number of users that match the given filters
 
- 
getUsersCountDescription copied from interface:UserCountMethodsProviderReturns the number of users that match the given filter parameters and is in at least one of the given groups.- Specified by:
- getUsersCountin interface- UserCountMethodsProvider
- Parameters:
- realm- the realm
- params- filter parameters
- groupIds- set if groups to check for
- Returns:
- number of users that match the given filters and groups
 
- 
searchForUserStreampublic Stream<UserModel> searchForUserStream(RealmModel realm, Map<String, String> attributes, Integer firstResult, Integer maxResults) Description copied from interface:UserQueryMethodsProviderSearches for user by parameter. If possible, implementations should treat the parameter values as partial match patterns (i.e. in RDMBS terms use LIKE). Valid parameters are:- UserModel.SEARCH- search for users whose username, email, first name or last name contain any of the strings in- searchseparated by whitespace, when- SEARCHis set all other params are ignored
- UserModel.FIRST_NAME- first name (case insensitive string)
- UserModel.LAST_NAME- last name (case insensitive string)
- UserModel.EMAIL- email (case insensitive string)
- UserModel.USERNAME- username (case insensitive string)
- UserModel.EXACT- whether search with FIRST_NAME, LAST_NAME, USERNAME or EMAIL should be exact match
- UserModel.EMAIL_VERIFIED- search only for users with verified/non-verified email (true/false)
- UserModel.ENABLED- search only for enabled/disabled users (true/false)
- UserModel.IDP_ALIAS- search only for users that have a federated identity from idp with the given alias configured (case sensitive string)
- UserModel.IDP_USER_ID- search for users with federated identity with the given userId (case sensitive string)
 Any other parameters will be treated as custom user attributes. This method is used by the REST API when querying users. - Specified by:
- searchForUserStreamin interface- UserQueryMethodsProvider
- Parameters:
- realm- a reference to the realm.
- attributes- a map containing the search parameters.
- firstResult- first result to return. Ignored if negative, zero, or- null.
- maxResults- maximum number of results to return. Ignored if negative or- null.
- Returns:
- a non-null Streamof users that match the search criteria.
 
- 
searchForUserByUserAttributeStreampublic Stream<UserModel> searchForUserByUserAttributeStream(RealmModel realm, String attrName, String attrValue) Description copied from interface:UserQueryMethodsProviderSearches for users that have a specific attribute with a specific value.- Specified by:
- searchForUserByUserAttributeStreamin interface- UserQueryMethodsProvider
- Parameters:
- realm- a reference to the realm.
- attrName- the attribute name.
- attrValue- the attribute value.
- Returns:
- a non-null Streamof users that match the search criteria.
 
- 
grantToAllUsersUserQueryProvidermethods implementation end hereUserBulkUpdateProvidermethods implementation start here- Specified by:
- grantToAllUsersin interface- UserBulkUpdateProvider
- Parameters:
- realm- Realm
- role- Role to be granted
 
- 
preRemoveUserBulkUpdateProvidermethods implementation end hereUserStorageProvidermethods implementations start here -> no StorageProviders involved- Specified by:
- preRemovein interface- UserProvider
- Parameters:
- realm- a reference to the realm
 
- 
preRemoveDescription copied from interface:UserProviderCalled when a group is removed. Should remove the group membership for each user.- Specified by:
- preRemovein interface- UserProvider
- Parameters:
- realm- a reference to the realm
- group- the group model
 
- 
preRemoveDescription copied from interface:UserProviderCalled when a role is removed. Should remove the role membership for each user.- Specified by:
- preRemovein interface- UserProvider
- Parameters:
- realm- a reference to the realm
- role- the role model
 
- 
addUserpublic UserModel addUser(RealmModel realm, String id, String username, boolean addDefaultRoles, boolean addDefaultRequiredActions) UserStorageProvidermethods implementation end hereUserProvidermethods implementations start here -> no StorageProviders involved- Specified by:
- addUserin interface- UserProvider
- Parameters:
- realm- the realm that user will be created in
- id- id of the new user. Should be generated to a random value if- null.
- username- username
- addDefaultRoles- if- true, the user should join all realm default roles
- addDefaultRequiredActions- if- true, all default required actions are added to the created user
- Returns:
- model of created user
 
- 
addFederatedIdentitypublic void addFederatedIdentity(RealmModel realm, UserModel user, FederatedIdentityModel socialLink) Description copied from interface:UserProviderAdds a federated identity link for the user within the realm- Specified by:
- addFederatedIdentityin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- user- the user model
- socialLink- the federated identity model containing all details of the association between the user and the identity provider
 
- 
updateFederatedIdentitypublic void updateFederatedIdentity(RealmModel realm, UserModel federatedUser, FederatedIdentityModel federatedIdentityModel) Description copied from interface:UserProviderUpdate details of association between the federatedUser and the idp given by the federatedIdentityModel- Specified by:
- updateFederatedIdentityin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- federatedUser- the user model
- federatedIdentityModel- the federated identity model containing all details of the association between the user and the identity provider
 
- 
removeFederatedIdentityDescription copied from interface:UserProviderRemoves federation link between the user and the identity provider given by its id- Specified by:
- removeFederatedIdentityin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- user- the user model
- socialProvider- alias of the identity provider, see- IdentityProviderModel.getAlias()
- Returns:
- trueif the association was removed,- falseotherwise TODO: Make this method return Boolean so that store can return "I don't know" answer, this can be used for example in async stores
 
- 
preRemoveDescription copied from interface:UserProviderCalled when an identity provider is removed. Should remove all federated identities assigned to users from the provider.- Specified by:
- preRemovein interface- UserProvider
- Parameters:
- realm- a reference to the realm
- provider- provider model
 
- 
addConsentDescription copied from interface:UserProviderAdd user consent for the user.- Specified by:
- addConsentin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- userId- id of the user
- consent- all details corresponding to the granted consent
 
- 
getConsentByClientpublic UserConsentModel getConsentByClient(RealmModel realm, String userId, String clientInternalId) Description copied from interface:UserProviderReturns UserConsentModel given by a user with the userId for the client with clientInternalId- Specified by:
- getConsentByClientin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- userId- id of the user
- clientInternalId- id of the client
- Returns:
- consent given by the user to the client or nullif no consent or user exists
 
- 
getConsentsStreamDescription copied from interface:UserProviderObtains the consents associated with the user identified by the specifieduserId.- Specified by:
- getConsentsStreamin interface- UserProvider
- Parameters:
- realm- a reference to the realm.
- userId- the user identifier.
- Returns:
- a non-null Streamof consents associated with the user.
 
- 
updateConsentDescription copied from interface:UserProviderUpdate client scopes in the stored user consent- Specified by:
- updateConsentin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- userId- id of the user
- consent- new details of the user consent
 
- 
revokeConsentForClientDescription copied from interface:UserProviderRemove a user consent given by the user id and client id- Specified by:
- revokeConsentForClientin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- userId- id of the user
- clientInternalId- id of the client
- Returns:
- trueif the consent was removed,- falseotherwise TODO: Make this method return Boolean so that store can return "I don't know" answer, this can be used for example in async stores
 
- 
setNotBeforeForUserDescription copied from interface:UserProviderSets the notBefore value for the given user- Specified by:
- setNotBeforeForUserin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- user- the user model
- notBefore- new value for notBefore
 
- 
getNotBeforeOfUserDescription copied from interface:UserProviderGets the notBefore value for the given user- Specified by:
- getNotBeforeOfUserin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- user- the user model
- Returns:
- the value of notBefore
 
- 
getUserByFederatedIdentityDescription copied from interface:UserProviderReturns a userModel that corresponds to the given socialLink.- Specified by:
- getUserByFederatedIdentityin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- socialLink- the socialLink
- Returns:
- the user corresponding to socialLink and nullif no such user exists
 
- 
getServiceAccountDescription copied from interface:UserProviderReturn a UserModel representing service account of the client- Specified by:
- getServiceAccountin interface- UserProvider
- Parameters:
- client- the client model
- Returns:
- userModel representing service account of the client
 
- 
getFederatedIdentitiesStreampublic Stream<FederatedIdentityModel> getFederatedIdentitiesStream(RealmModel realm, UserModel user) Description copied from interface:UserProviderObtains the federated identities of the specified user.- Specified by:
- getFederatedIdentitiesStreamin interface- UserProvider
- Parameters:
- realm- a reference to the realm.
- user- the reference to the user.
- Returns:
- a non-null Streamof federated identities associated with the user.
 
- 
getFederatedIdentitypublic FederatedIdentityModel getFederatedIdentity(RealmModel realm, UserModel user, String socialProvider) Description copied from interface:UserProviderReturns details of the association between the user and the socialProvider.- Specified by:
- getFederatedIdentityin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- user- the user model
- socialProvider- the id of the identity provider
- Returns:
- federatedIdentityModel or nullif no association exists
 
- 
preRemoveDescription copied from interface:UserProviderCalled when a client is removed. Should remove all user consents associated with the client- Specified by:
- preRemovein interface- UserProvider
- Parameters:
- realm- a reference to the realm
- client- the client model
 
- 
preRemoveDescription copied from interface:UserProviderCalled when a protocolMapper is removed- Specified by:
- preRemovein interface- UserProvider
- Parameters:
- protocolMapper- the protocolMapper model
 
- 
preRemoveDescription copied from interface:UserProviderCalled when a client scope is removed. Should remove the clientScope from each user consent- Specified by:
- preRemovein interface- UserProvider
- Parameters:
- clientScope- the clientScope model
 
- 
preRemoveDescription copied from interface:UserProviderCalled when a component is removed. Should remove all data in UserStorage associated with removed component. For example,- if component corresponds to UserStorageProvider all imported users from the provider should be removed,
- if component corresponds to ClientStorageProvider all consents granted for clients imported from the provider should be removed
 - Specified by:
- preRemovein interface- UserProvider
- Parameters:
- realm- a reference to the realm
- component- the component model
 
- 
removeImportedUsersDescription copied from interface:UserProviderRemoves any imported users from a specific User Storage Provider.- Specified by:
- removeImportedUsersin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- storageProviderId- id of the user storage provider
 
- 
unlinkUsersDescription copied from interface:UserProviderSet federation link tonullto imported users of a specific User Storage Provider- Specified by:
- unlinkUsersin interface- UserProvider
- Parameters:
- realm- a reference to the realm
- storageProviderId- id of the storage provider
 
- 
closepublic void close()UserProvidermethods implementations end here
- 
onCreate- Specified by:
- onCreatein interface- OnCreateComponent
 
- 
onUpdatepublic void onUpdate(KeycloakSession session, RealmModel realm, ComponentModel oldModel, ComponentModel newModel) - Specified by:
- onUpdatein interface- OnUpdateComponent
 
- 
onCache- Specified by:
- onCachein interface- OnUserCache
 
- 
decorateUserProfileDescription copied from interface:UserProfileDecoratorDecorates user profile with additional metadata. For instance, metadata attributes, which are available just for your user-storage provider can be added there, so they are available just for the users coming from your provider. This method is invoked every time a user is being managed through a user profile provider. - Specified by:
- decorateUserProfilein interface- UserProfileDecorator
- Parameters:
- providerId- the id of the user storage provider to which the user is associated with
- metadata- the current- UserProfileMetadatafor the current realm
- Returns:
- a list of attribute metadata.The AttributeMetadatareturned from this method overrides any other metadata already set inmetadatafor a given attribute.
 
 
-