public abstract class GraphPolicy extends Object
| Modifier and Type | Class and Description |
|---|---|
static class |
GraphPolicy.Ability
Abilities that the user may have to operate upon model objects.
|
static class |
GraphPolicy.Action
The action to take on an object instance.
|
static class |
GraphPolicy.Details
A tuple noting the state of a mapped object instance in the current graph traversal.
|
static class |
GraphPolicy.Orphan
If an object instance has any
GraphPolicy.Action.EXCLUDEd parentsthat would prevent it from being orphaned. |
| Constructor and Description |
|---|
GraphPolicy() |
| Modifier and Type | Method and Description |
|---|---|
GraphPolicy |
getCleanInstance()
A stateful graph policy must override this method to provide a clone that has fresh state.
|
abstract boolean |
isCondition(String name)
Check if a condition has been set.
|
void |
noteDetails(org.hibernate.Session session,
ome.model.IObject object,
String realClass,
long id)
Any model object about which policy may be asked is first passed to
#noteDetails(IObject, String, long) before
#review(Map, Details, Map, Set). |
abstract Set<GraphPolicy.Details> |
review(Map<String,Set<GraphPolicy.Details>> linkedFrom,
GraphPolicy.Details rootObject,
Map<String,Set<GraphPolicy.Details>> linkedTo,
Set<String> notNullable,
boolean isErrorRules)
The action to take about the link between the mapped objects.
|
abstract void |
setCondition(String name)
Set a named condition,
|
public GraphPolicy getCleanInstance()
public abstract void setCondition(String name)
name - the name of the conditionpublic abstract boolean isCondition(String name)
name - the name of the conditionpublic void noteDetails(org.hibernate.Session session,
ome.model.IObject object,
String realClass,
long id)
#noteDetails(IObject, String, long) before
#review(Map, Details, Map, Set). Each object is passed only once.
Subclasses overriding this method probably ought also override getCleanInstance().session - the Hibernate session, for obtaining more information about the objectobject - a model object about which policy may be askedrealClass - the real class name of the objectid - the ID of the objectpublic abstract Set<GraphPolicy.Details> review(Map<String,Set<GraphPolicy.Details>> linkedFrom, GraphPolicy.Details rootObject, Map<String,Set<GraphPolicy.Details>> linkedTo, Set<String> notNullable, boolean isErrorRules) throws GraphException
GraphPolicy.Action.EXCLUDEd object, once changed from that, may not change back to GraphPolicy.Action.EXCLUDE.
An GraphPolicy.Action.OUTSIDE object, once changed to that, may not change back from GraphPolicy.Action.OUTSIDE.
GraphPolicy.Orphan values matter only for GraphPolicy.Action.EXCLUDEd objects.
Given GraphPolicy.Orphan.RELEVANT if Action#IS_LAST or Action#IS_NOT_LAST can be returned,
or could be if after GraphPolicy.Orphan.RELEVANT is returned then resolved for the other object,
then appropriate values should be returned accordingly.
If Action#RELEVANT is returned for an object then this method may be called again with
Action#IS_LAST or Action#IS_NOT_LAST.
Class properties' String representation is package.DeclaringClass.propertyName.linkedFrom - map from class property to objects for which the property links to the root objectrootObject - the object at the center of this reviewlinkedTo - map from class property to objects to which the property links from the root objectnotNullable - which properties from the linkedFrom and linkedTo map keys are not nullableisErrorRules - if final checks should be performed instead of normal rule matchingGraphException - if there was a problem in applying the policy
Version: 5.1.1-ice35-b43
Copyright © 2015 The University of Dundee & Open Microscopy Environment. All Rights Reserved.