Class Attributes
- java.lang.Object
-
- akka.stream.Attributes
-
- All Implemented Interfaces:
java.io.Serializable
,scala.Equals
,scala.Product
public final class Attributes extends java.lang.Object implements scala.Product, java.io.Serializable, scala.Equals
Holds attributes which can be used to alterFlow
/Flow
orGraphDSL
/GraphDSL
materialization.Note that more attributes for the
Materializer
are defined inActorAttributes
.The
attributeList
is ordered with the most specific attribute first, least specific last. Note that the order was the opposite in Akka 2.4.x.
Operators should in general not access the
attributeList
but instead useget
to get the expected value of an attribute.Constructor is internal Akka API, use factories in companion to create instances.
- See Also:
- Serialized Form
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
Attributes.AsyncBoundary$
static interface
Attributes.Attribute
Note that more attributes for theMaterializer
are defined inActorAttributes
.static class
Attributes.CancellationStrategy
Cancellation strategies provide a way to configure the behavior of a stage whencancelStage
is called.static class
Attributes.CancellationStrategy$
static class
Attributes.InputBuffer
Each asynchronous piece of a materialized stream topology is executed by one Actor that manages an input buffer for all inlets of its shape.static class
Attributes.InputBuffer$
static class
Attributes.LogLevels
static class
Attributes.LogLevels$
static interface
Attributes.MandatoryAttribute
Attributes that are always present (is defined with default values by the materializer)static class
Attributes.Name
static class
Attributes.Name$
static class
Attributes.NestedMaterializationCancellationPolicy
Nested materialization cancellation strategy provides a way to configure the cancellation behavior of stages that materialize a nested flow.static class
Attributes.NestedMaterializationCancellationPolicy$
static class
Attributes.SourceLocation
Attribute that contains the source location of for example a lambda passed to an operator, useful for example for debugging.static class
Attributes.SourceLocation$
-
Constructor Summary
Constructors Constructor Description Attributes(scala.collection.immutable.List<Attributes.Attribute> attributeList)
Deprecated.Use factories on companion object instead.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description static scala.collection.immutable.List<Attributes.Attribute>
$lessinit$greater$default$1()
Attributes
and(Attributes other)
Adds given attributes.Attributes
and(Attributes.Attribute other)
Adds given attribute.static Attributes
apply()
static Attributes
apply(Attributes.Attribute attribute)
INTERNAL APIstatic Attributes
apply(scala.collection.immutable.List<Attributes.Attribute> attributeList)
static scala.collection.immutable.List<Attributes.Attribute>
apply$default$1()
static Attributes
asyncBoundary()
scala.collection.immutable.List<Attributes.Attribute>
attributeList()
static akka.stream.Attributes.CancellationStrategy.Strategy
cancellationStrategyAfterDelay(scala.concurrent.duration.FiniteDuration delay, akka.stream.Attributes.CancellationStrategy.Strategy strategy)
Java APIstatic akka.stream.Attributes.CancellationStrategy.Strategy
cancellationStrategyCompleteState()
Java APIstatic akka.stream.Attributes.CancellationStrategy.Strategy
cancellationStrategyFailStage()
Java APIstatic akka.stream.Attributes.CancellationStrategy.Strategy
cancellationStrategyPropagateFailure()
Java APIboolean
canEqual(java.lang.Object that)
boolean
contains(Attributes.Attribute attr)
Test whether the given attribute is contained within this attributes list.Attributes
copy(scala.collection.immutable.List<Attributes.Attribute> attributeList)
Deprecated.Don't use copy on Attributes.scala.collection.immutable.List<Attributes.Attribute>
copy$default$1()
static Attributes
createLogLevels(Logging.LogLevel onElement)
Java APIstatic Attributes
createLogLevels(Logging.LogLevel onElement, Logging.LogLevel onFinish, Logging.LogLevel onFailure)
Java APIboolean
equals(java.lang.Object other)
static java.lang.String
extractName(akka.stream.impl.TraversalBuilder builder, java.lang.String default_)
Compute a name by concatenating all Name attributes that the given module has, returning the given default value if none are found.<T extends Attributes.Attribute>
scala.collection.immutable.List<T>filtered(scala.reflect.ClassTag<T> evidence$4)
Scala API: Get all attributes of a given type (or subtypes thereof).<T extends Attributes.Attribute>
scala.Option<T>get(scala.reflect.ClassTag<T> evidence$2)
Scala API: Get the most specific attribute value for a given Attribute type or subclass thereof.<T extends Attributes.Attribute>
Tget(T default_, scala.reflect.ClassTag<T> evidence$1)
Scala API: Get the most specific attribute value for a given Attribute type or subclass thereof or if no such attribute exists, return a default value.<T extends Attributes.Attribute>
java.util.Optional<T>getAttribute(java.lang.Class<T> c)
Java API: Get the most specific attribute value for a given Attribute type or subclass thereof.<T extends Attributes.Attribute>
TgetAttribute(java.lang.Class<T> c, T default_)
Java API: Get the most specific attribute value for a given Attribute type or subclass thereof.java.util.List<Attributes.Attribute>
getAttributeList()
Java API<T extends Attributes.Attribute>
java.util.List<T>getAttributeList(java.lang.Class<T> c)
Java API: Get all attributes of a givenClass
or subclass thereof.<T extends Attributes.Attribute>
scala.Option<T>getFirst(scala.reflect.ClassTag<T> evidence$5)
Deprecated.Attributes should always be most specific, use get[T].<T extends Attributes.MandatoryAttribute>
TgetMandatoryAttribute(java.lang.Class<T> c)
Java API: Get the most specific of one of the mandatory attributes.int
hashCode()
static Attributes
inputBuffer(int initial, int max)
Each asynchronous piece of a materialized stream topology is executed by one Actor that manages an input buffer for all inlets of its shape.static Logging.LogLevel
logLevelDebug()
Java API: Use to enable logging at DEBUG level for certain operations when configuringcreateLogLevels(akka.event.Logging.LogLevel, akka.event.Logging.LogLevel, akka.event.Logging.LogLevel)
static Logging.LogLevel
logLevelError()
Java API: Use to enable logging at ERROR level for certain operations when configuringcreateLogLevels(akka.event.Logging.LogLevel, akka.event.Logging.LogLevel, akka.event.Logging.LogLevel)
static Logging.LogLevel
logLevelInfo()
Java API: Use to enable logging at INFO level for certain operations when configuringcreateLogLevels(akka.event.Logging.LogLevel, akka.event.Logging.LogLevel, akka.event.Logging.LogLevel)
static Logging.LogLevel
logLevelOff()
Java API: Use to disable logging on certain operations when configuringcreateLogLevels(akka.event.Logging.LogLevel, akka.event.Logging.LogLevel, akka.event.Logging.LogLevel)
static Attributes
logLevels(Logging.LogLevel onElement, Logging.LogLevel onFinish, Logging.LogLevel onFailure)
Configureslog()
operator log-levels to be used when logging.static Logging.LogLevel
logLevels$default$1()
static Logging.LogLevel
logLevels$default$2()
static Logging.LogLevel
logLevels$default$3()
static Logging.LogLevel
logLevelWarning()
Java API: Use to enable logging at WARNING level for certain operations when configuringcreateLogLevels(akka.event.Logging.LogLevel, akka.event.Logging.LogLevel, akka.event.Logging.LogLevel)
<T extends Attributes.MandatoryAttribute>
TmandatoryAttribute(scala.reflect.ClassTag<T> evidence$3)
Scala API: Get the most specific of one of the mandatory attributes.static Attributes
name(java.lang.String name)
Specifies the name of the operation.scala.Option<java.lang.String>
nameLifted()
Extracts Name attributes and concatenates them.java.lang.String
nameOrDefault(java.lang.String default_)
java.lang.String
nameOrDefault$default$1()
static Attributes.NestedMaterializationCancellationPolicy
nestedMaterializationCancellationPolicyDefault()
DefaultAttributes.NestedMaterializationCancellationPolicy
, please seenestedMaterializationCancellationPolicyEagerCancellation()
for details.static Attributes.NestedMaterializationCancellationPolicy
nestedMaterializationCancellationPolicyEagerCancellation()
Java API AAttributes.NestedMaterializationCancellationPolicy
that configures graph stages delaying nested flow materialization to cancel immediately when downstream cancels before nested flow materialization.static Attributes.NestedMaterializationCancellationPolicy
nestedMaterializationCancellationPolicyPropagateToNested()
Java API AAttributes.NestedMaterializationCancellationPolicy
that configures graph stages delaying nested flow materialization to delay cancellation when downstream cancels before nested flow materialization.static Attributes
none()
INTERNAL APIint
productArity()
Deprecated.Use explicit methods on Attributes to interact, not the ones provided by Product.java.lang.Object
productElement(int n)
Deprecated.Use explicit methods on Attributes to interact, not the ones provided by Product.static scala.Option<scala.collection.immutable.List<Attributes.Attribute>>
unapply(Attributes attrs)
Deprecated.Use explicit methods on Attributes to interact, not the synthetic case class ones.
-
-
-
Constructor Detail
-
Attributes
public Attributes(scala.collection.immutable.List<Attributes.Attribute> attributeList)
Deprecated.Use factories on companion object instead. Since 2.8.0.
-
-
Method Detail
-
$lessinit$greater$default$1
public static scala.collection.immutable.List<Attributes.Attribute> $lessinit$greater$default$1()
-
apply
public static Attributes apply()
-
apply
public static Attributes apply(scala.collection.immutable.List<Attributes.Attribute> attributeList)
-
unapply
public static scala.Option<scala.collection.immutable.List<Attributes.Attribute>> unapply(Attributes attrs)
Deprecated.Use explicit methods on Attributes to interact, not the synthetic case class ones. Since 2.8.0.
-
cancellationStrategyCompleteState
public static akka.stream.Attributes.CancellationStrategy.Strategy cancellationStrategyCompleteState()
Java APIStrategy that treats
cancelStage
the same ascompleteStage
, i.e. all inlets are cancelled (propagating the cancellation cause) and all outlets are regularly completed.This used to be the default behavior before Akka 2.6.
This behavior can be problematic in stacks of BidiFlows where different layers of the stack are both connected through inputs and outputs. In this case, an error in a doubly connected component triggers both a cancellation going upstream and an error going downstream. Since the stack might be connected to those components with inlets and outlets, a race starts whether the cancellation or the error arrives first. If the error arrives first, that's usually good because then the error can be propagated both on inlets and outlets. However, if the cancellation arrives first, the previous default behavior to complete the stage will lead other outputs to be completed regularly. The error which arrive late at the other hand will just be ignored (that connection will have been cancelled already and also the paths through which the error could propagates are already shut down).
-
cancellationStrategyFailStage
public static akka.stream.Attributes.CancellationStrategy.Strategy cancellationStrategyFailStage()
Java APIStrategy that treats
cancelStage
the same asfailStage
, i.e. all inlets are cancelled (propagating the cancellation cause) and all outlets are failed propagating the cause from cancellation.
-
cancellationStrategyPropagateFailure
public static akka.stream.Attributes.CancellationStrategy.Strategy cancellationStrategyPropagateFailure()
Java APIStrategy that treats
cancelStage
in different ways depending on the cause that was given to the cancellation.If the cause was a regular, active cancellation (
SubscriptionWithCancelException.NoMoreElementsNeeded
), the stage receiving this cancellation is completed regularly.If another cause was given, this is treated as an error and the behavior is the same as with
failStage
.This is a good default strategy.
-
cancellationStrategyAfterDelay
public static akka.stream.Attributes.CancellationStrategy.Strategy cancellationStrategyAfterDelay(scala.concurrent.duration.FiniteDuration delay, akka.stream.Attributes.CancellationStrategy.Strategy strategy)
Java APIStrategy that allows to delay any action when
cancelStage
is invoked.The idea of this strategy is to delay any action on cancellation because it is expected that the stage is completed through another path in the meantime. The downside is that a stage and a stream may live longer than expected if no such signal is received and cancellation is invoked later on. In streams with many stages that all apply this strategy, this strategy might significantly delay the propagation of a cancellation signal because each upstream stage might impose such a delay. During this time, the stream will be mostly "silent", i.e. it cannot make progress because of backpressure, but you might still be able observe a long delay at the ultimate source.
-
nestedMaterializationCancellationPolicyEagerCancellation
public static Attributes.NestedMaterializationCancellationPolicy nestedMaterializationCancellationPolicyEagerCancellation()
Java API AAttributes.NestedMaterializationCancellationPolicy
that configures graph stages delaying nested flow materialization to cancel immediately when downstream cancels before nested flow materialization. This applies toakka.stream.scaladsl.FlowOps.flatMapPrefix
,akka.stream.scaladsl.Flow.futureFlow
and derived operators.
-
nestedMaterializationCancellationPolicyPropagateToNested
public static Attributes.NestedMaterializationCancellationPolicy nestedMaterializationCancellationPolicyPropagateToNested()
Java API AAttributes.NestedMaterializationCancellationPolicy
that configures graph stages delaying nested flow materialization to delay cancellation when downstream cancels before nested flow materialization. Once the nested flow is materialized it will be cancelled immediately. This applies toakka.stream.scaladsl.FlowOps.flatMapPrefix
,akka.stream.scaladsl.Flow.futureFlow
and derived operators.
-
nestedMaterializationCancellationPolicyDefault
public static Attributes.NestedMaterializationCancellationPolicy nestedMaterializationCancellationPolicyDefault()
DefaultAttributes.NestedMaterializationCancellationPolicy
, please seenestedMaterializationCancellationPolicyEagerCancellation()
for details.
-
logLevelOff
public static Logging.LogLevel logLevelOff()
Java API: Use to disable logging on certain operations when configuringcreateLogLevels(akka.event.Logging.LogLevel, akka.event.Logging.LogLevel, akka.event.Logging.LogLevel)
-
logLevelError
public static Logging.LogLevel logLevelError()
Java API: Use to enable logging at ERROR level for certain operations when configuringcreateLogLevels(akka.event.Logging.LogLevel, akka.event.Logging.LogLevel, akka.event.Logging.LogLevel)
-
logLevelWarning
public static Logging.LogLevel logLevelWarning()
Java API: Use to enable logging at WARNING level for certain operations when configuringcreateLogLevels(akka.event.Logging.LogLevel, akka.event.Logging.LogLevel, akka.event.Logging.LogLevel)
-
logLevelInfo
public static Logging.LogLevel logLevelInfo()
Java API: Use to enable logging at INFO level for certain operations when configuringcreateLogLevels(akka.event.Logging.LogLevel, akka.event.Logging.LogLevel, akka.event.Logging.LogLevel)
-
logLevelDebug
public static Logging.LogLevel logLevelDebug()
Java API: Use to enable logging at DEBUG level for certain operations when configuringcreateLogLevels(akka.event.Logging.LogLevel, akka.event.Logging.LogLevel, akka.event.Logging.LogLevel)
-
apply
public static Attributes apply(Attributes.Attribute attribute)
INTERNAL API
-
apply$default$1
public static scala.collection.immutable.List<Attributes.Attribute> apply$default$1()
-
none
public static Attributes none()
INTERNAL API
-
asyncBoundary
public static Attributes asyncBoundary()
-
name
public static Attributes name(java.lang.String name)
Specifies the name of the operation. If the name is null or empty the name is ignored, i.e.none()
is returned.
-
inputBuffer
public static Attributes inputBuffer(int initial, int max)
Each asynchronous piece of a materialized stream topology is executed by one Actor that manages an input buffer for all inlets of its shape. This attribute configures the initial and maximal input buffer in number of elements for each inlet.
-
createLogLevels
public static Attributes createLogLevels(Logging.LogLevel onElement, Logging.LogLevel onFinish, Logging.LogLevel onFailure)
Java APIConfigures
log()
operator log-levels to be used when logging. Logging a certain operation can be completely disabled by usinglogLevelOff()
.
-
createLogLevels
public static Attributes createLogLevels(Logging.LogLevel onElement)
Java APIConfigures
log()
operator log-levels to be used when logging onElement. Logging a certain operation can be completely disabled by usinglogLevelOff()
.
-
logLevels
public static Attributes logLevels(Logging.LogLevel onElement, Logging.LogLevel onFinish, Logging.LogLevel onFailure)
Configureslog()
operator log-levels to be used when logging. Logging a certain operation can be completely disabled by usingLogLevels.Off
.See
Attributes.createLogLevels
for Java API
-
logLevels$default$1
public static Logging.LogLevel logLevels$default$1()
-
logLevels$default$2
public static Logging.LogLevel logLevels$default$2()
-
logLevels$default$3
public static Logging.LogLevel logLevels$default$3()
-
extractName
public static java.lang.String extractName(akka.stream.impl.TraversalBuilder builder, java.lang.String default_)
Compute a name by concatenating all Name attributes that the given module has, returning the given default value if none are found.
-
attributeList
public scala.collection.immutable.List<Attributes.Attribute> attributeList()
-
getAttribute
public <T extends Attributes.Attribute> T getAttribute(java.lang.Class<T> c, T default_)
Java API: Get the most specific attribute value for a given Attribute type or subclass thereof. If no such attribute exists, return adefault
value.The most specific value is the value that was added closest to the graph or operator itself or if the same attribute was added multiple times to the same graph, the last to be added.
This is the expected way for operators to access attributes.
-
getAttribute
public <T extends Attributes.Attribute> java.util.Optional<T> getAttribute(java.lang.Class<T> c)
Java API: Get the most specific attribute value for a given Attribute type or subclass thereof.The most specific value is the value that was added closest to the graph or operator itself or if the same attribute was added multiple times to the same graph, the last to be added.
This is the expected way for operators to access attributes.
-
get
public <T extends Attributes.Attribute> T get(T default_, scala.reflect.ClassTag<T> evidence$1)
Scala API: Get the most specific attribute value for a given Attribute type or subclass thereof or if no such attribute exists, return a default value.The most specific value is the value that was added closest to the graph or operator itself or if the same attribute was added multiple times to the same graph, the last to be added.
This is the expected way for operators to access attributes.
-
get
public <T extends Attributes.Attribute> scala.Option<T> get(scala.reflect.ClassTag<T> evidence$2)
Scala API: Get the most specific attribute value for a given Attribute type or subclass thereof.The most specific value is the value that was added closest to the graph or operator itself or if the same attribute was added multiple times to the same graph, the last to be added.
This is the expected way for operators to access attributes.
-
mandatoryAttribute
public <T extends Attributes.MandatoryAttribute> T mandatoryAttribute(scala.reflect.ClassTag<T> evidence$3)
Scala API: Get the most specific of one of the mandatory attributes. Mandatory attributes are guaranteed to always be among the attributes when the attributes are coming from a materialization.Note: looks for the exact mandatory attribute class, hierarchies of the same mandatory attribute not supported
-
getMandatoryAttribute
public <T extends Attributes.MandatoryAttribute> T getMandatoryAttribute(java.lang.Class<T> c)
Java API: Get the most specific of one of the mandatory attributes. Mandatory attributes are guaranteed to always be among the attributes when the attributes are coming from a materialization.Note: looks for the exact mandatory attribute class, hierarchies of the same mandatory attribute not supported
- Parameters:
c
- A class that is a subtype ofAttributes.MandatoryAttribute
-
and
public Attributes and(Attributes other)
Adds given attributes. Added attributes are considered more specific than already existing attributes of the same type.
-
and
public Attributes and(Attributes.Attribute other)
Adds given attribute. Added attribute is considered more specific than already existing attributes of the same type.
-
nameLifted
public scala.Option<java.lang.String> nameLifted()
Extracts Name attributes and concatenates them.
-
nameOrDefault
public java.lang.String nameOrDefault(java.lang.String default_)
-
nameOrDefault$default$1
public java.lang.String nameOrDefault$default$1()
-
contains
public boolean contains(Attributes.Attribute attr)
Test whether the given attribute is contained within this attributes list.Note that operators in general should not inspect the whole hierarchy but instead use
get
to get the most specific attribute value.
-
getAttributeList
public java.util.List<Attributes.Attribute> getAttributeList()
Java APIThe list is ordered with the most specific attribute first, least specific last. Note that the order was the opposite in Akka 2.4.x.
Note that operators in general should not inspect the whole hierarchy but instead use
get
to get the most specific attribute value.
-
getAttributeList
public <T extends Attributes.Attribute> java.util.List<T> getAttributeList(java.lang.Class<T> c)
Java API: Get all attributes of a givenClass
or subclass thereof.The list is ordered with the most specific attribute first, least specific last. Note that the order was the opposite in Akka 2.4.x.
Note that operators in general should not inspect the whole hierarchy but instead use
get
to get the most specific attribute value.
-
filtered
public <T extends Attributes.Attribute> scala.collection.immutable.List<T> filtered(scala.reflect.ClassTag<T> evidence$4)
Scala API: Get all attributes of a given type (or subtypes thereof).Note that operators in general should not inspect the whole hierarchy but instead use
get
to get the most specific attribute value.The list is ordered with the most specific attribute first, least specific last. Note that the order was the opposite in Akka 2.4.x.
-
getFirst
public <T extends Attributes.Attribute> scala.Option<T> getFirst(scala.reflect.ClassTag<T> evidence$5)
Deprecated.Attributes should always be most specific, use get[T]. Since 2.5.7.Scala API: Get the least specific attribute (added first) of a given type parameter TClass
or subclass thereof.
-
productArity
public int productArity()
Deprecated.Use explicit methods on Attributes to interact, not the ones provided by Product. Since 2.8.0.- Specified by:
productArity
in interfacescala.Product
-
productElement
public java.lang.Object productElement(int n)
Deprecated.Use explicit methods on Attributes to interact, not the ones provided by Product. Since 2.8.0.- Specified by:
productElement
in interfacescala.Product
-
copy
public Attributes copy(scala.collection.immutable.List<Attributes.Attribute> attributeList)
Deprecated.Don't use copy on Attributes. Since 2.8.0.
-
copy$default$1
public scala.collection.immutable.List<Attributes.Attribute> copy$default$1()
-
canEqual
public boolean canEqual(java.lang.Object that)
- Specified by:
canEqual
in interfacescala.Equals
-
equals
public boolean equals(java.lang.Object other)
- Specified by:
equals
in interfacescala.Equals
- Overrides:
equals
in classjava.lang.Object
-
hashCode
public int hashCode()
- Overrides:
hashCode
in classjava.lang.Object
-
-