com.evento.application.manager.AggregateManager 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.AggregateReference;
import com.evento.application.reference.AggregateStateEnvelope;
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.Aggregate;
import com.evento.common.modeling.exceptions.HandlerNotFoundException;
import com.evento.common.modeling.messaging.message.application.DecoratedDomainCommandMessage;
import com.evento.common.modeling.messaging.message.application.DomainCommandResponseMessage;
import com.evento.common.modeling.messaging.message.application.DomainEventMessage;
import com.evento.common.modeling.messaging.message.application.Message;
import com.evento.common.modeling.state.SerializedAggregateState;
import org.reflections.Reflections;
import java.lang.reflect.InvocationTargetException;
import java.util.function.BiFunction;
import java.util.function.Function;
/**
* The `AggregateManager` class is responsible for managing aggregates and handling domain commands.
*/
public class AggregateManager extends ReceiverComponentManager {
private static final Logger logger = LogManager.getLogger(AggregateManager.class);
/**
* Constructs an `AggregateManager`.
*
* @param bundleId The bundle identifier.
* @param gatewayTelemetryProxy A function to create a `GatewayTelemetryProxy`.
* @param tracingAgent The tracing agent for telemetry.
*/
public AggregateManager(String bundleId, BiFunction, GatewayTelemetryProxy> gatewayTelemetryProxy, TracingAgent tracingAgent) {
super(bundleId, gatewayTelemetryProxy, tracingAgent);
}
/**
* Parses and processes annotated aggregate classes.
*
* @param reflections The `Reflections` instance to discover annotated classes.
* @param findInjectableObject A function to find injectable objects.
* @throws InvocationTargetException If there is an issue with invoking a method.
* @throws InstantiationException If there is an issue with instantiating a class.
* @throws IllegalAccessException If there is an issue with accessing a class or its members.
*/
public void parse(Reflections reflections, Function, Object> findInjectableObject) throws InvocationTargetException, InstantiationException, IllegalAccessException {
for (Class> aClass : reflections.getTypesAnnotatedWith(Aggregate.class)) {
var aggregateReference = new AggregateReference(createComponentInstance(aClass, findInjectableObject),
aClass.getAnnotation(Aggregate.class).snapshotFrequency());
for (String command : aggregateReference.getRegisteredCommands()) {
getHandlers().put(command, aggregateReference);
logger.info("Aggregate command handler for %s found in %s".formatted(command, aggregateReference.getRef().getClass().getName()));
}
}
}
/**
* Handles a decorated domain command message.
*
* @param c The decorated domain command message to handle.
* @return The domain command response message.
* @throws Exception If an exception occurs during handling.
*/
public DomainCommandResponseMessage handle(DecoratedDomainCommandMessage c) throws Exception {
var handler = getHandlers().get(c.getCommandMessage().getCommandName());
if (handler == null)
throw new HandlerNotFoundException("No handler found for %s in %s"
.formatted(c.getCommandMessage().getCommandName(), getBundleId()));
var envelope = new AggregateStateEnvelope(c.getSerializedAggregateState().getAggregateState());
var proxy = getGatewayTelemetryProxy().apply(
handler.getComponentName(),
c.getCommandMessage());
return getTracingAgent().track(
c.getCommandMessage(),
handler.getComponentName(),
null,
() -> {
var event = handler.invoke(
c.getCommandMessage(),
envelope,
c.getEventStream(),
proxy,
proxy
);
var em = new DomainEventMessage(event);
getTracingAgent().correlate(c.getCommandMessage(), em);
var resp = new DomainCommandResponseMessage(em,
(handler.getSnapshotFrequency() >= 0 & handler.getSnapshotFrequency() <= c.getEventStream().size()) ?
new SerializedAggregateState<>(envelope.getAggregateState()) : null,
envelope.getAggregateState() != null
&& envelope.getAggregateState().isDeleted()
);
proxy.sendInvocationsMetric();
return resp;
});
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy