All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.evento.application.reference.ProjectionReference Maven / Gradle / Ivy

Go to download

Evento Framework - Bundle. The library to build a RECQ System based on Evento Server

There is a newer version: ev1.10.3
Show newest version
package com.evento.application.reference;

import com.evento.application.utils.ReflectionUtils;
import com.evento.common.messaging.gateway.CommandGateway;
import com.evento.common.messaging.gateway.QueryGateway;
import com.evento.common.modeling.annotations.handler.QueryHandler;
import com.evento.common.modeling.messaging.message.application.QueryMessage;
import com.evento.common.modeling.messaging.payload.Query;
import com.evento.common.modeling.messaging.query.QueryResponse;

import java.lang.reflect.Method;
import java.time.Instant;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Set;

/**
 * The ProjectionReference class extends the Reference class and is responsible for managing query handler references
 * for projection objects.
 */
public class ProjectionReference extends Reference {

    private final HashMap queryHandlerReferences = new HashMap<>();

    /**
     * The ProjectionReference class extends the Reference class and is responsible for managing query handler references
     * for projection objects.
     * @param ref the Projection Object
     */
    public ProjectionReference(Object ref) {
        super(ref);
        for (Method declaredMethod : ref.getClass().getDeclaredMethods()) {

            var ach = declaredMethod.getAnnotation(QueryHandler.class);
            if (ach != null) {
                queryHandlerReferences.put(Arrays.stream(declaredMethod.getParameterTypes())
                        .filter(Query.class::isAssignableFrom)
                        .findFirst()
                        .map(Class::getSimpleName)
                        .orElseThrow(() -> new IllegalArgumentException("Query parameter not fount in  " + declaredMethod)), declaredMethod);
            }
        }
    }

    /**
     * Retrieves the set of registered queries for query handlers managed by the ProjectionReference class.
     *
     * @return The set of registered queries as a Set of Strings.
     */
    public Set getRegisteredQueries() {
        return queryHandlerReferences.keySet();
    }

    /**
     * Retrieves the query handler method for the specified query name.
     *
     * @param queryName The name of the query.
     * @return The query handler method as a Method object, or null if no query handler is found for the given name.
     */
    public Method getQueryHandler(String queryName) {
        return queryHandlerReferences.get(queryName);
    }

    /**
     * Invokes a query handler method based on the given query message.
     *
     * @param qm              The query message containing the query and its payload.
     * @param commandGateway  The command gateway used for sending commands.
     * @param queryGateway    The query gateway used for sending queries.
     * @return The result of invoking the query handler method.
     * @throws Exception if an error occurs while invoking the query handler method.
     */
    public QueryResponse invoke(
            QueryMessage qm,
            CommandGateway commandGateway,
            QueryGateway queryGateway)
            throws Exception {

        var handler = queryHandlerReferences.get(qm.getQueryName());

        return (QueryResponse) ReflectionUtils.invoke(getRef(), handler,
                qm.getPayload(),
                commandGateway,
                queryGateway,
                qm,
                qm.getMetadata(),
                Instant.ofEpochMilli(qm.getTimestamp())
        );
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy