Interface ProcessProducer<T,X>
-
- Type Parameters:
T
- The bean class of the bean that declares the producer method or fieldX
- The return type of the producer method or the type of the producer field
public interface ProcessProducer<T,X>
The container fires an event of this type for each producer method or field of each enabled bean, including resources.
Any observer of this event is permitted to wrap and/or replace the
Producer
by calling eithersetProducer(Producer)
orconfigureProducer()
. If both methods are called within an observer notification anIllegalStateException
is thrown. The container must use the final value of this property, after all observers have been called, whenever it calls the producer or disposer.For example, this observer decorates the
Producer
for the all producer methods and field of typeEntityManager
.void decorateEntityManager(@Observes ProcessProducer<?, EntityManager> pp) { pit.setProducer(decorate(pp.getProducer())); }
If any observer method of a
ProcessProducer
event throws an exception, the exception is treated as a definition error by the container.CDI Lite implementations are not required to provide support for Portable Extensions.
- Author:
- David Allen
- See Also:
Producer
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description void
addDefinitionError(Throwable t)
Registers a definition error with the container, causing the container to abort deployment after bean discovery is complete.ProducerConfigurator<X>
configureProducer()
Returns aProducerConfigurator
initialized with theProducer
processed by this event, to configure a newProducer
that will replace the original one at the end of the observer invocation.AnnotatedMember<T>
getAnnotatedMember()
Returns theAnnotatedField
representing the producer field or theAnnotatedMethod
representing the producer method.Producer<X>
getProducer()
Returns theProducer
object that will be used by the container to call the producer method or read the producer field.void
setProducer(Producer<X> producer)
Replaces theProducer
object that will be used by the container to call the producer method or read the producer field.
-
-
-
Method Detail
-
getAnnotatedMember
AnnotatedMember<T> getAnnotatedMember()
Returns theAnnotatedField
representing the producer field or theAnnotatedMethod
representing the producer method.- Returns:
- the
AnnotatedMember
representing the producer - Throws:
IllegalStateException
- if called outside of the observer method invocation
-
getProducer
Producer<X> getProducer()
Returns theProducer
object that will be used by the container to call the producer method or read the producer field.- Returns:
- the
Producer
invoker object used by the container - Throws:
IllegalStateException
- if called outside of the observer method invocation
-
setProducer
void setProducer(Producer<X> producer)
Replaces theProducer
object that will be used by the container to call the producer method or read the producer field.- Parameters:
producer
- the newProducer
object to use- Throws:
IllegalStateException
- if called outside of the observer method invocation
-
configureProducer
ProducerConfigurator<X> configureProducer()
Returns aProducerConfigurator
initialized with theProducer
processed by this event, to configure a newProducer
that will replace the original one at the end of the observer invocation.Each call returns the same configurator instance within an observer notification.
- Returns:
- a non reusable
ProducerConfigurator
to configure the originalProducer
. - Throws:
IllegalStateException
- if called outside of the observer method invocation- Since:
- 2.0
-
addDefinitionError
void addDefinitionError(Throwable t)
Registers a definition error with the container, causing the container to abort deployment after bean discovery is complete.- Parameters:
t
- The definition error to register as aThrowable
- Throws:
IllegalStateException
- if called outside of the observer method invocation
-
-