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

ru.primetalk.synapse.akka.distributed.RouterActor.scala Maven / Gradle / Ivy

///////////////////////////////////////////////////////////////
// © ООО «Праймтолк», 2014                                   //
// Все права принадлежат компании ООО «Праймтолк».           //
///////////////////////////////////////////////////////////////
/**
 * SynapseGrid
 * © Primetalk Ltd., 2014.
 * All rights reserved.
 * Authors: A.Zhizhelev
 *
 * Created: 07.06.14, zhizhelev
 */
package ru.primetalk.synapse.akka.distributed

import akka.actor.{ActorRef, Actor}
import akka.event.{LoggingReceive, Logging}

/** Routes everything except register/unregister commands to
  * the system that has registered with the router.
  *
  * Unregister command is not supported.
  */
class RouterBecome extends Actor {
  val log = Logging(context.system, this)

  def receive = LoggingReceive {
    case Register(actor) =>
      log.info("RouterBecome: " + self.path + " received " + Register(actor))
      context.become(LoggingReceive {
        case m =>
          log.debug("RouterBecome.receive[" + self.path + "](" + actor + "): received " + m)
          actor forward m
      })
  }
}

sealed trait RouterCommand

/**
 * Registers the actor as a destination of all Router's input.
 * @param actor the destination of subsequent messages.
 */
case class Register(actor: ActorRef) extends RouterCommand

/**
 * Stops registration. All messages will be sent to DeathWatch.
 */
case object Unregister extends RouterCommand

///** Routes everything except register/unregister commands to
//  * the system that has registered with the router.
//  */
//class Router extends Actor {
//  val log = Logging(context.system, this)
//  var destination: Option[ActorRef] = None
//
//  def receive = {
//    case Register(actor) =>
//      destination = Some(actor)
//    case Unregister =>
//      destination = None
//    case m =>
//      destination.foreach(_ forward m)
//  }
//}
//




© 2015 - 2025 Weber Informatics LLC | Privacy Policy