[cdi-dev] New Servlet related scope - @UpgradeScoped (?)

Martin Kouba mkouba at redhat.com
Thu Dec 4 04:04:56 EST 2014


Dne 4.12.2014 v 09:28 Pavel Bucek napsal(a):
> Hello Arjan,
>
> On 03/12/14 19:44, arjan tijms wrote:
>> Hi,
>>
>> On Wednesday, December 3, 2014, Pavel Bucek <pavel.bucek at oracle.com
>> <mailto:pavel.bucek at oracle.com>> wrote:
>>
>>     Hi all,
>>
>>     I'm trying to figure out how to solve issue in JSR 356 - Java API for
>>     WebSocket, related to CDI scope usable from WebSocket endpoints.
>>     Problem
>>     is, that "standard" scopes do not apply, because there is no
>>     @RequestScoped (http response is already sent), HttpSession does not
>>     need to be created and the rest does not seem to be applicable, ...
>>
>>     I believe that CDI specification should define @UpgradeScoped, which
>>     would cover usages of HttpUpgradeHandler from Servlet API.
>>     (Similarly as
>>     it does for @RequestScoped, @SessionScoped, ... )
>>
>>
>> Wouldn't it be a better option to have WebSocket define that scope,
>> using CDI to implement it?
>
> That is one possibility, but @UpgradeScoped would be more general than
> just for WebSocket - it would apply for all HTTP/1.1+ Upgrade
> applications. In my eyes, it is something which was forgotten to do in
> Java EE 7 release, since HttpUpgradeHandler was introduced in it.
>
> Also please note, that other Servlet related scopes are already in CDI
> spec, so it seems like it belongs there more than anywhere else. This
> might have multiple reasons - for example, you can easily define
> relationship between @UpgradeScoped and others, already existing ones.
> In this sense, CDI specification now depends on Servlet API (it
> references some of the classes defined in it), but Servlet does not do
> that for CDI. I don't think that Servlet spec should introduce similar
> dependency just because of new scope.

That's a good point. However, I don't think it's a good path to follow. 
I mean if it were in CDI spec, CDI implementations would be required to 
implement this. However, Servlet spec is not very clear in many areas 
and doesn't always provide a powerful enough SPI. Even now there are 
technical issues with similar requirements (e.g. @RequestScoped during 
AsyncListener invocations). I'm not so sure about HttpUpgradeHandler 
though...

>
> Thanks,
> Pavel
>
>
>
> _______________________________________________
> cdi-dev mailing list
> cdi-dev at lists.jboss.org
> https://lists.jboss.org/mailman/listinfo/cdi-dev
>
> Note that for all code provided on this list, the provider licenses the code under the Apache License, Version 2 (http://www.apache.org/licenses/LICENSE-2.0.html). For all other ideas provided on this list, the provider waives all patent and other intellectual property rights inherent in such information.
>


More information about the cdi-dev mailing list