Class MapSingleUseObjectProvider
java.lang.Object
org.keycloak.models.map.singleUseObject.MapSingleUseObjectProvider
- All Implemented Interfaces:
SingleUseObjectProvider
,Provider
- Author:
- Martin Kanis
-
Field Summary
Modifier and TypeFieldDescriptionprotected final MapStorage<MapSingleUseObjectEntity,
SingleUseObjectValueModel> Fields inherited from interface org.keycloak.models.SingleUseObjectProvider
REVOKED_KEY
-
Constructor Summary
ConstructorDescription -
Method Summary
Modifier and TypeMethodDescriptionvoid
close()
boolean
Checks if there is a record in the store for the given key.Gets data associated with the given key.void
Stores the given data and guarantees that data should be available in the store for at least the time specified by parameterboolean
putIfAbsent
(String key, long lifespanInSeconds) Will try to put the key into the cache.This method returns data just if removal was successful.boolean
Replaces data associated with the given key in the store if the store contains the key.
-
Field Details
-
singleUseObjectTx
-
-
Constructor Details
-
MapSingleUseObjectProvider
public MapSingleUseObjectProvider(MapStorage<MapSingleUseObjectEntity, SingleUseObjectValueModel> storage)
-
-
Method Details
-
put
Description copied from interface:SingleUseObjectProvider
Stores the given data and guarantees that data should be available in the store for at least the time specified by parameter- Specified by:
put
in interfaceSingleUseObjectProvider
-
get
Description copied from interface:SingleUseObjectProvider
Gets data associated with the given key.- Specified by:
get
in interfaceSingleUseObjectProvider
- Parameters:
key
- String- Returns:
- Map<String, String> Data associated with the given key or
null
if there is no associated data.
-
remove
Description copied from interface:SingleUseObjectProvider
This 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:
remove
in interfaceSingleUseObjectProvider
- Returns:
- context data associated to the key. It returns
null
if there are no context data available.
-
replace
Description copied from interface:SingleUseObjectProvider
Replaces data associated with the given key in the store if the store contains the key.- Specified by:
replace
in interfaceSingleUseObjectProvider
- Parameters:
key
- Stringnotes
- Map<String, String> New data to be stored- Returns:
true
if the store contains the key and data was replaced, otherwisefalse
.
-
putIfAbsent
Description copied from interface:SingleUseObjectProvider
Will try to put the key into the cache. It will succeed just if key is not already there.- Specified by:
putIfAbsent
in interfaceSingleUseObjectProvider
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
-
contains
Description copied from interface:SingleUseObjectProvider
Checks if there is a record in the store for the given key.- Specified by:
contains
in interfaceSingleUseObjectProvider
- Parameters:
key
- String- Returns:
true
if the record is present in the store,false
otherwise.
-
close
public void close()
-