diff --git a/shield/src/main/java/org/elasticsearch/shield/transport/ShieldServerTransportService.java b/shield/src/main/java/org/elasticsearch/shield/transport/ShieldServerTransportService.java index 017ea32dfa1..b1976f3de33 100644 --- a/shield/src/main/java/org/elasticsearch/shield/transport/ShieldServerTransportService.java +++ b/shield/src/main/java/org/elasticsearch/shield/transport/ShieldServerTransportService.java @@ -20,6 +20,7 @@ import org.elasticsearch.transport.netty.NettyTransport; import java.util.Collections; import java.util.Map; +import java.util.concurrent.Callable; import static org.elasticsearch.shield.transport.netty.ShieldNettyTransport.*; @@ -67,6 +68,12 @@ public class ShieldServerTransportService extends TransportService { super.registerRequestHandler(action, request, executor, forceExecution, wrappedHandler); } + @Override + public void registerRequestHandler(String action, Callable requestFactory, String executor, TransportRequestHandler handler) { + TransportRequestHandler wrappedHandler = new ProfileSecuredRequestHandler<>(action, handler, profileFilters); + super.registerRequestHandler(action, requestFactory, executor, wrappedHandler); + } + protected Map initializeProfileFilters() { if (!(transport instanceof ShieldNettyTransport)) { return Collections.singletonMap(NettyTransport.DEFAULT_PROFILE, new ServerTransportFilter.NodeProfile(authcService, authzService, actionMapper, false));