com.evento.application.manager.ProjectionManager Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of evento-bundle Show documentation
Show all versions of evento-bundle Show documentation
Evento Framework - Bundle. The library to build a RECQ System based on Evento Server
package com.evento.application.manager;
import com.evento.application.performance.TracingAgent;
import com.evento.application.reference.ProjectionReference;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import com.evento.application.proxy.GatewayTelemetryProxy;
import com.evento.common.modeling.annotations.component.Projection;
import com.evento.common.modeling.exceptions.HandlerNotFoundException;
import com.evento.common.modeling.messaging.message.application.Message;
import com.evento.common.modeling.messaging.message.application.QueryMessage;
import com.evento.common.modeling.messaging.query.SerializedQueryResponse;
import org.reflections.Reflections;
import java.lang.reflect.InvocationTargetException;
import java.util.function.BiFunction;
import java.util.function.Function;
/**
* The ProjectionManager class extends the ReceiverComponentManager class and is responsible for managing projections.
* Projections are components capable of handling query messages.
*/
public class ProjectionManager extends ReceiverComponentManager, ProjectionReference> {
private static final Logger logger = LogManager.getLogger(ProjectionManager.class);
/**
* Creates a new instance of ProjectionManager.
*
* @param bundleId The identifier of the bundle.
* @param gatewayTelemetryProxy The function used to create GatewayTelemetryProxy instances.
* @param tracingAgent The tracing agent used for tracing.
*/
public ProjectionManager(String bundleId, BiFunction, GatewayTelemetryProxy> gatewayTelemetryProxy, TracingAgent tracingAgent) {
super(bundleId, gatewayTelemetryProxy, tracingAgent);
}
/**
* Parses the classes annotated with @Projection and registers the query handlers.
*
* @param reflections The reflections instance used for scanning classes.
* @param findInjectableObject The function used to find injectable objects.
* @throws InvocationTargetException If the class instantiation fails.
* @throws InstantiationException If the class instantiation fails.
* @throws IllegalAccessException If the class instantiation fails.
*/
@Override
public void parse(Reflections reflections, Function, Object> findInjectableObject)
throws InvocationTargetException, InstantiationException, IllegalAccessException {
for (Class> aClass : reflections.getTypesAnnotatedWith(Projection.class)) {
var projectionReference = new ProjectionReference(createComponentInstance(aClass, findInjectableObject));
for (String query : projectionReference.getRegisteredQueries()) {
getHandlers().put(query, projectionReference);
logger.info("Projection query handler for %s found in %s".formatted(query, projectionReference.getRef().getClass().getName()));
}
}
}
/**
* Handles the given query message by invoking the appropriate query handler.
*
* @param q The query message to handle.
* @return The serialized query response.
* @throws Exception If an error occurs while handling the query.
* @throws HandlerNotFoundException If no handler is found for the query in the bundle.
*/
@Override
public SerializedQueryResponse> handle(QueryMessage> q) throws Exception {
var handler = getHandlers().get(q.getQueryName());
if (handler == null)
throw new HandlerNotFoundException("No handler found for %s in %s".formatted(q.getQueryName(), getBundleId()));
var proxy = getGatewayTelemetryProxy().apply(handler.getComponentName(), q);
return getTracingAgent().track(q, handler.getComponentName(),
null,
() -> {
var result = handler.invoke(
q,
proxy,
proxy
);
var rm = new SerializedQueryResponse<>(result);
proxy.sendInvocationsMetric();
return rm;
});
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy