Add new cds-access-api proxies
[controller.git] / opendaylight / md-sal / cds-access-api / src / main / java / org / opendaylight / controller / cluster / access / commands / IncrementTransactionSequenceRequest.java
index 5e85316c413d75b9040355c4d10b65b334fab496..55a435beeec09d1a280940b8f9a45cd05741ad3d 100644 (file)
@@ -7,30 +7,55 @@
  */
 package org.opendaylight.controller.cluster.access.commands;
 
+import static com.google.common.base.Preconditions.checkArgument;
+
 import akka.actor.ActorRef;
-import com.google.common.base.Preconditions;
-import java.io.Serial;
+import java.io.IOException;
+import java.io.ObjectInput;
+import java.io.ObjectOutput;
 import org.opendaylight.controller.cluster.access.ABIVersion;
 import org.opendaylight.controller.cluster.access.concepts.TransactionIdentifier;
+import org.opendaylight.yangtools.concepts.WritableObjects;
 
 /**
  * A blank transaction request. This is used to provide backfill requests in converted retransmit scenarios, such as
  * when a initial request to a transaction (such as a {@link ReadTransactionRequest}) is satisfied by the backend
  * before the need to replay the transaction to a different remote backend.
- *
- * @author Robert Varga
  */
 public final class IncrementTransactionSequenceRequest extends
         AbstractReadTransactionRequest<IncrementTransactionSequenceRequest> {
-    @Serial
+    interface SerialForm extends AbstractReadTransactionRequest.SerialForm<IncrementTransactionSequenceRequest> {
+        @Override
+        default void writeExternal(final ObjectOutput out, final IncrementTransactionSequenceRequest msg)
+                throws IOException {
+            AbstractReadTransactionRequest.SerialForm.super.writeExternal(out, msg);
+            WritableObjects.writeLong(out, msg.getIncrement());
+        }
+
+        @Override
+        default IncrementTransactionSequenceRequest readExternal(final ObjectInput in,
+                final TransactionIdentifier target, final long sequence, final ActorRef replyTo,
+                final boolean snapshotOnly) throws IOException {
+            return new IncrementTransactionSequenceRequest(target, sequence, replyTo, snapshotOnly,
+                WritableObjects.readLong(in));
+        }
+    }
+
+    @java.io.Serial
     private static final long serialVersionUID = 1L;
 
     private final long increment;
 
+    public IncrementTransactionSequenceRequest(final IncrementTransactionSequenceRequest request,
+            final ABIVersion version) {
+        super(request, version);
+        increment = request.increment;
+    }
+
     public IncrementTransactionSequenceRequest(final TransactionIdentifier identifier, final long sequence,
             final ActorRef replyTo, final boolean snapshotOnly, final long increment) {
         super(identifier, sequence, replyTo, snapshotOnly);
-        Preconditions.checkArgument(increment >= 0);
+        checkArgument(increment >= 0, "Unexpected increment %s", increment);
         this.increment = increment;
     }
 
@@ -44,12 +69,12 @@ public final class IncrementTransactionSequenceRequest extends
     }
 
     @Override
-    protected IncrementTransactionSequenceRequestProxyV1 externalizableProxy(final ABIVersion version) {
-        return new IncrementTransactionSequenceRequestProxyV1(this);
+    protected SerialForm externalizableProxy(final ABIVersion version) {
+        return ABIVersion.MAGNESIUM.lt(version) ? new ITSR(this) : new IncrementTransactionSequenceRequestProxyV1(this);
     }
 
     @Override
     protected IncrementTransactionSequenceRequest cloneAsVersion(final ABIVersion targetVersion) {
-        return this;
+        return new IncrementTransactionSequenceRequest(this, targetVersion);
     }
 }