<div dir="ltr"><div><div><div>Thank you Jozef for your helpful response! I have another clarification on the interceptors on JavaEE component classes. <br><br>EE7 spec states the JavaEE component classes, listed in Table EE.5-1, need to support interceptors. Take servlet for an example, which methods can be intercepted?<br><br></div>As the servlet classes are invoked by the container, according to CDI1.2 spec, it seems only service(ServletRequest, ServletResponse) can be intercepted. No other methods can be intercepted. <br><br>Normally customer applications override doPost or doGet, but they cannot be intercepted. I cannot see any value of support interceptors on Servlet. Anything I missed?<br></div>Thanks<br></div>Emily<br></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, May 7, 2015 at 8:22 AM, Jozef Hartinger <span dir="ltr"><<a href="mailto:jharting@redhat.com" target="_blank">jharting@redhat.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div text="#000000" bgcolor="#FFFFFF">
Hi Emily, comments inline.<span class=""><br>
<br>
<div>On 05/06/2015 05:38 PM, Emily Jiang
wrote:<br>
</div>
<blockquote type="cite">
<div dir="ltr">
<div>
<div>
<div>
<div>I have a few questions on ejb integration on Weld. <br>
<br>
</div>
1)Does Weld handle the instance creation for ejb (using
injectionTarget.produce) or delegate the instance creation
to EJB container? I guess Weld will create the instead as
it can manage decorators. If not, how can decorators be
managed? Please confirm.<br>
</div>
</div>
</div>
</div>
</blockquote></span>
Correct. Weld creates EJB instances using InjectionTarget.produce()<span class=""><br>
<blockquote type="cite">
<div dir="ltr">
<div>
<div>
<div><br>
</div>
2) When Weld creates the EJB instance, how can the other
non-CDI aroundconstruct interceptors (such as the
interceptors defined via ejb-jar.xml or @Interceptors) be
passed in? I found out the WeldCreationContext and
AroundConstructCallback but I cannot find anything mentioned
in the weld reference doc. Is this the right plugin point?<br>
</div>
</div>
</div>
</blockquote></span>
Correct, AroundConstructCallback is the API you need to use. The
JavaDoc should be helpful. Let me know if anything is not clear.
I'll add a note about it to the refdoc.<span class=""><br>
<blockquote type="cite">
<div dir="ltr">
<div>
<div><br>
</div>
3)If Weld creates the EJB instance, how can all interceptors
(cdi style and ejb style) be invoked? Will the instance need
to be passed back to EJB container together with all CDI
interceptors (get hold of them via
EjbEndpointServiceImpl.java) and EJB container needs to manage
the interceptors being invoked?<br>
</div>
</div>
</blockquote></span>
For interception type other than @AroundConstruct we leave it up to
the EJB implementation to handle interception. Information about CDI
interceptors is exposed to the EJB implementation via
EjbServices.registerInterceptors()<span class=""><br>
<blockquote type="cite">
<div dir="ltr">
<div><br>
</div>
4)In Weld spec, it says you must register the
SessionBeanInterceptor as the inner most interceptor in the
stack for all EJBS. Can you clarify what inner most means? Does
this interceptor need to be the first EJB interceptor to be
called or the last EJB interceptor to be invoked?<br>
</div>
</blockquote></span>
Not sure why it says inner most - it should be outer most instead
that is it should be called as first so that the @RequestScope is
available for the other interceptors called later in the chain.<br>
<blockquote type="cite"><span class="">
<div dir="ltr">
<div>
<div>
<div>
<div>
<div>
<div><br clear="all">
<div><br>
-- <br>
<div>Thanks<br>
Emily<br>
=================<br>
Emily Jiang<br>
<a href="mailto:ejiang@apache.org" target="_blank">ejiang@apache.org</a><br>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<br>
<fieldset></fieldset>
<br>
</span><pre>_______________________________________________
weld-dev mailing list
<a href="mailto:weld-dev@lists.jboss.org" target="_blank">weld-dev@lists.jboss.org</a>
<a href="https://lists.jboss.org/mailman/listinfo/weld-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/weld-dev</a></pre>
</blockquote>
<br>
</div>
</blockquote></div><br><br clear="all"><br>-- <br><div class="gmail_signature">Thanks<br>Emily<br>=================<br>Emily Jiang<br><a href="mailto:ejiang@apache.org" target="_blank">ejiang@apache.org</a><br></div>
</div>