org.infinispan.commands.remote.recovery.GetInDoubtTransactionsCommand Maven / Gradle / Ivy
package org.infinispan.commands.remote.recovery;
import org.infinispan.commons.util.Util;
import org.infinispan.context.InvocationContext;
import org.infinispan.util.logging.Log;
import org.infinispan.util.logging.LogFactory;
import javax.transaction.xa.Xid;
import java.util.List;
/**
* Rpc to obtain all in-doubt prepared transactions stored on remote nodes.
* A transaction is in doubt if it is prepared and the node where it started has crashed.
*
* @author [email protected]
* @since 5.0
*/
public class GetInDoubtTransactionsCommand extends RecoveryCommand {
private static final Log log = LogFactory.getLog(GetInDoubtTransactionsCommand.class);
public static final int COMMAND_ID = 21;
private GetInDoubtTransactionsCommand() {
super(null); // For command id uniqueness test
}
public GetInDoubtTransactionsCommand(String cacheName) {
super(cacheName);
}
@Override
public List perform(InvocationContext ctx) throws Throwable {
List localInDoubtTransactions = recoveryManager.getInDoubtTransactions();
log.tracef("Returning result %s", localInDoubtTransactions);
return localInDoubtTransactions;
}
@Override
public byte getCommandId() {
return COMMAND_ID;
}
@Override
public Object[] getParameters() {
return Util.EMPTY_OBJECT_ARRAY;
}
@Override
public void setParameters(int commandId, Object[] parameters) {
if (commandId != COMMAND_ID)
throw new IllegalStateException("Expected " + COMMAND_ID + "and received " + commandId);
// No parameters
}
@Override
public String toString() {
return getClass().getSimpleName() + " { cacheName = " + cacheName + "}";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy