Trait/Object

eu.shiftforward.adstax.util

BaseAmqpProducerStashActor

Related Docs: object BaseAmqpProducerStashActor | package util

Permalink

trait BaseAmqpProducerStashActor extends Actor with Stash

A trait that extends an AMQP publisher and implements a common pattern where all received messages are stashed until the underlying producer is created and connected.

Mixing in this class requires defining the producerConnected method that should contain all the logic of publishing to AMQP and can assume all is ready for publishing, as well as defining the setupAmqp method which should create the producer actor. Another aspect of using this trait is that instead of using "context.become(newReceive)", one should use "stashedContextBecome(newReceive)" so that producer disconnected handling behaviour is not lost while changing context.

Linear Supertypes
Stash, RequiresMessageQueue[DequeBasedMessageQueueSemantics], UnrestrictedStash, StashSupport, Actor, AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. BaseAmqpProducerStashActor
  2. Stash
  3. RequiresMessageQueue
  4. UnrestrictedStash
  5. StashSupport
  6. Actor
  7. AnyRef
  8. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Type Members

  1. type Receive = PartialFunction[Any, Unit]

    Permalink
    Definition Classes
    Actor

Abstract Value Members

  1. abstract def producerConnected(producer: ActorRef): Receive

    Permalink

    Logic for handling AMQP publishing with assurance that everything is correctly created and connected.

    Logic for handling AMQP publishing with assurance that everything is correctly created and connected.

    producer

    the AMQP producer actor

    returns

    the logic handling receive

  2. abstract def setupAmqp: Future[ActorRef]

    Permalink

    Setup AMQP producer initialization and optionally exchange declaration

    Setup AMQP producer initialization and optionally exchange declaration

    returns

    a future of the producer actorRef, not necessarily fully connected to AMQP

Concrete Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. def aroundPostRestart(reason: Throwable): Unit

    Permalink
    Attributes
    protected[akka]
    Definition Classes
    Actor
  5. def aroundPostStop(): Unit

    Permalink
    Attributes
    protected[akka]
    Definition Classes
    Actor
  6. def aroundPreRestart(reason: Throwable, message: Option[Any]): Unit

    Permalink
    Attributes
    protected[akka]
    Definition Classes
    Actor
  7. def aroundPreStart(): Unit

    Permalink
    Attributes
    protected[akka]
    Definition Classes
    Actor
  8. def aroundReceive(receive: akka.actor.Actor.Receive, msg: Any): Unit

    Permalink
    Attributes
    protected[akka]
    Definition Classes
    Actor
  9. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  10. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  11. implicit val context: ActorContext

    Permalink
    Definition Classes
    Actor
  12. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  13. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  14. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  15. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  16. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  17. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  18. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  19. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  20. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  21. def postRestart(reason: Throwable): Unit

    Permalink
    Definition Classes
    Actor
    Annotations
    @throws( classOf[java.lang.Exception] )
  22. def postStop(): Unit

    Permalink
    Definition Classes
    UnrestrictedStash → Actor
  23. def preRestart(reason: Throwable, message: Option[Any]): Unit

    Permalink
    Definition Classes
    UnrestrictedStash → Actor
  24. def preStart(): Unit

    Permalink
    Definition Classes
    BaseAmqpProducerStashActor → Actor
  25. final def receive: Receive

    Permalink
    Definition Classes
    BaseAmqpProducerStashActor → Actor
  26. implicit final val self: ActorRef

    Permalink
    Definition Classes
    Actor
  27. final def sender(): ActorRef

    Permalink
    Definition Classes
    Actor
  28. def stash(): Unit

    Permalink
    Definition Classes
    StashSupport
  29. def stashedContextBecome(producer: ActorRef)(newContext: Receive): Unit

    Permalink

    Method for changing actor context while keeping necessary handling control behaviour.

    Method for changing actor context while keeping necessary handling control behaviour.

    producer

    the AMQP producer actor

    newContext

    the new context to change

  30. def supervisorStrategy: SupervisorStrategy

    Permalink
    Definition Classes
    Actor
  31. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  32. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  33. def unhandled(message: Any): Unit

    Permalink
    Definition Classes
    Actor
  34. def unstashAll(): Unit

    Permalink
    Definition Classes
    StashSupport
  35. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  36. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  37. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from Stash

Inherited from RequiresMessageQueue[DequeBasedMessageQueueSemantics]

Inherited from UnrestrictedStash

Inherited from StashSupport

Inherited from Actor

Inherited from AnyRef

Inherited from Any

Ungrouped