Interface PrismValueDelegator
- All Superinterfaces:
ComplexCopyable<PrismValue>
,DebugDumpable
,Freezable
,MidpointOriginMetadata
,PathVisitable
,PrismValue
,PrismVisitable
,Revivable
,SchemaLookup.Aware
,Serializable
,Visitable
- All Known Subinterfaces:
PrismContainerValueDelegator<C>
,PrismObjectValueDelegator<O>
,PrismPropertyValueDelegator<T>
,PrismReferenceValueDelegator
- All Known Implementing Classes:
FlyweightClonedValue
,GenericLazyPrismContainerValue
-
Field Summary
Fields inherited from interface com.evolveum.midpoint.util.DebugDumpable
INDENT_STRING
-
Method Summary
Modifier and TypeMethodDescriptiondefault void
default void
default boolean
acceptVisitor
(PrismVisitor visitor) Accept visitor and visits prism item or value and it's children Note: name is not accept, but accept visitor to prevent naming conflict in lambdas dynamic languages such as groovy withVisitable.accept(com.evolveum.midpoint.prism.Visitor)
default PrismValue
applyDefinition
(@NotNull ItemDefinition<?> definition) Definition application MAY change the value (currently only for container values).default PrismValue
applyDefinition
(@NotNull ItemDefinition<?> definition, boolean force) Definition application MAY change the value (currently only for container values).default void
applyDefinitionLegacy
(@NotNull ItemDefinition<?> definition) This one checks that nothing has changed.default void
applyDefinitionLegacy
(@NotNull ItemDefinition<?> definition, boolean force) Definition application MAY change the value (currently only for container/reference values).default void
checkConsistenceInternal
(Itemable rootItem, boolean requireDefinitions, boolean prohibitRaw, ConsistencyCheckScope scope) default void
Used when we are removing the value from the previous parent.default PrismValue
clone()
Literal clone.default PrismValue
cloneComplex
(@NotNull CloneStrategy strategy) Complex clone with different cloning strategies.default @NotNull PrismValue
default PrismValue
default String
Show the content of the object intended for diagnostics by system administrator.default String
debugDump
(int indent) default Object
default Object
debugDumpLazily
(int indent) delegate()
default void
default Collection<? extends ItemDelta>
diff
(PrismValue otherValue, ParameterizedEquivalenceStrategy strategy) Assumes matching representations.default boolean
equals
(PrismValue otherValue, @NotNull EquivalenceStrategy strategy) default boolean
equals
(PrismValue otherValue, @NotNull ParameterizedEquivalenceStrategy strategy) default Object
default @NotNull Collection<Item<?,
?>> getAllItems
(@NotNull ItemPath path) default @NotNull Collection<PrismValue>
getAllValues
(ItemPath path) default <T> T
getNearestValueOfType
(@NotNull Class<T> type) default Objectable
default OriginType
default Itemable
default PrismContainerValue<?>
default @NotNull ItemPath
getPath()
default @Nullable Class<?>
default <T> T
Returns the statically-typed "real value".default @Nullable Object
default @Nullable Object
default @Nullable Objectable
Returns the top-most object (Objectable
).default @NotNull PrismValue
default SchemaContext
default QName
default Object
getUserData
(@NotNull String key) default @NotNull ValueMetadata
Returns the value metadata, creating empty one if there's none.default <C extends Containerable>
@NotNull PrismContainer<C>Returns value metadata as typed PrismContainer.default @Nullable ValueMetadata
Returns the value metadata, if there is any.default int
hashCode
(@NotNull EquivalenceStrategy equivalenceStrategy) default int
hashCode
(@NotNull ParameterizedEquivalenceStrategy equivalenceStrategy) default boolean
default boolean
default boolean
isEmpty()
default boolean
Returns `true` if this value represents aPrismObject
value.default boolean
Ignores untyped values (considers them non-matching).default boolean
isRaw()
default boolean
default void
Currently doing nothing.default void
Recompute the value or otherwise "initialize" it before adding it to a prism tree.default void
recompute
(PrismContext prismContext) default boolean
representsSameValue
(PrismValue other, EquivalenceStrategy strategy, boolean lax) Returns true if this and other value represent the same value.default SchemaLookup
default void
setOriginObject
(Objectable source) default void
setOriginType
(OriginType type) default void
default void
setTransient
(boolean value) default void
setUserData
(@NotNull String key, Object value) default void
setValueMetadata
(Containerable realValue) Sets metadata from this value (from PCV).default void
setValueMetadata
(PrismContainer<?> valueMetadata) Sets metadata for this value.default void
setValueMetadata
(ValueMetadata valueMetadata) Sets metadata for this value.default String
Methods inherited from interface com.evolveum.midpoint.prism.Freezable
checkImmutable, checkMutable, freeze, isImmutable
Methods inherited from interface com.evolveum.midpoint.prism.PrismValue
copy, immutableCopy, mutableCopy
-
Method Details
-
delegate
PrismValue delegate() -
getUserData
- Specified by:
getUserData
in interfacePrismValue
-
getUserData
- Specified by:
getUserData
in interfacePrismValue
-
setUserData
- Specified by:
setUserData
in interfacePrismValue
-
getParent
- Specified by:
getParent
in interfacePrismValue
-
setParent
- Specified by:
setParent
in interfacePrismValue
-
getValueMetadata
Description copied from interface:PrismValue
Returns the value metadata, creating empty one if there's none. When performance is critical, consider usingPrismValue.getValueMetadataIfExists()
instead; or callPrismValue.hasValueMetadata()
first.- Specified by:
getValueMetadata
in interfacePrismValue
-
getValueMetadataIfExists
Description copied from interface:PrismValue
Returns the value metadata, if there is any.- Specified by:
getValueMetadataIfExists
in interfacePrismValue
-
getValueMetadataAsContainer
@Experimental @NotNull default <C extends Containerable> @NotNull PrismContainer<C> getValueMetadataAsContainer()Description copied from interface:PrismValue
Returns value metadata as typed PrismContainer. Useful for lazy clients because of the type matching.- Specified by:
getValueMetadataAsContainer
in interfacePrismValue
-
hasValueMetadata
default boolean hasValueMetadata()- Specified by:
hasValueMetadata
in interfacePrismValue
- Returns:
- True if this value has any metadata (i.e. the metadata container has any value). TODO Or should we accept only non-empty values? Probably not.
-
setValueMetadata
Description copied from interface:PrismValue
Sets metadata for this value.- Specified by:
setValueMetadata
in interfacePrismValue
-
setValueMetadata
Description copied from interface:PrismValue
Sets metadata for this value.- Specified by:
setValueMetadata
in interfacePrismValue
-
setValueMetadata
Description copied from interface:PrismValue
Sets metadata from this value (from PCV). To be removed (most probably).- Specified by:
setValueMetadata
in interfacePrismValue
- Throws:
SchemaException
-
deleteValueMetadata
default void deleteValueMetadata()- Specified by:
deleteValueMetadata
in interfacePrismValue
-
getPath
- Specified by:
getPath
in interfacePrismValue
-
clearParent
default void clearParent()Description copied from interface:PrismValue
Used when we are removing the value from the previous parent. Or when we know that the previous parent will be discarded and we want to avoid unnecessary cloning.- Specified by:
clearParent
in interfacePrismValue
-
applyDefinition
default PrismValue applyDefinition(@NotNull @NotNull ItemDefinition<?> definition) throws SchemaException Description copied from interface:PrismValue
Definition application MAY change the value (currently only for container values). The caller must deal with that. To be seen if this is a good idea. But probably so, because there are various situations when the definition application changes the nature of a prism value (midPoint shadow associations are currently the only places) but of prism items (midPoint attributes and associations need this; and it must be worked around for now).- Specified by:
applyDefinition
in interfacePrismValue
- Throws:
SchemaException
-
applyDefinitionLegacy
default void applyDefinitionLegacy(@NotNull @NotNull ItemDefinition<?> definition) throws SchemaException Description copied from interface:PrismValue
This one checks that nothing has changed.- Specified by:
applyDefinitionLegacy
in interfacePrismValue
- Throws:
SchemaException
-
applyDefinition
default PrismValue applyDefinition(@NotNull @NotNull ItemDefinition<?> definition, boolean force) throws SchemaException Description copied from interface:PrismValue
Definition application MAY change the value (currently only for container values). The caller must deal with that.- Specified by:
applyDefinition
in interfacePrismValue
- Throws:
SchemaException
-
applyDefinitionLegacy
default void applyDefinitionLegacy(@NotNull @NotNull ItemDefinition<?> definition, boolean force) throws SchemaException Description copied from interface:PrismValue
Definition application MAY change the value (currently only for container/reference values). The caller must deal with that.- Specified by:
applyDefinitionLegacy
in interfacePrismValue
- Throws:
SchemaException
-
recompute
default void recompute()Description copied from interface:PrismValue
Recompute the value or otherwise "initialize" it before adding it to a prism tree. This may as well do nothing if no recomputing or initialization is needed.- Specified by:
recompute
in interfacePrismValue
-
recompute
- Specified by:
recompute
in interfacePrismValue
-
accept
- Specified by:
accept
in interfacePrismValue
- Specified by:
accept
in interfaceVisitable
-
accept
- Specified by:
accept
in interfacePathVisitable
- Specified by:
accept
in interfacePrismValue
-
checkConsistenceInternal
default void checkConsistenceInternal(Itemable rootItem, boolean requireDefinitions, boolean prohibitRaw, ConsistencyCheckScope scope) - Specified by:
checkConsistenceInternal
in interfacePrismValue
-
representsSameValue
Description copied from interface:PrismValue
Returns true if this and other value represent the same value. E.g. if they have the same IDs, OIDs or it is otherwise know that they "belong together" without a deep examination of the values.- Specified by:
representsSameValue
in interfacePrismValue
lax
- If we can reasonably assume that the two values belong together even if they don't have the same ID, e.g. if they both belong to single-valued parent items. This is useful e.g. when comparing multi-valued containers. But can cause problems when we want to be sure we are removing the correct value.
-
normalize
default void normalize()Description copied from interface:PrismValue
Currently doing nothing.- Specified by:
normalize
in interfacePrismValue
-
clone
Description copied from interface:PrismValue
Literal clone.- Specified by:
clone
in interfacePrismValue
-
createImmutableClone
- Specified by:
createImmutableClone
in interfacePrismValue
-
cloneComplex
Description copied from interface:PrismValue
Complex clone with different cloning strategies.- Specified by:
cloneComplex
in interfaceComplexCopyable<PrismValue>
- Specified by:
cloneComplex
in interfacePrismValue
- See Also:
-
hashCode
- Specified by:
hashCode
in interfacePrismValue
-
hashCode
- Specified by:
hashCode
in interfacePrismValue
-
equals
- Specified by:
equals
in interfacePrismValue
-
equals
default boolean equals(PrismValue otherValue, @NotNull @NotNull ParameterizedEquivalenceStrategy strategy) - Specified by:
equals
in interfacePrismValue
-
diff
default Collection<? extends ItemDelta> diff(PrismValue otherValue, ParameterizedEquivalenceStrategy strategy) Description copied from interface:PrismValue
Assumes matching representations. I.e. it assumes that both this and otherValue represent the same instance of item. E.g. the container with the same ID.- Specified by:
diff
in interfacePrismValue
-
getRealClass
- Specified by:
getRealClass
in interfacePrismValue
-
hasRealClass
- Specified by:
hasRealClass
in interfacePrismValue
-
getRealValue
@Nullable default <T> T getRealValue()Description copied from interface:PrismValue
Returns the statically-typed "real value". TODO specify when exactly the returned value can be null. TODO decide for containers: they throw an exception if the value is not statically typed.- Specified by:
getRealValue
in interfacePrismValue
-
getRealValueOrRawType
- Specified by:
getRealValueOrRawType
in interfacePrismValue
-
getRealValueIfExists
- Specified by:
getRealValueIfExists
in interfacePrismValue
-
getRootValue
- Specified by:
getRootValue
in interfacePrismValue
-
getRootObjectable
Description copied from interface:PrismValue
Returns the top-most object (Objectable
).- Specified by:
getRootObjectable
in interfacePrismValue
-
getNearestValueOfType
- Specified by:
getNearestValueOfType
in interfacePrismValue
-
getParentContainerValue
- Specified by:
getParentContainerValue
in interfacePrismValue
-
getTypeName
- Specified by:
getTypeName
in interfacePrismValue
-
getAllValues
Description copied from interface:PrismValue
- Specified by:
getAllValues
in interfacePrismValue
-
getAllItems
Description copied from interface:PrismValue
SeeItem.getAllItems(ItemPath)
. Here the path is never empty.- Specified by:
getAllItems
in interfacePrismValue
-
isRaw
default boolean isRaw()- Specified by:
isRaw
in interfacePrismValue
-
isEmpty
default boolean isEmpty()- Specified by:
isEmpty
in interfacePrismValue
-
toHumanReadableString
- Specified by:
toHumanReadableString
in interfacePrismValue
-
find
- Specified by:
find
in interfacePrismValue
-
isTransient
- Specified by:
isTransient
in interfacePrismValue
- Returns:
- True if the value is transient, so it won't be serialized if serialization of transient value is disabled.
-
setTransient
- Specified by:
setTransient
in interfacePrismValue
-
isOfType
Description copied from interface:PrismValue
Ignores untyped values (considers them non-matching). Supports non-static types. (May be slower.)- Specified by:
isOfType
in interfacePrismValue
-
cloneIfImmutable
- Specified by:
cloneIfImmutable
in interfacePrismValue
-
isObjectable
default boolean isObjectable()Description copied from interface:PrismValue
Returns `true` if this value represents aPrismObject
value. Temporary implementation that uses real value to do the check, asPrismObjectValue
can mask itself as aPrismContainerValue
, at least for now.- Specified by:
isObjectable
in interfacePrismValue
-
getSchemaContext
- Specified by:
getSchemaContext
in interfacePrismValue
-
schemaLookup
- Specified by:
schemaLookup
in interfacePrismValue
- Specified by:
schemaLookup
in interfaceSchemaLookup.Aware
-
acceptVisitor
Description copied from interface:PrismVisitable
Accept visitor and visits prism item or value and it's children Note: name is not accept, but accept visitor to prevent naming conflict in lambdas dynamic languages such as groovy withVisitable.accept(com.evolveum.midpoint.prism.Visitor)
- Specified by:
acceptVisitor
in interfacePrismValue
- Specified by:
acceptVisitor
in interfacePrismVisitable
- Returns:
- return value of
PrismVisitor.visit(PrismVisitable)
invocation for this visitable.
-
debugDump
Description copied from interface:DebugDumpable
Show the content of the object intended for diagnostics by system administrator. The out put should be suitable to use in system logs at "debug" level. It may be multi-line, but in that case it should be well indented and quite terse. As it is intended to be used by system administrator, it should not use any developer terms such as class names, exceptions or stack traces.- Specified by:
debugDump
in interfaceDebugDumpable
- Returns:
- content of the object intended for diagnostics by system administrator.
-
debugDump
- Specified by:
debugDump
in interfaceDebugDumpable
-
debugDumpLazily
- Specified by:
debugDumpLazily
in interfaceDebugDumpable
-
debugDumpLazily
- Specified by:
debugDumpLazily
in interfaceDebugDumpable
-
getOriginObject
- Specified by:
getOriginObject
in interfaceMidpointOriginMetadata
-
getOriginType
- Specified by:
getOriginType
in interfaceMidpointOriginMetadata
-
setOriginType
- Specified by:
setOriginType
in interfaceMidpointOriginMetadata
-
setOriginObject
- Specified by:
setOriginObject
in interfaceMidpointOriginMetadata
-