+++ /dev/null
-/*
- * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-
-package org.opendaylight.controller.cluster.datastore.identifiers;
-
-import com.google.common.base.Preconditions;
-import org.opendaylight.controller.cluster.access.concepts.MemberName;
-
-public class TransactionIdentifier {
- protected static final String TX_SEPARATOR = "-txn-";
-
- private final MemberName memberName;
- private final long counter;
- private final long timestamp;
- private String stringRepresentation;
-
- public TransactionIdentifier(MemberName memberName, long counter) {
- this.memberName = Preconditions.checkNotNull(memberName, "memberName should not be null");
- this.counter = counter;
- this.timestamp = System.currentTimeMillis();
- }
-
- public String getChainId() {
- return "";
- }
-
- protected MemberName getMemberName() {
- return memberName;
- }
-
- protected long getCounter() {
- return counter;
- }
-
- protected long getTimestamp() {
- return timestamp;
- }
-
- public static TransactionIdentifier create(MemberName memberName, long counter) {
- return new TransactionIdentifier(memberName, counter);
- }
-
- @Override
- public boolean equals(Object o) {
- if (this == o) {
- return true;
- }
- if (o == null || getClass() != o.getClass()) {
- return false;
- }
-
- TransactionIdentifier that = (TransactionIdentifier) o;
-
- if (counter != that.counter) {
- return false;
- }
-
- if (timestamp != that.timestamp) {
- return false;
- }
-
- if (!memberName.equals(that.memberName)) {
- return false;
- }
-
- return true;
- }
-
- @Override
- public int hashCode() {
- int result = memberName.hashCode();
- result = 31 * result + (int) (counter ^ (counter >>> 32));
- result = 31 * result + (int)(timestamp ^ (timestamp >>> 32));
- return result;
- }
-
-
- @Override
- public String toString() {
- if(stringRepresentation == null) {
- stringRepresentation = new StringBuilder(memberName.getName().length() + TX_SEPARATOR.length() + 21).
- append(memberName.getName()).append(TX_SEPARATOR).append(counter).append('-').append(timestamp).toString();
- }
-
- return stringRepresentation;
- }
-
-}