org.infinispan.commands.remote.recovery.CompleteTransactionCommand Maven / Gradle / Ivy
package org.infinispan.commands.remote.recovery;
import org.infinispan.context.InvocationContext;
import javax.transaction.xa.Xid;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
/**
* Command used by the recovery tooling for forcing transaction completion .
*
* @author Mircea Markus
* @since 5.0
*/
public class CompleteTransactionCommand extends RecoveryCommand {
public static final byte COMMAND_ID = 24;
/**
* The tx which we want to complete.
*/
private Xid xid;
/**
* if true the transaction is committed, otherwise it is rolled back.
*/
private boolean commit;
private CompleteTransactionCommand() {
super(null); // For command id uniqueness test
}
public CompleteTransactionCommand(String cacheName) {
super(cacheName);
}
public CompleteTransactionCommand(String cacheName, Xid xid, boolean commit) {
super(cacheName);
this.xid = xid;
this.commit = commit;
}
@Override
public Object perform(InvocationContext ctx) throws Throwable {
return recoveryManager.forceTransactionCompletion(xid, commit);
}
@Override
public byte getCommandId() {
return COMMAND_ID;
}
@Override
public void writeTo(ObjectOutput output) throws IOException {
output.writeObject(xid);
output.writeBoolean(commit);
}
@Override
public void readFrom(ObjectInput input) throws IOException, ClassNotFoundException {
xid = (Xid) input.readObject();
commit = input.readBoolean();
}
@Override
public boolean canBlock() {
//this command performs the 2PC commit.
return true;
}
@Override
public String toString() {
return getClass().getSimpleName() +
"{ xid=" + xid +
", commit=" + commit +
", cacheName=" + cacheName +
"} ";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy