Add JournalSegmentFile.map()
[controller.git] / opendaylight / md-sal / sal-akka-raft / src / main / java / org / opendaylight / controller / cluster / raft / base / messages / CaptureSnapshot.java
index bb86e1a37d9e1b1bb481dbcf78c48792d9ce312b..0fd48edf811923d5d96f7f2cb301a193f0da01a8 100644 (file)
@@ -8,18 +8,33 @@
 
 package org.opendaylight.controller.cluster.raft.base.messages;
 
-public class CaptureSnapshot {
-    private long lastAppliedIndex;
-    private long lastAppliedTerm;
-    private long lastIndex;
-    private long lastTerm;
-
-    public CaptureSnapshot(long lastIndex, long lastTerm,
-        long lastAppliedIndex, long lastAppliedTerm) {
+import akka.dispatch.ControlMessage;
+import java.util.Collections;
+import java.util.List;
+import org.opendaylight.controller.cluster.raft.ReplicatedLogEntry;
+
+public class CaptureSnapshot implements ControlMessage {
+    private final long lastAppliedIndex;
+    private final long lastAppliedTerm;
+    private final long lastIndex;
+    private final long lastTerm;
+    private final long replicatedToAllIndex;
+    private final long replicatedToAllTerm;
+    private final List<ReplicatedLogEntry> unAppliedEntries;
+    private final boolean mandatoryTrim;
+
+    public CaptureSnapshot(long lastIndex, long lastTerm, long lastAppliedIndex,
+            long lastAppliedTerm, long replicatedToAllIndex, long replicatedToAllTerm,
+            List<ReplicatedLogEntry> unAppliedEntries, boolean mandatoryTrim) {
         this.lastIndex = lastIndex;
         this.lastTerm = lastTerm;
         this.lastAppliedIndex = lastAppliedIndex;
         this.lastAppliedTerm = lastAppliedTerm;
+        this.replicatedToAllIndex = replicatedToAllIndex;
+        this.replicatedToAllTerm = replicatedToAllTerm;
+        this.unAppliedEntries = unAppliedEntries != null ? unAppliedEntries :
+            Collections.<ReplicatedLogEntry>emptyList();
+        this.mandatoryTrim = mandatoryTrim;
     }
 
     public long getLastAppliedIndex() {
@@ -37,4 +52,35 @@ public class CaptureSnapshot {
     public long getLastTerm() {
         return lastTerm;
     }
+
+    public long getReplicatedToAllIndex() {
+        return replicatedToAllIndex;
+    }
+
+    public long getReplicatedToAllTerm() {
+        return replicatedToAllTerm;
+    }
+
+    public List<ReplicatedLogEntry> getUnAppliedEntries() {
+        return unAppliedEntries;
+    }
+
+    public boolean isMandatoryTrim() {
+        return mandatoryTrim;
+    }
+
+    @Override
+    public String toString() {
+        return "CaptureSnapshot [lastAppliedIndex=" + lastAppliedIndex
+                + ", lastAppliedTerm=" + lastAppliedTerm
+                + ", lastIndex=" + lastIndex
+                + ", lastTerm=" + lastTerm
+                + ", installSnapshotInitiated="
+                + ", replicatedToAllIndex=" + replicatedToAllIndex
+                + ", replicatedToAllTerm=" + replicatedToAllTerm
+                + ", unAppliedEntries size=" + unAppliedEntries.size()
+                + ", mandatoryTrim=" + mandatoryTrim + "]";
+    }
+
+
 }