|
@@ -9,6 +9,7 @@
|
|
package org.elasticsearch.action.support.single.shard;
|
|
package org.elasticsearch.action.support.single.shard;
|
|
|
|
|
|
import org.elasticsearch.action.ActionListener;
|
|
import org.elasticsearch.action.ActionListener;
|
|
|
|
+import org.elasticsearch.action.ActionListenerResponseHandler;
|
|
import org.elasticsearch.action.ActionResponse;
|
|
import org.elasticsearch.action.ActionResponse;
|
|
import org.elasticsearch.action.ActionRunnable;
|
|
import org.elasticsearch.action.ActionRunnable;
|
|
import org.elasticsearch.action.NoShardAvailableActionException;
|
|
import org.elasticsearch.action.NoShardAvailableActionException;
|
|
@@ -25,7 +26,6 @@ import org.elasticsearch.cluster.node.DiscoveryNodes;
|
|
import org.elasticsearch.cluster.routing.ShardRouting;
|
|
import org.elasticsearch.cluster.routing.ShardRouting;
|
|
import org.elasticsearch.cluster.routing.ShardsIterator;
|
|
import org.elasticsearch.cluster.routing.ShardsIterator;
|
|
import org.elasticsearch.cluster.service.ClusterService;
|
|
import org.elasticsearch.cluster.service.ClusterService;
|
|
-import org.elasticsearch.common.io.stream.StreamInput;
|
|
|
|
import org.elasticsearch.common.io.stream.Writeable;
|
|
import org.elasticsearch.common.io.stream.Writeable;
|
|
import org.elasticsearch.common.logging.LoggerMessageFormat;
|
|
import org.elasticsearch.common.logging.LoggerMessageFormat;
|
|
import org.elasticsearch.core.Nullable;
|
|
import org.elasticsearch.core.Nullable;
|
|
@@ -35,7 +35,6 @@ import org.elasticsearch.threadpool.ThreadPool;
|
|
import org.elasticsearch.transport.TransportChannel;
|
|
import org.elasticsearch.transport.TransportChannel;
|
|
import org.elasticsearch.transport.TransportException;
|
|
import org.elasticsearch.transport.TransportException;
|
|
import org.elasticsearch.transport.TransportRequestHandler;
|
|
import org.elasticsearch.transport.TransportRequestHandler;
|
|
-import org.elasticsearch.transport.TransportResponseHandler;
|
|
|
|
import org.elasticsearch.transport.TransportService;
|
|
import org.elasticsearch.transport.TransportService;
|
|
|
|
|
|
import java.io.IOException;
|
|
import java.io.IOException;
|
|
@@ -173,22 +172,7 @@ public abstract class TransportSingleShardAction<Request extends SingleShardRequ
|
|
clusterService.localNode(),
|
|
clusterService.localNode(),
|
|
transportShardAction,
|
|
transportShardAction,
|
|
internalRequest.request(),
|
|
internalRequest.request(),
|
|
- new TransportResponseHandler<Response>() {
|
|
|
|
- @Override
|
|
|
|
- public Response read(StreamInput in) throws IOException {
|
|
|
|
- return reader.read(in);
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- @Override
|
|
|
|
- public void handleResponse(final Response response) {
|
|
|
|
- listener.onResponse(response);
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- @Override
|
|
|
|
- public void handleException(TransportException exp) {
|
|
|
|
- listener.onFailure(exp);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
|
|
+ new ActionListenerResponseHandler<>(listener, reader)
|
|
);
|
|
);
|
|
} else {
|
|
} else {
|
|
perform(null);
|
|
perform(null);
|
|
@@ -241,18 +225,7 @@ public abstract class TransportSingleShardAction<Request extends SingleShardRequ
|
|
node,
|
|
node,
|
|
transportShardAction,
|
|
transportShardAction,
|
|
internalRequest.request(),
|
|
internalRequest.request(),
|
|
- new TransportResponseHandler<Response>() {
|
|
|
|
-
|
|
|
|
- @Override
|
|
|
|
- public Response read(StreamInput in) throws IOException {
|
|
|
|
- return reader.read(in);
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- @Override
|
|
|
|
- public void handleResponse(final Response response) {
|
|
|
|
- listener.onResponse(response);
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
|
|
+ new ActionListenerResponseHandler<>(listener, reader) {
|
|
@Override
|
|
@Override
|
|
public void handleException(TransportException exp) {
|
|
public void handleException(TransportException exp) {
|
|
onFailure(shardRouting, exp);
|
|
onFailure(shardRouting, exp);
|