All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.infinispan.commands.write.ExceptionAckCommand Maven / Gradle / Ivy

package org.infinispan.commands.write;

import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;

import org.infinispan.commands.remote.BaseRpcCommand;
import org.infinispan.util.ByteString;
import org.infinispan.util.concurrent.CommandAckCollector;

/**
 * A command that represents an exception acknowledge sent by any owner.
 * 

* The acknowledge represents an unsuccessful execution of the operation. * * @author Pedro Ruivo * @since 9.0 */ public class ExceptionAckCommand extends BaseRpcCommand { public static final byte COMMAND_ID = 42; private CommandAckCollector commandAckCollector; private Throwable throwable; private long id; private int topologyId; public ExceptionAckCommand() { super(null); } public ExceptionAckCommand(ByteString cacheName) { super(cacheName); } public ExceptionAckCommand(ByteString cacheName, long id, Throwable throwable, int topologyId) { super(cacheName); this.id = id; this.throwable = throwable; this.topologyId = topologyId; } public void ack() { commandAckCollector.completeExceptionally(id, throwable, topologyId); } @Override public byte getCommandId() { return COMMAND_ID; } @Override public boolean isReturnValueExpected() { return false; } @Override public boolean canBlock() { return false; } @Override public void writeTo(ObjectOutput output) throws IOException { output.writeLong(id); output.writeObject(throwable); output.writeInt(topologyId); } @Override public void readFrom(ObjectInput input) throws IOException, ClassNotFoundException { id = input.readLong(); throwable = (Throwable) input.readObject(); topologyId = input.readInt(); } public void setCommandAckCollector(CommandAckCollector commandAckCollector) { this.commandAckCollector = commandAckCollector; } @Override public String toString() { return "ExceptionAckCommand{" + "id=" + id + ", throwable=" + throwable + ", topologyId=" + topologyId + '}'; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy