Package org.fuin.ddd4j.ddd
Class EntityIdPath
- java.lang.Object
-
- org.fuin.objects4j.vo.AbstractStringValueObject
-
- org.fuin.ddd4j.ddd.EntityIdPath
-
- All Implemented Interfaces:
Serializable,Comparable<org.fuin.objects4j.vo.AbstractStringValueObject>,org.fuin.objects4j.vo.AsStringCapable,org.fuin.objects4j.vo.ValueObject,org.fuin.objects4j.vo.ValueObjectWithBaseType<String>
public final class EntityIdPath extends org.fuin.objects4j.vo.AbstractStringValueObject implements Serializable
An ordered list of entity identifiers. An aggregate root will be the first entry if it's contained in the list.- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description static StringPATH_SEPARATORDivides the entity identifiers in the path.
-
Constructor Summary
Constructors Constructor Description EntityIdPath(List<EntityId> ids)Constructor with ID list.EntityIdPath(EntityId... entityIds)Constructor with ID array.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description StringasBaseType()<T extends EntityId>
Tfirst()Returns the first entity identifier in the path.Iterator<EntityId>iterator()Creates a NEW list of the entity identifiers contained in the entity id path and returns an iterator on it.<T extends EntityId>
Tlast()Returns the last entity identifier in the path.EntityIdPathparent()Returns the parent path without the last entry.EntityIdPathrest()Returns the path without the first entry.intsize()Returns the number of elements in the path.StringtoString()
-
-
-
Field Detail
-
PATH_SEPARATOR
public static final String PATH_SEPARATOR
Divides the entity identifiers in the path.- See Also:
- Constant Field Values
-
-
Constructor Detail
-
EntityIdPath
public EntityIdPath(EntityId... entityIds)
Constructor with ID array.- Parameters:
entityIds- Entity identifier in correct order (from outer to inner).
-
-
Method Detail
-
iterator
public final Iterator<EntityId> iterator()
Creates a NEW list of the entity identifiers contained in the entity id path and returns an iterator on it. This means deleting an element using theIterator.remove()method will NOT remove something from this entity id path.- Returns:
- Iterator on a new list instance.
-
first
public final <T extends EntityId> T first()
Returns the first entity identifier in the path.- Type Parameters:
T- Type of the entity identifier that is returned.- Returns:
- First entity identifier in the path.
-
last
public final <T extends EntityId> T last()
Returns the last entity identifier in the path.- Type Parameters:
T- Type of the entity identifier that is returned.- Returns:
- Last entity identifier in the path.
-
rest
public final EntityIdPath rest()
Returns the path without the first entry.- Returns:
- Rest or NULL if the path has only one element.
-
parent
public EntityIdPath parent()
Returns the parent path without the last entry.- Returns:
- Parent identifier path or NULL if this is an aggregate root ID.
-
size
public final int size()
Returns the number of elements in the path.- Returns:
- Number of identifiers contained in the path.
-
asBaseType
public final String asBaseType()
- Specified by:
asBaseTypein interfaceorg.fuin.objects4j.vo.ValueObjectWithBaseType<String>
-
-