package com.mongodb.internal.connection;
import com.mongodb.ServerAddress;
import com.mongodb.async.SingleResultCallback;
import com.mongodb.diagnostics.logging.Logger;
import com.mongodb.diagnostics.logging.Loggers;
import org.bson.BsonDocument;
import org.bson.BsonDocumentReader;
import org.bson.codecs.BsonDocumentCodec;
import org.bson.codecs.Decoder;
import org.bson.codecs.DecoderContext;
class CommandResultCallback<T> extends CommandResultBaseCallback<BsonDocument> {
public static final Logger LOGGER = Loggers.getLogger("protocol.command");
private final SingleResultCallback<T> callback;
private final Decoder<T> decoder;
CommandResultCallback(final SingleResultCallback<T> callback, final Decoder<T> decoder,
final long requestId, final ServerAddress serverAddress) {
super(new BsonDocumentCodec(), requestId, serverAddress);
this.callback = callback;
this.decoder = decoder;
}
@Override
protected void callCallback(final BsonDocument response, final Throwable t) {
if (t != null) {
callback.onResult(null, t);
} else {
if (LOGGER.isDebugEnabled()) {
LOGGER.debug("Command execution completed with status " + ProtocolHelper.isCommandOk(response));
}
if (!ProtocolHelper.isCommandOk(response)) {
callback.onResult(null, ProtocolHelper.getCommandFailureException(response, getServerAddress()));
} else {
try {
callback.onResult(decoder.decode(new BsonDocumentReader(response), DecoderContext.builder().build()), null);
} catch (Throwable t1) {
callback.onResult(null, t1);
}
}
}
}
}