Class DITCacheMap<T>
- java.lang.Object
-
- java.util.AbstractMap<Dn,T>
-
- org.opends.server.api.DITCacheMap<T>
-
- Type Parameters:
T
- arbitrary object type.
public final class DITCacheMap<T> extends AbstractMap<Dn,T>
The DITCacheMap class implements custom Map for structural storage of arbitrary objects in Directory Information Tree (DIT) like structure.This Map intended usage is for caching various server objects which can be subject to subtree operations like retrieval or removal of all objects under a specific DN. While using a regular Map it would require the entire Map iteration to achieve, this Map implementation maintains such internal structure that subtree operations are more efficient and do not require iterations over the entire map, instead additional subtree operations methods are provided by this Map to do just that.
API wise it behaves exactly like a regular Map implementation except for providing additional subtree methods. All required linkage and structuring is performed within this Map implementation itself and not exposed via the API in any way. For example, putting these key/value pairs:
cn=Object1,ou=Objects,dc=example,dc=com : object1 cn=Object2,ou=Objects,dc=example,dc=com : object2 cn=Object3,ou=Objects,dc=example,dc=com : object3
then invoking a subtree method on this Map with any of these keys:ou=Objects,dc=example,dc=com dc=example,dc=com dc=com
would bring all three objects previously stored in this map into subtree operation scope. Standard Map API methods can only work with the objects previously stored in this map explicitly.Note that this Map implementation is not synchronized.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class java.util.AbstractMap
AbstractMap.SimpleEntry<K extends Object,V extends Object>, AbstractMap.SimpleImmutableEntry<K extends Object,V extends Object>
-
-
Constructor Summary
Constructors Constructor Description DITCacheMap()
Default constructor.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Iterator<Map.Entry<Dn,T>>
childrenIterator(Dn baseDn)
Returns a filtered-view of this map containing only the immediate children of base-dn.void
clear()
boolean
containsKey(Object key)
boolean
containsSubtree(Dn key)
Returnstrue
if there are stored objects associated with the subtree having the provided base DN.boolean
containsValue(Object value)
Set<Map.Entry<Dn,T>>
entrySet()
T
get(Object key)
Dn
getBaseDn(Dn entryDn)
Find the Base DN of the provided DN.List<Dn>
getChildrenDns(Dn key, long maxNumberOfChildren)
Returns the list of the children's DNs, size bounded.Collection<T>
getSubtreeValues(Dn key)
Returns values from the stored objects associated with the subtree having the provided base DN.boolean
hasChildren(Dn key)
Returnstrue
if there are objects below the DN, excluding the DN itself.boolean
isEmpty()
T
put(Dn key, T value)
void
putAll(Map<? extends Dn,? extends T> m)
T
remove(Object key)
boolean
removeSubtree(Dn key, Collection<? super T> removedValues)
Removes the stored objects associated with the subtree having the provided base DN.int
size()
-
Methods inherited from class java.util.AbstractMap
clone, equals, hashCode, keySet, toString, values
-
Methods inherited from class java.lang.Object
finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface java.util.Map
compute, computeIfAbsent, computeIfPresent, forEach, getOrDefault, merge, putIfAbsent, remove, replace, replace, replaceAll
-
-
-
-
Method Detail
-
size
public int size()
-
isEmpty
public boolean isEmpty()
-
containsKey
public boolean containsKey(Object key)
- Specified by:
containsKey
in interfaceMap<Dn,T>
- Overrides:
containsKey
in classAbstractMap<Dn,T>
-
containsValue
public boolean containsValue(Object value)
- Specified by:
containsValue
in interfaceMap<Dn,T>
- Overrides:
containsValue
in classAbstractMap<Dn,T>
-
getBaseDn
public Dn getBaseDn(Dn entryDn)
Find the Base DN of the provided DN.- Parameters:
entryDn
- The DN of the entry for which to retrieve the corresponding base DN.- Returns:
- The base DN if found,
null
otherwise.
-
childrenIterator
public Iterator<Map.Entry<Dn,T>> childrenIterator(Dn baseDn)
Returns a filtered-view of this map containing only the immediate children of base-dn.- Parameters:
baseDn
- The base-dn- Returns:
- A read-only
Iterator
on this map returning only immediate children of baseDn. InvokingIterator.remove()
will throw anUnsupportedOperationException
.
-
getSubtreeValues
public Collection<T> getSubtreeValues(Dn key)
Returns values from the stored objects associated with the subtree having the provided base DN.- Parameters:
key
- subtree DN.- Returns:
- values from the stored objects associated with the subtree having the provided base DN
-
getChildrenDns
public List<Dn> getChildrenDns(Dn key, long maxNumberOfChildren)
Returns the list of the children's DNs, size bounded. To return the whole list,maxNumberOfChildren
should be 0.- Parameters:
key
- the parent DNmaxNumberOfChildren
- the maximum number of children to return, 0 for all- Returns:
- the list of children dn
-
hasChildren
public boolean hasChildren(Dn key)
Returnstrue
if there are objects below the DN, excluding the DN itself.- Parameters:
key
- subtree DN- Returns:
true
if there are objects below the DN, excluding the DN itself
-
containsSubtree
public boolean containsSubtree(Dn key)
Returnstrue
if there are stored objects associated with the subtree having the provided base DN.- Parameters:
key
- the subtree DN.- Returns:
true
if there are stored objects associated with the subtree having the provided base DN
-
removeSubtree
public boolean removeSubtree(Dn key, Collection<? super T> removedValues)
Removes the stored objects associated with the subtree having the provided base DN.- Parameters:
key
- subtree DN.removedValues
- Collection in which to put the removed elements, ornull
.- Returns:
true
if the map changed as a result of calling this method,false
otherwise.
-
clear
public void clear()
-
-