- 
        1. Re: Conditional observersgavin.king Oct 28, 2009 8:24 PM (in response to william.drai)Hrm. Interesting. Ordinary beans are not allowed to observe container lifecycle events. It seems like we should make that explicit and validated at startup time... 
- 
        2. Re: Conditional observerswilliam.drai Oct 29, 2009 12:00 PM (in response to william.drai)In fact I don't want to observe container lifecycle events. 
 I just want to observe all my application events (thus the Object type) and preferably without having to implement a ApplicationEvent interface, so it would be a problem for me if what I do became forbidden by the spec.
- 
        3. Re: Conditional observersgavin.king Oct 29, 2009 3:12 PM (in response to william.drai)I don't see how we could really make this work. You've explicitly specified that you want everything, by using @Any. To be honest, I really don't see your usecase for this. 
- 
        4. Re: Conditional observerspmuir Oct 29, 2009 4:14 PM (in response to william.drai)
 Gavin King wrote on Oct 28, 2009 20:24:
 Hrm. Interesting. Ordinary beans are not allowed to observe container lifecycle events. It seems like we should make that explicit and validated at startup time...This is a bug. We shouldn't be firing lifecycle events to anything that doesn't impl extension. Please file a WELD issue with classes to reproduce. 
- 
        5. Re: Conditional observerswilliam.drai Oct 29, 2009 4:21 PM (in response to william.drai)In fact this already works (almost...). This global event handler will select itself which events it needs to process, that's why I want to observe @Any Object, no problem with this, the handler can just ignore lifecycle events. 
 The problem is that Weld tries to trigger this observer during application startup when there is no session context. I thought that IF_EXISTS would be enough to avoid this but this is not the case because Weld still tries to get the bean reference and gets a ContextNotActiveException.Anyway I've found a way to do what I want, hopefully this will be 'legal' in the final release : public class GlobalObserver { @Inject private BeanManager manager; public void processEvent(@Observes(notifyObserver=Notify.ALWAYS) @Any Object event) { try { Bean<GlobalEventHandler> gehBean = (Bean<GlobalEventHandler>)manager.getBeans(GlobalEventHandler.class).iterator().next(); GlobalEventHandler eventHandler = (GlobalEventHandler)manager.getReference(gehBean, GlobalEventHandler.class); if (eventHandler != null) eventHandler.processEvent(event); } catch (ContextNotActiveException e) { // Ignore event, no session context } } } @SessionScoped public class GlobalEventHandler { public void processEvent(Object event) { ... } }The use case is relatively specific as I'm working on the integration of Flex and JCDI/Weld in the GraniteDS project. This global handler is meant to send back to the Flex client some events for which the client has registered itself as listener. 
 Maybe there is another way to do this with portable extensions, but I've not seen anything that would allow for intercepting any kind of event, or at least to register dynamically event observers once the application is deployed (that enough would probably fit my needs).
- 
        6. Re: Conditional observersgavin.king Oct 29, 2009 4:31 PM (in response to william.drai)
 This is a bug. We shouldn't be firing lifecycle events to anything that doesn't impl extension.Hrm. I agree that this sounds desirable, and I can see how you would probably read the spec to imply that, but it's not explicit in the spec. I suppose I should make that explicit. Let me think about it. 
- 
        7. Re: Conditional observersgavin.king Oct 29, 2009 4:35 PM (in response to william.drai)
 Maybe there is another way to do this with portable extensionsYes, implement ObserverMethod and call AfterBeanDiscovery.addObserverMethod() from an Extension. If that approach doesn't work, it is definitely a bug. 
- 
        8. Re: Conditional observersgavin.king Oct 29, 2009 4:56 PM (in response to william.drai)Or a completely different solution is to just declare your observer method on an Extension :-) 
- 
        9. Re: Conditional observersgavin.king Oct 29, 2009 5:40 PM (in response to william.drai)
 but it's not explicit in the specI've updated the spec to say very explicitly that container lifecycle events aren't delivered to ordinary beans. 
- 
        10. Re: Conditional observerswilliam.drai Oct 29, 2009 6:10 PM (in response to william.drai)Thanks, I'll try these solutions 
 
     
    