Class ConcurrentHashMapStorage<K,V extends AbstractEntity & UpdatableEntity,M>
- java.lang.Object
- 
- org.keycloak.models.map.storage.chm.ConcurrentHashMapStorage<K,V,M>
 
- 
- All Implemented Interfaces:
- ConcurrentHashMapCrudOperations<V,M>,- MapStorage<V,M>
 - Direct Known Subclasses:
- SingleUseObjectConcurrentHashMapStorage
 
 public class ConcurrentHashMapStorage<K,V extends AbstractEntity & UpdatableEntity,M> extends Object implements MapStorage<V,M>, ConcurrentHashMapCrudOperations<V,M> It contains basic object CRUD operations as well as bulkread(org.keycloak.models.map.storage.QueryParameters)and bulkdelete(org.keycloak.models.map.storage.QueryParameters)operations, and operation for determining the number of the objects satisfying given criteria (getCount(org.keycloak.models.map.storage.QueryParameters)).- Author:
- hmlnarik
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected DeepClonerclonerprotected Map<SearchableModelField<? super M>,MapModelCriteriaBuilder.UpdatePredicatesFunc<K,V,M>>fieldPredicatesprotected StringKeyConverter<K>keyConverterprotected ConcurrentMap<K,V>store
 - 
Constructor SummaryConstructors Constructor Description ConcurrentHashMapStorage(Class<M> modelClass, StringKeyConverter<K> keyConverter, DeepCloner cloner)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description Vcreate(V value)Creates an object in the store.MapModelCriteriaBuilder<K,V,M>createCriteriaBuilder()MapKeycloakTransaction<V,M>createTransaction(KeycloakSession session)Creates aMapKeycloakTransactionobject that tracks a new transaction related to this storage.booleandelete(String key)Deletes object with the givenkeyfrom the storage, if exists, no-op otherwise.longdelete(QueryParameters<M> queryParameters)Deletes objects that match the given criteria.longgetCount(QueryParameters<M> queryParameters)Returns the number of objects satisfying givencriteriafrom the storage.StringKeyConverter<K>getKeyConverter()Vread(String key)Returns object with the givenkeyfrom the storage ornullif object does not exist.Stream<V>read(QueryParameters<M> queryParameters)Returns stream of objects satisfying givencriteriafrom the storage.Vupdate(V value)Updates the object with the key of thevalue's ID in the storage if it already exists.- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.keycloak.models.map.storage.chm.ConcurrentHashMapCrudOperationsdetermineKeyFromValue, exists, exists
 
- 
 
- 
- 
- 
Field Detail- 
storeprotected final ConcurrentMap<K,V extends AbstractEntity & UpdatableEntity> store 
 - 
fieldPredicatesprotected final Map<SearchableModelField<? super M>,MapModelCriteriaBuilder.UpdatePredicatesFunc<K,V extends AbstractEntity & UpdatableEntity,M>> fieldPredicates 
 - 
keyConverterprotected final StringKeyConverter<K> keyConverter 
 - 
clonerprotected final DeepCloner cloner 
 
- 
 - 
Constructor Detail- 
ConcurrentHashMapStoragepublic ConcurrentHashMapStorage(Class<M> modelClass, StringKeyConverter<K> keyConverter, DeepCloner cloner) 
 
- 
 - 
Method Detail- 
createpublic V create(V value) Description copied from interface:ConcurrentHashMapCrudOperationsCreates an object in the store. ID of thevaluemay be prescribed in id of thevalue. If the id isnullor its format is not matching the store internal format for ID, then thevalue's ID will be generated and returned in the id of the return value.- Specified by:
- createin interface- ConcurrentHashMapCrudOperations<K,V extends AbstractEntity & UpdatableEntity>
- Parameters:
- value- Entity to create in the store
- Returns:
- Entity representing the valuein the store. It may or may not be the same instance asvalue
- See Also:
- AbstractEntity.getId()
 
 - 
