[cdi-dev] Fwd: [jsr342-experts] request scope for Web Sockets?

Mark Struberg struberg at yahoo.de
Sun May 26 04:24:50 EDT 2013


Hi!

A user can easily use CDI in WebSocket apps already via DeltaSpike ContextControl. Even if the container does not yet support it.


LieGrue,
strub





----- Original Message -----
> From: Pete Muir <pmuir at bleepbleep.org.uk>
> To: "cdi-dev at lists.jboss.org" <cdi-dev at lists.jboss.org>
> Cc: 
> Sent: Wednesday, 22 May 2013, 12:15
> Subject: [cdi-dev] Fwd: [jsr342-experts] request scope for Web Sockets?
> 
> All, please see below, and let me know your thoughts.
> 
> I would prefer to see the Web Sockets spec handle this, just like we had JTA 
> handle the TransactionScoped context details.
> 
> Begin forwarded message:
> 
>>  From: Bill Shannon <bill.shannon at oracle.com>
>>  Subject: [jsr342-experts] request scope for Web Sockets?
>>  Date: 16 May 2013 19:21:40 BST
>>  To: jsr342-experts at javaee-spec.java.net
>>  Cc: Joseph Snyder <J.J.SNYDER at oracle.com>, Danny Coward 
> <danny.coward at oracle.com>, Rajiv Mordani <Rajiv.Mordani at oracle.com>, 
> "CHAN,SHING WAI" <shing.wai.chan at oracle.com>
>>  Reply-To: jsr342-experts at javaee-spec.java.net
>> 
>>  Experts,
>> 
>>  An issue has come up about the definition of the CDI request scope and how
>>  it applies to Web Sockets applications.  The issue is reported here:
>>  https://issues.jboss.org/browse/CDI-370
>> 
>>  We're trying to decide whether this is a simple oversight that could be
>>  corrected with an errata to the existing spec(s), or whether it's a 
> missing
>>  requirement that would require a new revision of the spec(s).  Since this
>>  involves the interaction of three specs, I'm starting the conversation 
> here.
>> 
>>  Danny, Pete, Shing Wai, please forward this message to your expert groups
>>  for their input as well.
>> 
>> 
>>  Here's the definition of when a request scope is active and when it is 
> destroyed:
>> 
>>>  The request scope is active:
>>> 
>>>     - during the service() method of any servlet in the web
>>>       application, during the doFilter() method of any servlet filter 
> and
>>>       when the container calls any ServletRequestListener or 
> AsyncListener,
>>>     - during any Java EE web service invocation,
>>>     - during any remote method invocation of any EJB, during any
>>>       asynchronous method invocation of any EJB, during any call to an 
> EJB
>>>       timeout method and during message delivery to any EJB 
> message-driven
>>>       bean, and
>>>     - during any message delivery to a MessageListener for a JMS
>>>       topic or queue obtained from the Java EE component environment.
>>> 
>>>  The request context is destroyed:
>>> 
>>>     - at the end of the servlet request, after the service() method, all
>>>       doFilter() methods, and all requestDestroyed() and onComplete()
>>>       notifications return,
>>>     - after the web service invocation completes,
>>>     - after the EJB remote method invocation, asynchronous method 
> invocation,
>>>       timeout or message delivery completes, or
>>>     - after the message delivery to the MessageListener completes.
>> 
>>  It would be easy to "fix" the first bullet in each list above by 
> saying
>>  "oops, we forgot to include the work done by a protocol handler in
>>  Servlet 3.1".  Since all this other work done by Servlet applications
>>  is part of the same request scope, adding the work done by protocol
>>  handlers would make sense.
>> 
>>  But, we have to decide if that's the fix we want.
>> 
>>  Adding bullet items to each list to cover specific Web Socket operations
>>  might be more what people are expecting, resulting in a request scope for
>>  Web Sockets that's "smaller" than the request scope for the 
> corresponding
>>  http request.  Even if we did that, we would still need to define clearly
>>  whether or not a request scope is active during any arbitrary protocol
>>  handler operation (not just Web Socket protocol handlers).  Defining it
>>  for Web Sockets but not defining it for protocol handlers in general might
>>  be acceptable.  Defining it one way for Web Sockets and a different way
>>  for other protocol handlers would not be acceptable.
>> 
>> 
>>  Should we fix this as an errata by saying that obviously protocol handler
>>  operations should've been included in those lists of Servlet 
> operations?
>> 
>>  Or should we add items to each list to cover specifically Web Socket
>>  operations?  (In which case what do we say about protocol handlers in
>>  general?)  This would clearly require a new version of either the CDI
>>  spec or the Web Sockets spec.
>> 
>>  If we defined all Web Socket operations for a single http request to be
>>  part of the same request scope (the "errata" approach), we could 
> later
>>  define a "message" scope or something similar to cover individual 
> Web Socket
>>  operations.
>> 
>>  Let us know what you think.
> 
> 
> _______________________________________________
> cdi-dev mailing list
> cdi-dev at lists.jboss.org
> https://lists.jboss.org/mailman/listinfo/cdi-dev
> 



More information about the cdi-dev mailing list