Package akka.actor.typed
Class BehaviorInterceptor<Outer,Inner>
- java.lang.Object
-
- akka.actor.typed.BehaviorInterceptor<Outer,Inner>
-
- Direct Known Subclasses:
AbstractSupervisor
,BehaviorSignalInterceptor
,GuardianStopInterceptor
,LogMessagesInterceptor
,MonitorInterceptor
,TransformMessagesInterceptor
,WithMdcBehaviorInterceptor
public abstract class BehaviorInterceptor<Outer,Inner> extends java.lang.Object
Scala API: TheClassTag
forOuter
ensures that only messages of this class or a subclass thereof will be intercepted. Other message types (e.g. a private protocol) will bypass the interceptor and be continue to the inner behavior untouched.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static interface
BehaviorInterceptor.PreStartTarget<T>
static interface
BehaviorInterceptor.ReceiveTarget<T>
static interface
BehaviorInterceptor.SignalTarget<T>
-
Constructor Summary
Constructors Constructor Description BehaviorInterceptor(java.lang.Class<Outer> interceptMessageClass)
BehaviorInterceptor(scala.reflect.ClassTag<Outer> interceptMessageClassTag)
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description abstract Behavior<Inner>
aroundReceive(TypedActorContext<Outer> ctx, Outer msg, BehaviorInterceptor.ReceiveTarget<Inner> target)
Intercept a message sent to the running actor.Behavior<Inner>
aroundSignal(TypedActorContext<Outer> ctx, Signal signal, BehaviorInterceptor.SignalTarget<Inner> target)
Override to intercept a signal sent to the running actor.Behavior<Inner>
aroundStart(TypedActorContext<Outer> ctx, BehaviorInterceptor.PreStartTarget<Inner> target)
Override to intercept actor startup.java.lang.Class<Outer>
interceptMessageClass()
boolean
isSame(BehaviorInterceptor<java.lang.Object,java.lang.Object> other)
-
-
-
Method Detail
-
interceptMessageClass
public java.lang.Class<Outer> interceptMessageClass()
-
aroundStart
public Behavior<Inner> aroundStart(TypedActorContext<Outer> ctx, BehaviorInterceptor.PreStartTarget<Inner> target)
Override to intercept actor startup. To trigger startup of the next behavior in the stack, calltarget.start()
.- Parameters:
ctx
- (undocumented)target
- (undocumented)- Returns:
- The returned behavior will be the "started" behavior of the actor used to accept the next message or signal.
-
aroundReceive
public abstract Behavior<Inner> aroundReceive(TypedActorContext<Outer> ctx, Outer msg, BehaviorInterceptor.ReceiveTarget<Inner> target)
Intercept a message sent to the running actor. Pass the message on to the next behavior in the stack by passing it totarget.apply
, returnBehaviors.same
without invokingtarget
to filter out the message.- Parameters:
ctx
- (undocumented)msg
- (undocumented)target
- (undocumented)- Returns:
- The behavior for next message or signal
-
aroundSignal
public Behavior<Inner> aroundSignal(TypedActorContext<Outer> ctx, Signal signal, BehaviorInterceptor.SignalTarget<Inner> target)
Override to intercept a signal sent to the running actor. Pass the signal on to the next behavior in the stack by passing it totarget.apply
.- Parameters:
ctx
- (undocumented)signal
- (undocumented)target
- (undocumented)- Returns:
- The behavior for next message or signal
- See Also:
BehaviorSignalInterceptor
-
isSame
public boolean isSame(BehaviorInterceptor<java.lang.Object,java.lang.Object> other)
- Parameters:
other
- (undocumented)- Returns:
true
if this behavior logically the same as another behavior interceptor and can therefore be eliminated (to avoid building infinitely growing stacks of behaviors)? Default implementation is based on instance equality. Override to provide use case specific logic.
-
-