Class InfinispanSingleUseObjectProvider
- java.lang.Object
- 
- org.keycloak.models.sessions.infinispan.InfinispanSingleUseObjectProvider
 
- 
- All Implemented Interfaces:
- SingleUseObjectProvider,- Provider
 
 public class InfinispanSingleUseObjectProvider extends Object implements SingleUseObjectProvider TODO: Check if Boolean can be used as single-use cache argument instead of SingleUseObjectValueEntity. With respect to other single-use cache usecases like "Revoke Refresh Token" . Also with respect to the usage of streams iterating over "actionTokens" cache (check there are no ClassCastExceptions when casting values directly to SingleUseObjectValueEntity)- Author:
- Marek Posolda
 
- 
- 
Field SummaryFields Modifier and Type Field Description static org.jboss.logging.Loggerlogger- 
Fields inherited from interface org.keycloak.models.SingleUseObjectProviderREVOKED_KEY
 
- 
 - 
Constructor SummaryConstructors Constructor Description InfinispanSingleUseObjectProvider(KeycloakSession session, Supplier<org.infinispan.commons.api.BasicCache<String,SingleUseObjectValueEntity>> singleUseObjectCache)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()booleancontains(String key)Checks if there is a record in the store for the given key.Map<String,String>get(String key)Gets data associated with the given key.voidput(String key, long lifespanSeconds, Map<String,String> notes)Stores the given data and guarantees that data should be available in the store for at least the time specified by {@param lifespanSeconds} parameterbooleanputIfAbsent(String key, long lifespanInSeconds)Will try to put the key into the cache.Map<String,String>remove(String key)This method returns data just if removal was successful.booleanreplace(String key, Map<String,String> notes)Replaces data associated with the given key in the store if the store contains the key.
 
- 
- 
- 
Constructor Detail- 
InfinispanSingleUseObjectProviderpublic InfinispanSingleUseObjectProvider(KeycloakSession session, Supplier<org.infinispan.commons.api.BasicCache<String,SingleUseObjectValueEntity>> singleUseObjectCache) 
 
- 
 - 
Method Detail- 
putpublic void put(String key, long lifespanSeconds, Map<String,String> notes) Description copied from interface:SingleUseObjectProviderStores the given data and guarantees that data should be available in the store for at least the time specified by {@param lifespanSeconds} parameter- Specified by:
- putin interface- SingleUseObjectProvider
 
 - 
getpublic Map<String,String> get(String key) Description copied from interface:SingleUseObjectProviderGets data associated with the given key.- Specified by:
- getin interface- SingleUseObjectProvider
- Parameters:
- key- String
- Returns:
- MapData associated with the given key or nullif there is no associated data.
 
 - 
removepublic Map<String,String> remove(String key) Description copied from interface:SingleUseObjectProviderThis method returns data just if removal was successful. Implementation should guarantee that "remove" is single-use. So if 2 threads (even on different cluster nodes or on different cross-dc nodes) calls "remove(123)" concurrently, then just one of them is allowed to succeed and return data back. It can't happen that both will succeed.- Specified by:
- removein interface- SingleUseObjectProvider
- Returns:
- context data associated to the key. It returns nullif there are no context data available.
 
 - 
replacepublic boolean replace(String key, Map<String,String> notes) Description copied from interface:SingleUseObjectProviderReplaces data associated with the given key in the store if the store contains the key.- Specified by:
- replacein interface- SingleUseObjectProvider
- Parameters:
- key- String
- notes- Map- New data to be stored 
- Returns:
- trueif the store contains the key and data was replaced, otherwise- false.
 
 - 
putIfAbsentpublic boolean putIfAbsent(String key, long lifespanInSeconds) Description copied from interface:SingleUseObjectProviderWill try to put the key into the cache. It will succeed just if key is not already there.- Specified by:
- putIfAbsentin interface- SingleUseObjectProvider
- lifespanInSeconds- Minimum lifespan for which successfully added key will be kept in the cache.
- Returns:
- true if the key was successfully put into the cache. This means that same key wasn't in the cache before
 
 - 
containspublic boolean contains(String key) Description copied from interface:SingleUseObjectProviderChecks if there is a record in the store for the given key.- Specified by:
- containsin interface- SingleUseObjectProvider
- Parameters:
- key- String
- Returns:
- trueif the record is present in the store,- falseotherwise.
 
 
- 
 
-