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

io.vertx.up.runtime.ZeroMotor Maven / Gradle / Ivy

There is a newer version: 0.9.0
Show newest version
package io.vertx.up.runtime;

import io.vertx.core.ClusterOptions;
import io.vertx.core.VertxOptions;
import io.vertx.core.eventbus.EnvelopCodec;
import io.vertx.core.eventbus.EventBus;
import io.vertx.core.spi.cluster.ClusterManager;
import io.vertx.up.commune.Envelop;
import io.vertx.up.eon.Info;
import io.vertx.up.eon.em.ServerType;
import io.vertx.up.fn.Fn;
import io.vertx.up.log.Annal;
import io.vertx.up.util.Ut;
import io.vertx.zero.exception.VertxCallbackException;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;
import java.util.function.BiConsumer;
import java.util.function.Consumer;

/**
 * Start up tools shared in
 * Web Application & Rx Application
 */
public final class ZeroMotor {

    private static final Annal LOGGER = Annal.get(ZeroMotor.class);

    public static  void start(
        final Class clazz,
        final Consumer consumer,
        final Consumer> fnSingle,
        final BiConsumer> fnCluster,
        final Annal logger) {
        if (null == consumer) {
            throw new VertxCallbackException(clazz);
        }
        // 1. Check if clustered mode
        final ClusterOptions cluster = ZeroGrid.getClusterOption();
        if (cluster.isEnabled()) {
            // 2.1. Clustered
            final ClusterManager manager = cluster.getManager();
            logger.info(Info.APP_CLUSTERD, manager.getClass().getName(),
                manager.getNodeId(), manager.isActive());
            fnCluster.accept(manager, consumer);
        } else {
            // 2.2. Standalone
            fnSingle.accept(consumer);
        }
    }

    public static void each(
        final BiConsumer consumer) {
        final ConcurrentMap vertxOptions
            = ZeroGrid.getVertxOptions();
        vertxOptions.forEach(consumer);
    }

    public static void codec(final EventBus eventBus) {
        eventBus.registerDefaultCodec(Envelop.class,
            Ut.singleton(EnvelopCodec.class));
    }

    /**
     * Agent calculation
     *
     * @param defaultAgents default agent classes array
     * @param internals     default internal agent class
     *
     * @return The map to stored agent class for each ServerType here
     */
    public static ConcurrentMap> agents(
        final ServerType category,
        final Class[] defaultAgents,
        final ConcurrentMap> internals
    ) {
        final ConcurrentMap>> agents =
            getMergedAgents(category, internals);
        final ConcurrentMap defines =
            ZeroHelper.isAgentDefined(agents, defaultAgents);
        final ConcurrentMap> ret =
            new ConcurrentHashMap<>();
        // Fix Boot
        // 1. If defined, use default
        Ut.itMap(agents, (type, list) -> {
            // 2. Defined -> You have defined
            Fn.safeSemi(defines.containsKey(type) && defines.get(type), LOGGER,
                () -> {
                    // Use user-defined Agent instead.
                    final Class found = Ut.elementFind(list,
                        (item) -> internals.get(type) != item);
                    if (null != found) {
                        ret.put(type, found);
                    }
                }, () -> {
                    // Use internal defined ( system defaults )
                    final Class found = Ut.elementFind(list,
                        (item) -> internals.get(type) == item);
                    if (null != found) {
                        LOGGER.info(Info.AGENT_DEFINED, found, type);
                        ret.put(type, found);
                    }
                });
        });
        // 2.Filter
        return filterAgents(ret);
    }

    private static ConcurrentMap> filterAgents(
        final ConcurrentMap> agents) {
        // Check Rpc Enabled
        if (ZeroGrid.getRpcOptions().isEmpty()) {
            agents.remove(ServerType.IPC);
        } else {
            LOGGER.info(Info.RPC_ENABLED);
        }
        // Check Socket Enabled
        if (ZeroGrid.getSockOptions().isEmpty()) {
            agents.remove(ServerType.SOCK);
        } else {
            LOGGER.info(Info.SOCK_ENABLED);
        }
        return agents;
    }

    private static ConcurrentMap>> getMergedAgents(
        final ServerType category,
        final ConcurrentMap> internals
    ) {
        final ConcurrentMap>> agents = ZeroAnno.getAgents();
        if (agents.isEmpty()) {
            // Inject ServerType by category input.
            agents.put(category, new ArrayList<>(internals.values()));
        }
        return agents;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy