]> git.argeo.org Git - gpl/argeo-slc.git/blobdiff - runtime/org.argeo.slc.specs/src/main/java/org/argeo/slc/process/SlcExecution.java
Improve JCR DAO
[gpl/argeo-slc.git] / runtime / org.argeo.slc.specs / src / main / java / org / argeo / slc / process / SlcExecution.java
index 5e745a2f0d619a1ac8099516112abbd463d49480..88d37c4f581db65e5087463663b6380e9bf0f543 100644 (file)
@@ -2,12 +2,14 @@ package org.argeo.slc.process;
 \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 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
@@ -20,12 +22,16 @@ public class SlcExecution implements Serializable {
        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
+       /** Attachment uuid. */\r
+       private String realizedFlowsXml = null;\r
+\r
        public List<RealizedFlow> getRealizedFlows() {\r
                return realizedFlows;\r
        }\r
@@ -83,10 +89,12 @@ public class SlcExecution implements Serializable {
        }\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
@@ -117,4 +125,40 @@ public class SlcExecution implements Serializable {
                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
+       /**\r
+        * Not (yet) a stable API, should not be relied upon!\r
+        * \r
+        * @return an id or an url allowing to retrieve the XML, not the XML itself!\r
+        */\r
+       public String getRealizedFlowsXml() {\r
+               return realizedFlowsXml;\r
+       }\r
+\r
+       /** Not (yet) a stable API, should not be relied upon! */\r
+       public void setRealizedFlowsXml(String realizedFlowsXml) {\r
+               this.realizedFlowsXml = realizedFlowsXml;\r
+       }\r
+\r
 }\r