public abstract static class SseEventSource.Builder
extends java.lang.Object
SseEventSource
builder class.
Event source builder provides methods that let you conveniently configure and subsequently build
a new SseEventSource
instance. You can obtain a new event source builder instance using
a static SseEventSource.target(endpoint)
factory method.
For example:
SseEventSource es = SseEventSource.target(endpoint) .reconnectingEvery(5, SECONDS) .build(); es.register(System.out::println); es.open();
Modifier and Type | Field and Description |
---|---|
static java.lang.String |
JAXRS_DEFAULT_SSE_BUILDER_PROPERTY
Name of the property identifying the
SseEventSource.Builder implementation
to be returned from newBuilder() . |
Modifier | Constructor and Description |
---|---|
protected |
Builder()
Allows custom implementations to extend the SSE event source builder class.
|
Modifier and Type | Method and Description |
---|---|
abstract SseEventSource |
build()
Build new SSE event source pointing at a SSE streaming
web target . |
abstract SseEventSource.Builder |
reconnectingEvery(long delay,
java.util.concurrent.TimeUnit unit)
Set the initial reconnect delay to be used by the event source.
|
protected abstract SseEventSource.Builder |
target(WebTarget endpoint) |
public static final java.lang.String JAXRS_DEFAULT_SSE_BUILDER_PROPERTY
SseEventSource.Builder
implementation
to be returned from newBuilder()
.protected Builder()
protected abstract SseEventSource.Builder target(WebTarget endpoint)
public abstract SseEventSource.Builder reconnectingEvery(long delay, java.util.concurrent.TimeUnit unit)
Note that this value may be later overridden by the SSE endpoint using either a retry
SSE event field
or HTTP 503 + "Retry-After"
mechanism as described
in the SseEventSource
javadoc.
delay
- the default time to wait before attempting to recover from a connection loss.unit
- time unit of the reconnect delay parameter.public abstract SseEventSource build()
web target
.
The returned event source is ready, but not connected
to the SSE endpoint.
It is expected that you will manually invoke its SseEventSource.open()
method once you are ready to start
receiving SSE events. In case you want to build an event source instance that is already connected
to the SSE endpoint, use the event source builder SseEventSource.open()
method instead.
Once the event source is open, the incoming events are processed by the event source in an
asynchronous task that runs in an internal single-threaded scheduled executor service
.
SseEventSource.open()