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
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 either
setProducer(Producer) or configureProducer(). If both methods are called within an observer notification an
IllegalStateException 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 type
EntityManager.
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.
- See Also:
-
Method Summary
Modifier and TypeMethodDescriptionvoidRegisters a definition error with the container, causing the container to abort deployment after bean discovery is complete.Returns aProducerConfiguratorinitialized with theProducerprocessed by this event, to configure a newProducerthat will replace the original one at the end of the observer invocation.Returns theAnnotatedFieldrepresenting the producer field or theAnnotatedMethodrepresenting the producer method.Returns theProducerobject that will be used by the container to call the producer method or read the producer field.voidsetProducer(Producer<X> producer) Replaces theProducerobject that will be used by the container to call the producer method or read the producer field.
-
Method Details
-
getAnnotatedMember
AnnotatedMember<T> getAnnotatedMember()Returns theAnnotatedFieldrepresenting the producer field or theAnnotatedMethodrepresenting the producer method.- Returns:
- the
AnnotatedMemberrepresenting the producer - Throws:
IllegalStateException- if called outside of the observer method invocation
-
getProducer
Returns theProducerobject that will be used by the container to call the producer method or read the producer field.- Returns:
- the
Producerinvoker object used by the container - Throws:
IllegalStateException- if called outside of the observer method invocation
-
setProducer
Replaces theProducerobject that will be used by the container to call the producer method or read the producer field.- Parameters:
producer- the newProducerobject to use- Throws:
IllegalStateException- if called outside of the observer method invocation
-
configureProducer
ProducerConfigurator<X> configureProducer()Returns aProducerConfiguratorinitialized with theProducerprocessed by this event, to configure a newProducerthat 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
ProducerConfiguratorto configure the originalProducer. - Throws:
IllegalStateException- if called outside of the observer method invocation- Since:
- 2.0
-
addDefinitionError
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
-