Class RelationRegistryImpl
java.lang.Object
com.evolveum.midpoint.schema.relation.RelationRegistryImpl
- All Implemented Interfaces:
RelationRegistry
- Author:
- semancik
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
applyRelationsConfiguration
(SystemConfigurationType systemConfiguration) This method should be called whenever midPoint determines that the relations definition in system configuration might have been changed.@NotNull Collection<QName>
getAliases
(QName relation) Returns aliases of a relation.@NotNull Collection<QName>
Returns all relations of a given kind.Returns the default relation i.e.Returns the default relation for a given kind.getRelationDefinition
(QName relation) Returns a relation definition for a specified relation name.Returns all relation definitions: explicitly specified as well as built-in ones.boolean
isAutomaticallyMatched
(QName relation) Whether this kind of relations is automatically matched by order constraints.boolean
Checks whether the relation is equivalent to the default one.boolean
isOfKind
(QName relation, RelationKindType kind) Returns true if the relation is of specified kind.boolean
isProcessedOnLogin
(QName relation) Whether this kind of relations is processed on login.boolean
isProcessedOnRecompute
(QName relation) Whether this kind of relations is processed on recompute.boolean
isStoredIntoParentOrgRef
(QName relation) Whether this kind of relations is stored in parentOrgRef.@NotNull QName
normalizeRelation
(QName relation) Returns a normalized relation name, i.e.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface com.evolveum.midpoint.schema.RelationRegistry
isApprover, isDelegation, isManager, isMember, isMeta, isOwner
-
Constructor Details
-
RelationRegistryImpl
public RelationRegistryImpl()
-
-
Method Details
-
applyRelationsConfiguration
Description copied from interface:RelationRegistry
This method should be called whenever midPoint determines that the relations definition in system configuration might have been changed.- Specified by:
applyRelationsConfiguration
in interfaceRelationRegistry
-
getRelationDefinitions
Description copied from interface:RelationRegistry
Returns all relation definitions: explicitly specified as well as built-in ones. Invalid or duplicate definitions are filtered out and not mentioned here. Each relation is listed only once even if it can be referenced using various QNames (e.g. null, default, org:default).- Specified by:
getRelationDefinitions
in interfaceRelationRegistry
-
getRelationDefinition
Description copied from interface:RelationRegistry
Returns a relation definition for a specified relation name. The relation name need not be normalized, i.e. all names for a relation might be used here (e.g. null, default, org:default); resulting in the same definition. Returns null if the definition cannot be found.- Specified by:
getRelationDefinition
in interfaceRelationRegistry
-
isOfKind
Description copied from interface:RelationRegistry
Returns true if the relation is of specified kind. The relation name need not be normalized.- Specified by:
isOfKind
in interfaceRelationRegistry
-
isProcessedOnLogin
Description copied from interface:RelationRegistry
Whether this kind of relations is processed on login. By default, only relations of MEMBER and DELEGATION kinds are.- Specified by:
isProcessedOnLogin
in interfaceRelationRegistry
-
isProcessedOnRecompute
Description copied from interface:RelationRegistry
Whether this kind of relations is processed on recompute. By default, only relations of MEMBER, MANAGER and DELEGATION kinds are.- Specified by:
isProcessedOnRecompute
in interfaceRelationRegistry
-
isStoredIntoParentOrgRef
Description copied from interface:RelationRegistry
Whether this kind of relations is stored in parentOrgRef. By default, only relations of MEMBER kind are.- Specified by:
isStoredIntoParentOrgRef
in interfaceRelationRegistry
-
isAutomaticallyMatched
Description copied from interface:RelationRegistry
Whether this kind of relations is automatically matched by order constraints. By default, only relations of MEMBER, META and DELEGATION kinds are.- Specified by:
isAutomaticallyMatched
in interfaceRelationRegistry
-
getDefaultRelationFor
Description copied from interface:RelationRegistry
Returns the default relation for a given kind. The result might be a null value; although it is a bad practice to configure midPoint in that way. Unused relations are better hidden using categories.- Specified by:
getDefaultRelationFor
in interfaceRelationRegistry
-
getAllRelationsFor
Description copied from interface:RelationRegistry
Returns all relations of a given kind. Note that the result might be an empty set; although it is a bad practice to configure midPoint in that way. Unused relations are better hidden using categories.- Specified by:
getAllRelationsFor
in interfaceRelationRegistry
-
getDefaultRelation
Description copied from interface:RelationRegistry
Returns the default relation i.e. the one that is equivalent to the null relation name. Please do NOT use this information for queries nor determining the behavior of the relation! Use relation kinds instead.- Specified by:
getDefaultRelation
in interfaceRelationRegistry
-
normalizeRelation
Description copied from interface:RelationRegistry
Returns a normalized relation name, i.e. the one that is used in the "ref" item on the definition. It should be qualified (so please DO NOT use unqualified relation names in the definitions!) Returns default relation for null input, never returns null. If the relation is unknown, the relation name is returned unchanged.- Specified by:
normalizeRelation
in interfaceRelationRegistry
-
isDefault
Description copied from interface:RelationRegistry
Checks whether the relation is equivalent to the default one. Please do NOT use this information for determining the behavior of the relation! Use relation kinds instead.- Specified by:
isDefault
in interfaceRelationRegistry
-
getAliases
Description copied from interface:RelationRegistry
Returns aliases of a relation. Currently these are: - unqualified version of the relation QName - null if the relation is the default one -- In the future we might return some other values (e.g. explicitly configured aliases) as well. But we would need to adapt prismContext.relationsEquivalent method and other comparison methods as well. So it is perhaps not worth the effort.- Specified by:
getAliases
in interfaceRelationRegistry
-