package org.argeo.slc.process;\r
\r
+import java.io.Serializable;\r
import java.util.ArrayList;\r
+import java.util.Date;\r
import java.util.List;\r
import java.util.Map;\r
import java.util.TreeMap;\r
\r
-public class SlcExecution {\r
+public class SlcExecution implements Serializable {\r
+ private static final long serialVersionUID = 1L;\r
+ public final static String STATUS_NONE = "DEFAULT";\r
public final static String STATUS_SCHEDULED = "SCHEDULED";\r
public final static String STATUS_RUNNING = "RUNNING";\r
public final static String STATUS_FINISHED = "FINISHED";\r
private String host;\r
private String user;\r
private String type;\r
- private String status;\r
+ private String status = STATUS_NONE;\r
private Map<String, String> attributes = new TreeMap<String, String>();\r
\r
+ /** TODO: Synchronize */\r
private List<SlcExecutionStep> steps = new ArrayList<SlcExecutionStep>();\r
+ private List<RealizedFlow> realizedFlows = new ArrayList<RealizedFlow>();\r
+\r
+ public List<RealizedFlow> getRealizedFlows() {\r
+ return realizedFlows;\r
+ }\r
+\r
+ public void setRealizedFlows(List<RealizedFlow> realizedFlows) {\r
+ this.realizedFlows = realizedFlows;\r
+ }\r
\r
public List<SlcExecutionStep> getSteps() {\r
return steps;\r
}\r
\r
public SlcExecutionStep currentStep() {\r
- if (steps.size() > 0)\r
- return steps.get(steps.size() - 1);\r
- else\r
- return null;\r
+ synchronized (steps) {\r
+ if (steps.size() > 0)\r
+ return steps.get(steps.size() - 1);\r
+ else\r
+ return null;\r
+ }\r
}\r
\r
@Override\r
buf.append(" attributes=").append(attributes);\r
return buf.toString();\r
}\r
+\r
+ public Date getStartDate() {\r
+ synchronized (steps) {\r
+ if (steps.size() == 0)\r
+ return null;\r
+ else\r
+ return steps.get(0).getBegin();\r
+ }\r
+ }\r
+\r
+ public Date getEndDate() {\r
+ if (!status.equals(STATUS_FINISHED) && !status.equals(STATUS_ERROR))\r
+ return null;\r
+\r
+ synchronized (steps) {\r
+ if (steps.size() == 0)\r
+ return null;\r
+ else\r
+ return steps.get(steps.size() - 1).getBegin();\r
+ }\r
+ }\r
}\r