X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fcds-access-api%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Faccess%2Fconcepts%2FLocalHistoryIdentifier.java;h=7346ed0f0fffd94e3c69fac7e3d1a97c399ef756;hb=5f540931c1f8972b59e51556b6cba14b2c8f3f40;hp=330362e6aeccf11df77e798d1210c0d30f8c3fa2;hpb=104ce145c9cd637c9b1caecfe0fe02c4ce4f343c;p=controller.git diff --git a/opendaylight/md-sal/cds-access-api/src/main/java/org/opendaylight/controller/cluster/access/concepts/LocalHistoryIdentifier.java b/opendaylight/md-sal/cds-access-api/src/main/java/org/opendaylight/controller/cluster/access/concepts/LocalHistoryIdentifier.java index 330362e6ae..7346ed0f0f 100644 --- a/opendaylight/md-sal/cds-access-api/src/main/java/org/opendaylight/controller/cluster/access/concepts/LocalHistoryIdentifier.java +++ b/opendaylight/md-sal/cds-access-api/src/main/java/org/opendaylight/controller/cluster/access/concepts/LocalHistoryIdentifier.java @@ -9,62 +9,102 @@ package org.opendaylight.controller.cluster.access.concepts; import com.google.common.base.MoreObjects; import com.google.common.base.Preconditions; +import java.io.DataInput; +import java.io.DataOutput; import java.io.Externalizable; import java.io.IOException; import java.io.ObjectInput; import java.io.ObjectOutput; -import org.opendaylight.yangtools.concepts.Identifier; +import org.opendaylight.yangtools.concepts.WritableIdentifier; +import org.opendaylight.yangtools.concepts.WritableObjects; /** - * Globally-unique identifier of a local history. - * - * @param Frontend type + * Globally-unique identifier of a local history. This identifier is assigned on the frontend and is composed of + * - a {@link ClientIdentifier}, which uniquely identifies a single instantiation of a particular frontend + * - an unsigned long, which uniquely identifies the history on the backend + * - an unsigned long cookie, assigned by the client and meaningless on the backend, which just reflects it back * * @author Robert Varga */ -public final class LocalHistoryIdentifier implements Identifier { - private static final class Proxy implements Externalizable { +public final class LocalHistoryIdentifier implements WritableIdentifier { + /* + * Implementation note: cookie is currently required only for module-based sharding, which is implemented as part + * of normal DataBroker interfaces. For DOMDataTreeProducer cookie will always be zero, hence + * we may end up not needing cookie at all. + * + * We use WritableObjects.writeLongs() to output historyId and cookie (in that order). If we + * end up not needing the cookie at all, we can switch to writeLong() and use zero flags for + * compatibility. + */ + private static final class Proxy implements Externalizable { private static final long serialVersionUID = 1L; - private ClientIdentifier clientId; + private ClientIdentifier clientId; private long historyId; + private long cookie; + // checkstyle flags the public modifier as redundant however it is explicitly needed for Java serialization to + // be able to create instances via reflection. + @SuppressWarnings("checkstyle:RedundantModifier") public Proxy() { // For Externalizable } - Proxy(final ClientIdentifier frontendId, final long historyId) { + Proxy(final ClientIdentifier frontendId, final long historyId, final long cookie) { this.clientId = Preconditions.checkNotNull(frontendId); this.historyId = historyId; + this.cookie = cookie; } @Override public void writeExternal(final ObjectOutput out) throws IOException { - out.writeObject(clientId); - out.writeLong(historyId); + clientId.writeTo(out); + WritableObjects.writeLongs(out, historyId, cookie); } - @SuppressWarnings("unchecked") @Override - public void readExternal(final ObjectInput in) throws IOException, ClassNotFoundException { - clientId = (ClientIdentifier) in.readObject(); - historyId = in.readLong(); + public void readExternal(final ObjectInput in) throws IOException { + clientId = ClientIdentifier.readFrom(in); + + final byte header = WritableObjects.readLongHeader(in); + historyId = WritableObjects.readFirstLong(in, header); + cookie = WritableObjects.readSecondLong(in, header); } private Object readResolve() { - return new LocalHistoryIdentifier<>(clientId, historyId); + return new LocalHistoryIdentifier(clientId, historyId, cookie); } } private static final long serialVersionUID = 1L; - private final ClientIdentifier clientId; + private final ClientIdentifier clientId; private final long historyId; + private final long cookie; + + public LocalHistoryIdentifier(final ClientIdentifier frontendId, final long historyId) { + this(frontendId, historyId, 0); + } - public LocalHistoryIdentifier(final ClientIdentifier frontendId, final long historyId) { + public LocalHistoryIdentifier(final ClientIdentifier frontendId, final long historyId, final long cookie) { this.clientId = Preconditions.checkNotNull(frontendId); this.historyId = historyId; + this.cookie = cookie; + } + + public static LocalHistoryIdentifier readFrom(final DataInput in) throws IOException { + final ClientIdentifier clientId = ClientIdentifier.readFrom(in); + + final byte header = WritableObjects.readLongHeader(in); + return new LocalHistoryIdentifier(clientId, WritableObjects.readFirstLong(in, header), + WritableObjects.readSecondLong(in, header)); + } + + @Override + public void writeTo(final DataOutput out) throws IOException { + clientId.writeTo(out); + WritableObjects.writeLongs(out, historyId, cookie); } - public ClientIdentifier getClienId() { + public ClientIdentifier getClientId() { return clientId; } @@ -72,31 +112,39 @@ public final class LocalHistoryIdentifier implements Ide return historyId; } + public long getCookie() { + return cookie; + } + @Override public int hashCode() { - return clientId.hashCode() * 31 + Long.hashCode(historyId); + int ret = clientId.hashCode(); + ret = 31 * ret + Long.hashCode(historyId); + ret = 31 * ret + Long.hashCode(cookie); + return ret; } @Override - public boolean equals(final Object o) { - if (this == o) { + public boolean equals(final Object obj) { + if (this == obj) { return true; } - if (!(o instanceof LocalHistoryIdentifier)) { + if (!(obj instanceof LocalHistoryIdentifier)) { return false; } - final LocalHistoryIdentifier other = (LocalHistoryIdentifier) o; - return historyId == other.historyId && clientId.equals(other.clientId); + final LocalHistoryIdentifier other = (LocalHistoryIdentifier) obj; + return historyId == other.historyId && cookie == other.cookie && clientId.equals(other.clientId); } @Override public String toString() { return MoreObjects.toStringHelper(LocalHistoryIdentifier.class).add("client", clientId) - .add("history", Long.toUnsignedString(historyId)).toString(); + .add("history", Long.toUnsignedString(historyId, 16)) + .add("cookie", Long.toUnsignedString(cookie, 16)).toString(); } private Object writeReplace() { - return new Proxy<>(clientId, historyId); + return new Proxy(clientId, historyId, cookie); } }