com.evento.application.manager.ProjectorManager 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.consumer.ProjectorEvenConsumer;
import com.evento.application.performance.TracingAgent;
import com.evento.application.reference.ProjectorReference;
import com.evento.common.utils.Context;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import com.evento.application.proxy.GatewayTelemetryProxy;
import com.evento.common.messaging.consumer.ConsumerStateStore;
import com.evento.common.modeling.annotations.component.Projector;
import com.evento.common.modeling.messaging.message.application.Message;
import org.reflections.Reflections;
import java.lang.reflect.InvocationTargetException;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.function.BiFunction;
import java.util.function.Function;
import java.util.function.Supplier;
/**
* The ProjectorManager class is responsible for managing projectors and their event consumers.
* It extends the ConsumerComponentManager class and provides methods to start event consumers
* and parse projectors.
*/
public class ProjectorManager extends ConsumerComponentManager {
private static final Logger logger = LogManager.getLogger(ProjectorManager.class);
/**
* Constructs a ProjectorManager object with the specified parameters.
*
* @param bundleId the bundle ID associated with the ProjectorManager
* @param gatewayTelemetryProxy a function that takes a String and a Message object and returns a GatewayTelemetryProxy
* @param tracingAgent the TracingAgent object used for tracing
* @param isShuttingDown a supplier that provides a Boolean value indicating if the application is shutting down
* @param sssFetchSize the fetch size for SSS
* @param sssFetchDelay the fetch delay for SSS
*/
public ProjectorManager(String bundleId, BiFunction, GatewayTelemetryProxy> gatewayTelemetryProxy, TracingAgent tracingAgent, Supplier isShuttingDown, int sssFetchSize, int sssFetchDelay) {
super(bundleId, gatewayTelemetryProxy, tracingAgent, isShuttingDown, sssFetchSize, sssFetchDelay);
}
/**
* Starts the event consumers for projectors.
*
* @param onAllHeadReached the runnable that gets executed when all heads have been reached
* @param consumerStateStore the consumer state store used by the event consumers
* @param contexts the map containing the consumers contexts association
*/
public void startEventConsumers(Runnable onAllHeadReached, ConsumerStateStore consumerStateStore, Map> contexts) {
if (getReferences().isEmpty()) {
onAllHeadReached.run();
return;
}
var counter = new AtomicInteger(getReferences()
.stream()
.mapToInt(p -> contexts.getOrDefault(p.getComponentName(), Set.of(Context.ALL))
.size())
.sum());
logger.info("Checking for projector event consumers");
for (ProjectorReference projector : getReferences()) {
var annotation = projector.getRef().getClass().getAnnotation(Projector.class);
for (var context : contexts.getOrDefault(projector.getComponentName(), Set.of(Context.ALL))) {
var projectorName = projector.getRef().getClass().getSimpleName();
var projectorVersion = annotation.version();
logger.info("Starting event consumer for Projector: %s - Version: %d - Context: %s"
.formatted(projectorName, projectorVersion, context));
var t = new Thread(new ProjectorEvenConsumer(
getBundleId(),
projectorName,
projectorVersion,
context,
getIsShuttingDown(),
consumerStateStore,
getHandlers(),
getTracingAgent(),
getGatewayTelemetryProxy(),
getSssFetchSize(),
getSssFetchDelay(),
counter,
onAllHeadReached
));
t.setName(projectorName + "(v"+projectorVersion+") - " + context);
t.start();
}
}
}
/**
* Parses the classes annotated with @Projector and adds them as references to the ProjectorManager.
* Also registers the projector event handlers.
*
* @param reflections the Reflections object containing the annotated classes
* @param findInjectableObject a function that can find an injectable object by its class
* @throws InvocationTargetException if an exception occurs while invoking a method or constructor via reflection
* @throws InstantiationException if a class cannot be instantiated
* @throws IllegalAccessException if access to a class, field, method, or constructor is denied
*/
public void parse(Reflections reflections, Function, Object> findInjectableObject) throws InvocationTargetException, InstantiationException, IllegalAccessException {
for (Class> aClass : reflections.getTypesAnnotatedWith(Projector.class)) {
var projectorReference = new ProjectorReference(createComponentInstance(aClass, findInjectableObject));
getReferences().add(projectorReference);
for (String event : projectorReference.getRegisteredEvents()) {
var hl = getHandlers().getOrDefault(event, new HashMap<>());
hl.put(aClass.getSimpleName(), projectorReference);
getHandlers().put(event, hl);
logger.info("Projector event handler for %s found in %s".formatted(event, projectorReference.getRef().getClass().getName()));
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy