X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2Fmessages%2FVersionedExternalizableMessage.java;h=c809029a0fbe9c74e4fcd302eaf8e809cf009cd2;hb=4f5c7ef907bf086c966dfc6b1165eddbf34f5b8f;hp=2a660fa4b2ab0804b9bb91670bc0d2129c7f6d0e;hpb=6405fa8d6b47e406cdf566b26b15f980d802cad4;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/VersionedExternalizableMessage.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/VersionedExternalizableMessage.java index 2a660fa4b2..c809029a0f 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/VersionedExternalizableMessage.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/VersionedExternalizableMessage.java @@ -11,6 +11,9 @@ import java.io.Externalizable; import java.io.IOException; import java.io.ObjectInput; import java.io.ObjectOutput; +import org.eclipse.jdt.annotation.NonNull; +import org.opendaylight.controller.cluster.datastore.DataStoreVersions; +import org.opendaylight.controller.cluster.datastore.node.utils.stream.NormalizedNodeStreamVersion; /** * Abstract base class for a versioned Externalizable message. @@ -20,26 +23,46 @@ import java.io.ObjectOutput; public abstract class VersionedExternalizableMessage implements Externalizable, SerializableMessage { private static final long serialVersionUID = 1L; - private short version; + private short version = DataStoreVersions.CURRENT_VERSION; public VersionedExternalizableMessage() { } - public VersionedExternalizableMessage(short version) { - this.version = version; + public VersionedExternalizableMessage(final short version) { + this.version = version <= DataStoreVersions.CURRENT_VERSION ? version : DataStoreVersions.CURRENT_VERSION; } public short getVersion() { return version; } + protected final @NonNull NormalizedNodeStreamVersion getStreamVersion() { + return version < DataStoreVersions.NEON_SR2_VERSION + ? NormalizedNodeStreamVersion.LITHIUM : NormalizedNodeStreamVersion.NEON_SR2; + } + @Override - public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException { + public void readExternal(final ObjectInput in) throws IOException, ClassNotFoundException { version = in.readShort(); } @Override - public void writeExternal(ObjectOutput out) throws IOException { + public void writeExternal(final ObjectOutput out) throws IOException { out.writeShort(version); } + + @Override + public final Object toSerializable() { + if (getVersion() < DataStoreVersions.BORON_VERSION) { + throw new UnsupportedOperationException("Versions prior to " + DataStoreVersions.BORON_VERSION + + " are not supported"); + } + + return this; + } + + @Override + public String toString() { + return getClass().getSimpleName() + " [version=" + getVersion() + "]"; + } }