import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
-import org.opendaylight.controller.cluster.datastore.DataStoreVersions;
-import org.opendaylight.controller.protobuff.messages.transaction.ShardTransactionMessages;
+import org.opendaylight.controller.cluster.access.concepts.TransactionIdentifier;
public class CreateTransaction extends VersionedExternalizableMessage {
private static final long serialVersionUID = 1L;
- private String transactionId;
+ private TransactionIdentifier transactionId;
private int transactionType;
- private String transactionChainId;
public CreateTransaction() {
}
- public CreateTransaction(String transactionId, int transactionType, String transactionChainId,
- short version) {
+ public CreateTransaction(TransactionIdentifier transactionId, int transactionType, short version) {
super(version);
this.transactionId = Preconditions.checkNotNull(transactionId);
this.transactionType = transactionType;
- this.transactionChainId = transactionChainId != null ? transactionChainId : "";
}
- public String getTransactionId() {
+ public TransactionIdentifier getTransactionId() {
return transactionId;
}
return transactionType;
}
- public String getTransactionChainId() {
- return transactionChainId;
- }
-
@Override
public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException {
super.readExternal(in);
- transactionId = in.readUTF();
+ transactionId = TransactionIdentifier.readFrom(in);
transactionType = in.readInt();
- transactionChainId = in.readUTF();
}
@Override
public void writeExternal(ObjectOutput out) throws IOException {
super.writeExternal(out);
- out.writeUTF(transactionId);
+ transactionId.writeTo(out);
out.writeInt(transactionType);
- out.writeUTF(transactionChainId);
- }
-
- @Override
- public Object toSerializable() {
- if(getVersion() >= DataStoreVersions.BORON_VERSION) {
- return this;
- } else {
- return ShardTransactionMessages.CreateTransaction.newBuilder()
- .setTransactionId(transactionId).setTransactionType(transactionType)
- .setTransactionChainId(transactionChainId).setMessageVersion(getVersion()).build();
- }
}
@Override
public String toString() {
- return "CreateTransaction [transactionId=" + transactionId + ", transactionType=" + transactionType
- + ", transactionChainId=" + transactionChainId + "]";
+ return "CreateTransaction [transactionId=" + transactionId + ", transactionType=" + transactionType + "]";
}
public static CreateTransaction fromSerializable(Object message) {
- if(message instanceof CreateTransaction) {
- return (CreateTransaction)message;
- } else {
- ShardTransactionMessages.CreateTransaction createTransaction =
- (ShardTransactionMessages.CreateTransaction) message;
- return new CreateTransaction(createTransaction.getTransactionId(),
- createTransaction.getTransactionType(), createTransaction.getTransactionChainId(),
- (short)createTransaction.getMessageVersion());
- }
+ Preconditions.checkArgument(message instanceof CreateTransaction);
+ return (CreateTransaction)message;
}
public static boolean isSerializedType(Object message) {
- return message instanceof CreateTransaction || message instanceof ShardTransactionMessages.CreateTransaction;
+ return message instanceof CreateTransaction;
}
}