readpublic V read(String key) Description copied from interface:ConcurrentHashMapCrudOperationsReturns object with the givenkeyfrom the storage ornullif object does not exist.
 IfVimplementsExpirableEntitythis method should not return entities that are expired. SeeExpirableEntityJavaDoc for more details. TODO: Consider returningOptional<V>instead.- Specified by:
- readin interface- ConcurrentHashMapCrudOperations<K,V extends AbstractEntity & UpdatableEntity>
- Parameters:
- key- Key of the object. Must not be- null.
- Returns:
- See description
 
 - 
updatepublic V update(V value) Description copied from interface:ConcurrentHashMapCrudOperationsUpdates the object with the key of thevalue's ID in the storage if it already exists.- Specified by:
- updatein interface- ConcurrentHashMapCrudOperations<K,V extends AbstractEntity & UpdatableEntity>
- Parameters:
- value- Updated value
- Returns:
- the previous value associated with the specified key, or null if there was no mapping for the key. (A null return can also indicate that the map previously associated null with the key, if the implementation supports null values.)
- See Also:
- AbstractEntity.getId()
 
 - 
deletepublic boolean delete(String key) Description copied from interface:ConcurrentHashMapCrudOperationsDeletes object with the givenkeyfrom the storage, if exists, no-op otherwise.- Specified by:
- deletein interface- ConcurrentHashMapCrudOperations<K,V extends AbstractEntity & UpdatableEntity>
- Returns:
- Returns trueif the object has been deleted or result cannot be determined,falseotherwise.
 
 - 
deletepublic long delete(QueryParameters<M> queryParameters) Description copied from interface:ConcurrentHashMapCrudOperationsDeletes objects that match the given criteria.- Specified by:
- deletein interface- ConcurrentHashMapCrudOperations<K,V extends AbstractEntity & UpdatableEntity>
- Parameters:
- queryParameters- parameters for the query like firstResult, maxResult, requested ordering, etc.
- Returns:
- Number of removed objects (might return -1if not supported)
 
 - 
createTransactionpublic MapKeycloakTransaction<V,M> createTransaction(KeycloakSession session) Description copied from interface:MapStorageCreates aMapKeycloakTransactionobject that tracks a new transaction related to this storage. In case of JPA or similar, the transaction object might be supplied by the container (via JTA) or shared same across storages accessing the same database within the same session; in other cases (e.g. plain map) a separate transaction handler might be created per each storage.- Specified by:
- createTransactionin interface- MapStorage<K,V extends AbstractEntity & UpdatableEntity>
- Returns:
- See description. Never returns null
 
 - 
createCriteriaBuilderpublic MapModelCriteriaBuilder<K,V,M> createCriteriaBuilder() 
 - 
getKeyConverterpublic StringKeyConverter<K> getKeyConverter() 
 - 
readpublic Stream<V> read(QueryParameters<M> queryParameters) Description copied from interface:ConcurrentHashMapCrudOperationsReturns stream of objects satisfying givencriteriafrom the storage. The criteria are specified in the given criteria builder based on model properties. IfVimplementsExpirableEntitythis method should not return entities that are expired. SeeExpirableEntityJavaDoc for more details.- Specified by:
- readin interface- ConcurrentHashMapCrudOperations<K,V extends AbstractEntity & UpdatableEntity>
- Parameters:
- queryParameters- parameters for the query like firstResult, maxResult, requested ordering, etc.
- Returns:
- Stream of objects. Never returns null.
 
 - 
getCountpublic long getCount(QueryParameters<M> queryParameters) Description copied from interface:ConcurrentHashMapCrudOperationsReturns the number of objects satisfying givencriteriafrom the storage. The criteria are specified in the given criteria builder based on model properties.- Specified by:
- getCountin interface- ConcurrentHashMapCrudOperations<K,V extends AbstractEntity & UpdatableEntity>
- Parameters:
- queryParameters- parameters for the query like firstResult, maxResult, requested ordering, etc.
- Returns:
- Number of objects. Never returns null.
 
 
- 
 
-