T - the converted type.public interface ReactiveTypeConverter<T>
CompletionStage and Publisher.
In addition to conversion operations, this class provides characteristics on the converted type:
<T> may emit at most one item<T> may emit multiple items<T> may emit null values
Implementations must be tested against the TCK by extending the test case from the
io.smallrye.reactive.converters.tck packages.
| Modifier and Type | Method and Description |
|---|---|
boolean |
emitAtMostOneItem() |
boolean |
emitItems() |
<X> T |
fromCompletionStage(CompletionStage<X> cs)
Transforms an instance of
CompletionStage to an instance of T. |
<X> T |
fromPublisher(org.reactivestreams.Publisher<X> publisher)
Transforms an instance of
T to a Publisher. |
default boolean |
requireAtLeastOneItem() |
boolean |
supportNullValue() |
<X> CompletionStage<X> |
toCompletionStage(T instance)
Transforms an instance of
T to a CompletionStage completed with a potential value. |
<X> org.reactivestreams.Publisher<X> |
toRSPublisher(T instance)
Transforms an instance of
T to a Publisher. |
Class<T> |
type() |
<X> CompletionStage<X> toCompletionStage(T instance)
T to a CompletionStage completed with a potential value.
Each converter instances can use specific rules, however the following set of rules are mandatory:
CompletionStage must never be null.CompletionStage completes with the first emitted value. This value may be null
for empty stream or instance of T emitting null as first value.instance emits several values, only the first one is considered, others are
discarded.instance fails before emitting a value, the returned CompletionStage
completes with this failure.instance does not emit any value and does not fail or complete, the returned
CompletionStage does not complete.instance completes beforeCompletionStage is completed with a null value.instance emits null as first value (if supported), the
CompletionStage is completed with null. As a consequence, there are no
differences between an instance emitting null as first value or completing without emitting
a value. If the instance does not support emitting null values, the returned
CompletionStage must be completed with a failure.X - the type used to complete the returned CompletionStage.
It is generally the type of data emitted by the passed instance.instance - the instance to convert to a CompletionStage. Must not be null.non-null CompletionStage.<X> org.reactivestreams.Publisher<X> toRSPublisher(T instance)
T to a Publisher.
Each converter instances can use specific rules, however the following set of rules are mandatory:
Publisher must never be null.instance are emitted by the returned Publisher.instance emits a failure, Publisher propagates the same failure and
terminates.instance completes, Publisher also completes.instance does not emit any value and does not fail or complete, the returned
Publisher does not send any signals or values.instance completes beforePublisher
also completes empty.instance emits null, the Publisher must send a failure
(NullPointerException.instance support back-pressure, the resulting Publisher must enforce
back-pressure. When the instance does not support back-pressure, the Publisher consumes
the data without back-pressure using an unbounded-buffer. In other words, this operation is a pass-through
for back-pressure and its behavior is determined by the back-pressure behavior of the passed
instance.X - the type emitted by the returned Publisher. It
is generally the type of data emitted by the passed instance.instance - the instance to convert to a Publisher. Must not be null.non-null Publisher.<X> T fromCompletionStage(CompletionStage<X> cs)
CompletionStage to an instance of T. The value emitted by T
depends on the completion of the passed CompletionStage. Each converter instances can use specific rules,
however the following set of rules are mandatory:
T must never be null.CompletionStage never completes, no values are emitted by the returned
T.CompletionStage redeems a null value, and if T support null
values, null is emitted by the returned instance of T.CompletionStage redeems a null value, and if T does not support
null values, a failure is emitted by the returned instance of T.CompletionStage redeems a non-null value, the value is emitted by the
returned instance of T.CompletionStage is completed with a failure, the same failure is emitted by
the returned instance of T.CompletionStage is cancelled before having completed, the
CancellationException must be emitted by the returned instance.
Implementations must not expect the CompletionStage to be instances of
CompletableFuture.
Implementations may decide to adapt the emitted result when receiving container object such as Optional.
X - the type of result provided by the CompletionStagecs - the instance of CompletionStage, must not be nullX.<X> T fromPublisher(org.reactivestreams.Publisher<X> publisher)
T to a Publisher.
Each converter instances can use specific rules, however the following set of rules are mandatory:
Publisher must never be null.T emits a single value, the returned Publisher emits the same value
and completes.T does not emits value, sends the completion signal, the returned
Publisher completes.T emits a failure, the returned Publisher emits a failure.T emits a null value, the returned Publisher emits an
NullPointerException as null is not a valid value.T does neither emits a value nor a signal, the returned Publisher
does not emits values or signals.X - the type of data emitted by the passed Publisher.publisher - the Publisher to convert. Must not be null.non-null instance of T.Class<T> type()
null. Notice that sub-classes of the returned class are also
managed by the same converter.boolean emitItems()
true if the type T may emit items, false otherwise.boolean emitAtMostOneItem()
true if the type T may emit items at most one item, false otherwise. Returning
false to this method means that the converted type only signals about completion or error. Returning
true means that emitItems() must also return true.boolean supportNullValue()
true if the type T can emit or receive null as item.default boolean requireAtLeastOneItem()
true if the type T require at least one item. Converting from a type not emitting a
value item would fail.Copyright © 2018–2019 SmallRye. All rights reserved.