Package org.keycloak.models.session
Interface UserSessionPersisterProvider
- All Superinterfaces:
Provider
- All Known Implementing Classes:
DisabledUserSessionPersisterProvider,JpaUserSessionPersisterProvider
- Author:
- Marek Posolda
-
Method Summary
Modifier and TypeMethodDescriptionvoidcreateClientSession(AuthenticatedClientSessionModel clientSession, boolean offline) voidcreateUserSession(UserSessionModel userSession, boolean offline) intgetUserSessionsCount(boolean offline) Retrieves the count of user sessions for all realms.intgetUserSessionsCount(RealmModel realm, ClientModel clientModel, boolean offline) Retrieves the count of user client-sessions for the given clientgetUserSessionsCountsByClients(RealmModel realm, boolean offline) Returns aMapcontaining the number of user-sessions aggregated by client id for the given realm.loadClientSession(RealmModel realm, ClientModel client, UserSessionModel userSession, boolean offline) Loads client session from the db by provided user session and client.loadUserSession(RealmModel realm, String userSessionId, boolean offline) Loads the user session with the given userSessionId.loadUserSessionsStream(Integer firstResult, Integer maxResults, boolean offline, String lastUserSessionId) Called during startup.loadUserSessionsStream(RealmModel realm, ClientModel client, boolean offline, Integer firstResult, Integer maxResults) Loads the user sessions for the givenClientModelin the givenRealmModelif present.loadUserSessionsStream(RealmModel realm, UserModel user, boolean offline, Integer firstResult, Integer maxResults) Loads the user sessions for the givenUserModelin the givenRealmModelif present.voidonClientRemoved(RealmModel realm, ClientModel client) voidonRealmRemoved(RealmModel realm) voidonUserRemoved(RealmModel realm, UserModel user) voidremoveClientSession(String userSessionId, String clientUUID, boolean offline) voidremoveExpired(RealmModel realm) voidremoveUserSession(String userSessionId, boolean offline) voidupdateLastSessionRefreshes(RealmModel realm, int lastSessionRefresh, Collection<String> userSessionIds, boolean offline)
-
Method Details
-
createUserSession
-
createClientSession
-
removeUserSession
-
removeClientSession
-
onRealmRemoved
-
onClientRemoved
-
onUserRemoved
-
updateLastSessionRefreshes
void updateLastSessionRefreshes(RealmModel realm, int lastSessionRefresh, Collection<String> userSessionIds, boolean offline) -
removeExpired
-
loadUserSession
Loads the user session with the given userSessionId.- Parameters:
userSessionId-offline-- Returns:
-
loadUserSessionsStream
Stream<UserSessionModel> loadUserSessionsStream(RealmModel realm, UserModel user, boolean offline, Integer firstResult, Integer maxResults) Loads the user sessions for the givenUserModelin the givenRealmModelif present.- Parameters:
realm-user-offline-firstResult-maxResults-- Returns:
-
loadUserSessionsStream
Stream<UserSessionModel> loadUserSessionsStream(RealmModel realm, ClientModel client, boolean offline, Integer firstResult, Integer maxResults) Loads the user sessions for the givenClientModelin the givenRealmModelif present.- Parameters:
realm-client-offline-firstResult-maxResults-- Returns:
-
loadUserSessionsStream
Stream<UserSessionModel> loadUserSessionsStream(Integer firstResult, Integer maxResults, boolean offline, String lastUserSessionId) Called during startup. For each userSession, it loads also clientSessions.- Parameters:
firstResult-IntegerIndex of the first desired user session. Ignored if negative ornull.maxResults-IntegerMaximum number of returned user sessions. Ignored if negative ornull.offline-booleanFlag to include offline sessions.lastUserSessionId-StringId of the user session. It will return only user sessions with id's lexicographically greater than this. it will compare the id in dictionary order and takes only those created later.- Returns:
- Stream of
UserSessionModel. Never returnsnull.
-
loadClientSession
AuthenticatedClientSessionModel loadClientSession(RealmModel realm, ClientModel client, UserSessionModel userSession, boolean offline) Loads client session from the db by provided user session and client.- Parameters:
realm- RealmModel Realm for the associated client session.client- ClientModel Client used for the creation of client session.userSession- UserSessionModel User session for the associated client session.offline- boolean Flag that indicates the client session should be online/offline.- Returns:
- Client session according the provided criteria or
nullif not found.
-
getUserSessionsCount
int getUserSessionsCount(boolean offline) Retrieves the count of user sessions for all realms.- Parameters:
offline-- Returns:
-
getUserSessionsCount
Retrieves the count of user client-sessions for the given client- Parameters:
realm-clientModel-offline-- Returns:
-
getUserSessionsCountsByClients
Returns aMapcontaining the number of user-sessions aggregated by client id for the given realm.- Parameters:
realm-offline-- Returns:
- the count
Mapwith clientId as key and session count as value
-