Package org.keycloak.models
Interface SingleUseObjectProvider
- All Superinterfaces:
- Provider
- All Known Implementing Classes:
- InfinispanSingleUseObjectProvider,- RemoteInfinispanSingleUseObjectProvider
Provides a cache to store data for single-use use case or the details about used action tokens.
- Author:
- Marek Posolda
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringSuffix to a key to indicate that token is considered revoked.
- 
Method SummaryModifier and TypeMethodDescriptionbooleanChecks if there is a record in the store for the given key.Gets data associated with the given key.voidStores the given data and guarantees that data should be available in the store for at least the time specified by parameterbooleanputIfAbsent(String key, long lifespanInSeconds) Will try to put the key into the cache.This method returns data just if removal was successful.booleanReplaces data associated with the given key in the store if the store contains the key.
- 
Field Details- 
REVOKED_KEYSuffix to a key to indicate that token is considered revoked. For revoked tokens, only the methodsput(java.lang.String, long, java.util.Map<java.lang.String, java.lang.String>)andcontains(java.lang.String)must be used.- See Also:
 
 
- 
- 
Method Details- 
putStores the given data and guarantees that data should be available in the store for at least the time specified by parameter- Parameters:
- key- String
- lifespanSeconds- Minimum lifespan for which successfully added key will be kept in the cache.
- notes- For revoked tokens, this must be an empty Map.
 
- 
getGets data associated with the given key.- Parameters:
- key- String
- Returns:
- Map<String, String> Data associated with the given key or nullif there is no associated data.
 
- 
removeThis 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 multi-site 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.- Parameters:
- key- String
- Returns:
- context data associated to the key. It returns nullif there are no context data available.
 
- 
replaceReplaces data associated with the given key in the store if the store contains the key.- Parameters:
- key- String
- notes- Map<String, String> New data to be stored
- Returns:
- trueif the store contains the key and data was replaced, otherwise- false.
 
- 
putIfAbsentWill try to put the key into the cache. It will succeed just if key is not already there.- Parameters:
- key-
- 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
 
- 
containsChecks if there is a record in the store for the given key.- Parameters:
- key- String
- Returns:
- trueif the record is present in the store,- falseotherwise.
 
 
-