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

io.vlingo.lattice.router.CommandRouter Maven / Gradle / Ivy

Go to download

Tooling for reactive Domain-Driven Design projects that are highly concurrent. Includes compute grid, actor caching, spaces, cross-node cluster messaging, CQRS, and Event Sourcing support.

There is a newer version: 1.7.5
Show newest version
// Copyright © 2012-2020 VLINGO LABS. All rights reserved.
//
// This Source Code Form is subject to the terms of the
// Mozilla Public License, v. 2.0. If a copy of the MPL
// was not distributed with this file, You can obtain
// one at https://mozilla.org/MPL/2.0/.

package io.vlingo.lattice.router;

import io.vlingo.actors.Stage;
import io.vlingo.lattice.model.Command;

public interface CommandRouter {
  static CommandRouter of(final Stage stage, final Type type, final int totalRoutees) {
    switch (type) {
    case LoadBalancing:
      return stage.actorFor(CommandRouter.class, LoadBalancingCommandRouter.class, totalRoutees);
    case Partitioning:
      return stage.actorFor(CommandRouter.class, PartitioningCommandRouter.class, totalRoutees);
    case RoundRobin:
      return stage.actorFor(CommandRouter.class, RoundRobinCommandRouter.class, totalRoutees);
    }
    throw new IllegalArgumentException("The command router type is not mapped: " + type);
  }

   void route(final RoutableCommand command);

  enum Type { LoadBalancing, Partitioning, RoundRobin };
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy