[8780cbec] | 1 | package com.nailabs.abac.process; |
---|
| 2 | |
---|
| 3 | import com.nailabs.abac.trust.*; |
---|
| 4 | import com.nailabs.abac.test.*; |
---|
| 5 | import java.util.*; |
---|
| 6 | |
---|
| 7 | /** |
---|
| 8 | * A linking soilution edge represents an edge in a trust target graph |
---|
| 9 | * between a <CODE>LinkingGoalNode</CODE> and it's solution children. |
---|
| 10 | */ |
---|
| 11 | public class LinkingSolutionEdge extends EdgeOperation { |
---|
| 12 | /** Default constructor */ |
---|
| 13 | public LinkingSolutionEdge() { |
---|
| 14 | super(); |
---|
| 15 | type = new String("LinkingSolution"); |
---|
| 16 | } |
---|
| 17 | |
---|
| 18 | /** Parsed element constructor */ |
---|
| 19 | public LinkingSolutionEdge(LinkingGoal parent, TrustTarget child, |
---|
| 20 | ProcessingState state) { |
---|
| 21 | super(parent, child, state, null); |
---|
| 22 | type = "LinkingSolution"; |
---|
| 23 | } |
---|
| 24 | |
---|
| 25 | public void performAdditional(TTG graph) { |
---|
| 26 | SimpleTTNode child = (SimpleTTNode)graph.getNodeByHash(getChild()); |
---|
| 27 | LinkingGoalNode parent = |
---|
| 28 | (LinkingGoalNode)graph.getNodeByHash(getParent()); |
---|
| 29 | |
---|
| 30 | parent.addChild(child); |
---|
| 31 | child.addLinkingSolutionParent(parent); |
---|
| 32 | } |
---|
| 33 | |
---|
| 34 | public void performNewAdditional(TTG graph) { |
---|
| 35 | TargetNode child = (TargetNode)graph.getNodeByHash(getChild()); |
---|
| 36 | if(child == null) { |
---|
| 37 | child = (TargetNode)TTGNode.createNode(getChild()); |
---|
| 38 | child.getProcessingState().update(state); |
---|
| 39 | graph.putNodeByHash(child); |
---|
| 40 | } |
---|
| 41 | performAdditional(graph); |
---|
| 42 | } |
---|
| 43 | |
---|
| 44 | } |
---|
| 45 | |
---|
| 46 | |
---|
| 47 | |
---|
| 48 | |
---|
| 49 | |
---|