jsr370-experts@jax-rs-spec.java.net

Re: [jax-rs-spec users] SSE in non-JavaEE environments

From: Marek Potociar <marek.potociar_at_oracle.com>
Date: Fri, 27 Nov 2015 17:06:12 +0100

Just for your reference, here’s the link to the pull request:
https://github.com/jax-rs/api/pull/2 <https://github.com/jax-rs/api/pull/2>

Marek

> On 27 Nov 2015, at 17:05, Marek Potociar <marek.potociar_at_oracle.com> wrote:
>
> Not sure I understand I did post the full code. What else do you need?
>
> Marek
>
>> On 24 Nov 2015, at 17:55, Markus KARG <markus_at_headcrashing.eu <mailto:markus_at_headcrashing.eu>> wrote:
>>
>> I think it would be best if Santiago posts the proposed full code example. I believe that your proposal is well-done, but I simply need to see some source code answering my original question. :-)
>>
>> From: Marek Potociar [mailto:marek.potociar_at_oracle.com <mailto:marek.potociar_at_oracle.com>]
>> Sent: Montag, 23. November 2015 16:51
>> To: jsr370-experts_at_jax-rs-spec.java.net <mailto:jsr370-experts_at_jax-rs-spec.java.net>
>> Subject: Re: [jax-rs-spec users] SSE in non-JavaEE environments
>>
>> Hi Markus,
>>
>> This is the assumption in our current design:
>>
>> SSE Output = single SSE client connection
>>
>> Does that make the concept clearer?
>>
>> Marek
>>
>>
>>> On 27 Oct 2015, at 20:14, Markus KARG <markus_at_headcrashing.eu <mailto:markus_at_headcrashing.eu>> wrote:
>>>
>>> So this means that there is only one SseContext for all injections? How to separate the different "event sinks" then? The code example only shows "sslContext.newOutput()"… so is there only one "event sink" for all resources, or is the "event sink" private to the resource class… or is there a "newOutput(String eventSinkName)"?
>>>
>>> From: Santiago Pericasgeertsen [mailto:santiago.pericasgeertsen_at_oracle.com <mailto:santiago.pericasgeertsen_at_oracle.com>]
>>> Sent: Dienstag, 27. Oktober 2015 19:36
>>> To: jsr370-experts_at_jax-rs-spec.java.net <mailto:jsr370-experts_at_jax-rs-spec.java.net>
>>> Subject: Re: [jax-rs-spec users] SSE in non-JavaEE environments
>>>
>>> Markus,
>>>
>>> We should probably come up with a different example to better reflect how the API works. There is nothing in the API that requires the use of @Singleton for things to work. It is possible to write SSE samples using the default request scope and without using statics (but with the SseContext injected as shown in the example).
>>>
>>> — Santiago
>>>
>>>> On Oct 26, 2015, at 2:31 PM, Markus KARG <markus_at_headcrashing.eu <mailto:markus_at_headcrashing.eu>> wrote:
>>>>
>>>> Santiago and Marek,
>>>>
>>>> I discovered one more issue with the SSE proposal and like to ask the following question:
>>>>
>>>> The SSE example you posted uses the @Singleton annotation from the javax.inject package. Typically this instructs a Java EE server to create exactly one instance of a JAX-RS resource, hence is a guarantee that both, the SSE event source and the SSE event sink are defintively the same instance due to the singleton JAX-RS resource. This constraint apparently is needed to allow the SseEventOutput to correctly route the events from the SSE event source (the one being triggered by a posting client) to the SSE event sink (the one pushing SSE clients).
>>>>
>>>> As the JAX-RS specification does not say that support for @Singleton is mandatory on non-Java EE environments, the question is: How will this routing from SSE source to SSE sink work on Java SE? Will it be necessary for the application programmer to explicitly use a shared, static instance, or do you plan to provide some kind of service registry where shared SseEventOutput instances have to be looked up (which would also work on Java EE as a common programming model)? Related is the question whether different kinds of JAX-RS resources will be able to share an instance of SseEventOutput, so for example Resource A will push and event to SSE clients whenever a method of Resource B is invoked?
>>>>
>>>> Thanks
>>>> -Markus
>