Class BeanManagerImpl
- java.lang.Object
-
- org.jboss.weld.manager.BeanManagerImpl
-
- All Implemented Interfaces:
BeanManager
,Serializable
,org.jboss.weld.manager.api.WeldManager
public class BeanManagerImpl extends Object implements org.jboss.weld.manager.api.WeldManager, Serializable
Implementation of the Bean Manager. Essentially a singleton for registering Beans, Contexts, Observers, Interceptors etc. as well as providing resolution- Author:
- Pete Muir, Marius Bogoevici, Ales Justin, Jozef Hartinger
- See Also:
- Serialized Form
-
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description void
addAccessibleBeanManager(BeanManagerImpl accessibleBeanManager)
void
addBean(Bean<?> bean)
void
addBeans(Collection<? extends Bean<?>> beans)
Optimization which modifies CopyOnWrite structures only once instead of once for every bean.void
addContext(Context context)
void
addDecorator(Decorator<?> bean)
void
addInterceptor(Interceptor<?> bean)
void
addObserver(ObserverMethod<?> observer)
Does the actual observer registrationvoid
addValidationFailureCallback(BiConsumer<Exception,org.jboss.weld.bootstrap.api.Environment> callback)
boolean
areInterceptorBindingsEquivalent(Annotation interceptorBinding1, Annotation interceptorBinding2)
Determine if two interceptor bindings are considered equivalent for the purposes of typesafe resolution, taking into account any members annotated withNonbinding
.boolean
areQualifiersEquivalent(Annotation qualifier1, Annotation qualifier2)
Determine if two qualifiers are considered equivalent for the purposes of typesafe resolution, taking into account any members annotated withNonbinding
.void
cleanup()
void
cleanupAfterBoot()
For internal use only.<T> AnnotatedType<T>
createAnnotatedType(Class<T> type)
Obtain anAnnotatedType
that may be used to read the annotations of the given class or interface.<T> AnnotatedType<T>
createAnnotatedType(Class<T> type, String id)
<T> Bean<T>
createBean(BeanAttributes<T> attributes, Class<T> beanClass, InjectionTargetFactory<T> injectionTargetFactory)
<T,X>
Bean<T>createBean(BeanAttributes<T> attributes, Class<X> beanClass, ProducerFactory<X> producerFactory)
BeanAttributes<?>
createBeanAttributes(AnnotatedMember<?> member)
Obtains aBeanAttributes
for the givenAnnotatedType
.<T> BeanAttributes<T>
createBeanAttributes(AnnotatedType<T> type)
Obtains aBeanAttributes
for the givenAnnotatedType
.<T> WeldCreationalContext<T>
createCreationalContext(Contextual<T> contextual)
Obtain an instance of aCreationalContext
for the given contextual type, or for a non-contextual object.<T> EnhancedAnnotatedType<T>
createEnhancedAnnotatedType(Class<T> type)
FieldInjectionPointAttributes<?,?>
createInjectionPoint(AnnotatedField<?> field)
Obtains a container provided implementation ofInjectionPoint
for the givenAnnotatedField
.ParameterInjectionPointAttributes<?,?>
createInjectionPoint(AnnotatedParameter<?> parameter)
Obtains a container provided implementation ofInjectionPoint
for the givenAnnotatedParameter
.<T> InjectionTarget<T>
createInjectionTarget(AnnotatedType<T> type)
Obtains anInjectionTarget
for the givenAnnotatedType
.<T> InjectionTarget<T>
createInjectionTarget(org.jboss.weld.ejb.spi.EjbDescriptor<T> descriptor)
<T> org.jboss.weld.manager.api.WeldInjectionTargetBuilder<T>
createInjectionTargetBuilder(AnnotatedType<T> type)
WeldInstance<Object>
createInstance()
Obtains anInstance
object to access to beans instances.<T> InterceptionFactory<T>
createInterceptionFactory(CreationalContext<T> ctx, Class<T> clazz)
Create anInterceptionFactory
for the givenCreationalContext
and type.<T> void
disposeAnnotatedType(Class<T> type, String id)
boolean
equals(Object obj)
WeldEvent<Object>
event()
Set<QualifierInstance>
extractInterceptorBindingsForQualifierInstance(Iterable<QualifierInstance> annotations)
void
fireEvent(Object event, Annotation... qualifiers)
Fires an event object with given event object for given bindings<X> InjectionTarget<X>
fireProcessInjectionTarget(AnnotatedType<X> annotatedType)
<X> InjectionTarget<X>
fireProcessInjectionTarget(AnnotatedType<X> annotatedType, InjectionTarget<X> injectionTarget)
void
fireRequestContextBeforeDestroyed(Object payload)
void
fireRequestContextDestroyed(Object payload)
void
fireRequestContextInitialized(Object payload)
Set<Bean<?>>
getAccessibleBeans()
UnlikegetDynamicAccessibleBeans()
this method returns a mutable set which is not updated automatically.ObserverNotifier
getAccessibleLenientObserverNotifier()
Get the lenient observer notifier for accessible observer methods.HashSet<BeanManagerImpl>
getAccessibleManagers()
List<String>
getAccessibleNamespaces()
UnlikegetDynamicAccessibleNamespaces()
this method returns a mutable set which is not updated automatically.<T> SessionBean<T>
getBean(org.jboss.weld.ejb.spi.EjbDescriptor<T> descriptor)
<T> Bean<T>
getBean(Resolvable resolvable)
TypeSafeBeanResolver
getBeanResolver()
Get the web bean resolver.List<Bean<?>>
getBeans()
The beans registered with the Web Bean manager which are resolvable.Set<Bean<?>>
getBeans(InjectionPoint injectionPoint)
Set<Bean<?>>
getBeans(Type beanType, Annotation... qualifiers)
Return the set of beans which have the given required type and qualifiers and are available for injection in the module or library containing the class into which theBeanManager
was injected or the Java EE component from whose JNDI environment namespace theBeanManager
was obtained, according to the rules of typesafe resolution.Set<Bean<?>>
getBeans(Type beanType, Set<Annotation> qualifiers)
Set<Bean<?>>
getBeans(String name)
Return the set of beans which have the given EL name and are available for injection in the module or library containing the class into which theBeanManager
was injected or the Java EE component from whose JNDI environment namespace theBeanManager
was obtained, according to the rules of EL name resolution.ClientProxyProvider
getClientProxyProvider()
ContainerLifecycleEvents
getContainerLifecycleEvents()
Context
getContext(Class<? extends Annotation> scopeType)
Gets an active context of the given scope.String
getContextId()
protected Map<Class<? extends Annotation>,List<Context>>
getContexts()
TypeSafeDecoratorResolver
getDecoratorResolver()
Get the decorator resolver.List<Decorator<?>>
getDecorators()
Iterable<Bean<?>>
getDynamicAccessibleBeans()
Iterable<Decorator<?>>
getDynamicAccessibleDecorators()
Iterable<Interceptor<?>>
getDynamicAccessibleInterceptors()
Iterable<String>
getDynamicAccessibleNamespaces()
<T> org.jboss.weld.ejb.spi.EjbDescriptor<T>
getEjbDescriptor(String beanName)
jakarta.el.ELResolver
getELResolver()
Returns aELResolver
that resolves beans by EL name.ModuleEnablement
getEnabled()
Enabled Alternatives, Interceptors and DecoratorsMap<org.jboss.weld.ejb.spi.EjbDescriptor<?>,SessionBean<?>>
getEnterpriseBeans()
Gets the class-mapped beans.Event<Object>
getEvent()
Returns an instance of Event with specified typejava.lang.Object
and specified qualifier@Default
It allows typesafe synchronous or asynchronous event firing without injection ofEvent
built-in bean requirement.<T extends Extension>
TgetExtension(Class<T> extensionClass)
Obtains the container's instance of an Extension class declared inMETA-INF/services
.ObserverNotifier
getGlobalLenientObserverNotifier()
Get the lenient global observer notifier.ObserverNotifier
getGlobalStrictObserverNotifier()
Get the Strict global observer notifier.String
getId()
Object
getInjectableReference(InjectionPoint injectionPoint, CreationalContext<?> creationalContext)
Obtains an injectable reference for a certain injection point.Object
getInjectableReference(InjectionPoint injectionPoint, Bean<?> resolvedBean, CreationalContext<?> creationalContext)
Get a reference, registering the injection point used.<T> org.jboss.weld.manager.api.WeldInjectionTargetFactory<T>
getInjectionTargetFactory(AnnotatedType<T> type)
Creates anInjectionTargetFactory
for a given type.<T> WeldInstance<Object>
getInstance(CreationalContext<?> ctx)
Set<Annotation>
getInterceptorBindingDefinition(Class<? extends Annotation> bindingType)
Obtains the set of meta-annotations for a certain interceptor binding type .int
getInterceptorBindingHashCode(Annotation interceptorBinding)
Determine the hash code of an interceptor binding, using the JDK algorithm for determining an annotation hash code, ignoring any members annotated withNonbinding
.InterceptorMetadataReader
getInterceptorMetadataReader()
ConcurrentMap<SlimAnnotatedType<?>,InterceptionModel>
getInterceptorModelRegistry()
TypeSafeInterceptorResolver
getInterceptorResolver()
List<Interceptor<?>>
getInterceptors()
<T> InjectionTargetFactoryImpl<T>
getLocalInjectionTargetFactory(AnnotatedType<T> type)
Creates anInjectionTargetFactory
for a given type.NameBasedResolver
getNameBasedResolver()
protected List<String>
getNamespaces()
List<ObserverMethod<?>>
getObservers()
Bean<?>
getPassivationCapableBean(String id)
Returns thePassivationCapable
bean with the given identifier.Bean<?>
getPassivationCapableBean(org.jboss.weld.serialization.spi.BeanIdentifier identifier)
<X> FieldProducerFactory<X>
getProducerFactory(AnnotatedField<? super X> field, Bean<X> declaringBean)
An implementation ofProducerFactory
that provides container createdProducer
instances for the given field.<X> MethodProducerFactory<X>
getProducerFactory(AnnotatedMethod<? super X> method, Bean<X> declaringBean)
An implementation ofProducerFactory
that provides container createdProducer
instances for the given method.int
getQualifierHashCode(Annotation qualifier)
Determine the hash code of a qualifier, using the JDK algorithm for determining an annotation hash code, ignoring any members annotated withNonbinding
.Object
getReference(Bean<?> bean, Type requestedType, CreationalContext<?> creationalContext)
Obtains a contextual reference for a certain bean and a certain bean type of the bean.Object
getReference(Bean<?> bean, Type requestedType, CreationalContext<?> creationalContext, boolean noProxy)
Object
getReference(InjectionPoint injectionPoint, Bean<?> resolvedBean, CreationalContext<?> creationalContext)
Deprecated.Collection<Class<? extends Annotation>>
getScopes()
org.jboss.weld.bootstrap.api.ServiceRegistry
getServices()
Set<Annotation>
getStereotypeDefinition(Class<? extends Annotation> stereotype)
Obtains meta-annotations for a certain stereotype.Context
getUnwrappedContext(Class<? extends Annotation> scopeType)
int
hashCode()
Instance<Object>
instance()
<X> BeanAttributes<?>
internalCreateBeanAttributes(AnnotatedMember<X> member)
boolean
isBeanEnabled(Bean<?> bean)
boolean
isContextActive(Class<? extends Annotation> scopeType)
boolean
isInterceptorBinding(Class<? extends Annotation> annotationType)
Test the given annotation type to determine if it is an interceptor binding type .boolean
isNormalScope(Class<? extends Annotation> annotationType)
Test the given annotation type to determine if it is a normal scope type.boolean
isPassivatingScope(Class<? extends Annotation> annotationType)
Test the given annotation type to determine if it is a passivating scope type.boolean
isQualifier(Class<? extends Annotation> annotationType)
Test the given annotation type to determine if it is a qualifier type.boolean
isScope(Class<? extends Annotation> annotationType)
Test the given annotation type to determine if it is a scope type.boolean
isStereotype(Class<? extends Annotation> annotationType)
Test the given annotation type to determine if it is a stereotype.static BeanManagerImpl
newManager(BeanManagerImpl rootManager, String id, org.jboss.weld.bootstrap.api.ServiceRegistry services)
static BeanManagerImpl
newRootManager(String contextId, String id, org.jboss.weld.bootstrap.api.ServiceRegistry serviceRegistry)
Create a new, root, managerprotected Object
readResolve()
protected void
registerBeanNamespace(Bean<?> bean)
<X> Bean<? extends X>
resolve(Set<Bean<? extends X>> beans)
Apply the ambiguous dependency resolution rules to a set of beans.List<Decorator<?>>
resolveDecorators(Set<Type> types, Annotation... qualifiers)
Return an ordered list of decorators for a set of bean types and a set of qualifiers and which are enabled in the module or library containing the class into which theBeanManager
was injected or the Java EE component from whose JNDI environment namespace theBeanManager
was obtained.List<Decorator<?>>
resolveDecorators(Set<Type> types, Set<Annotation> qualifiers)
List<Interceptor<?>>
resolveInterceptors(InterceptionType type, Annotation... interceptorBindings)
Resolves a list of interceptors based on interception type and interceptor bindings.List<Interceptor<?>>
resolveInterceptors(InterceptionType type, Collection<Annotation> interceptorBindings)
Resolves a list of interceptors based on interception type and interceptor bindings.<T> Set<ObserverMethod<? super T>>
resolveObserverMethods(T event, Annotation... bindings)
Return an ordered set of observer methods for an event.void
setEnabled(ModuleEnablement enabled)
String
toString()
Gets a string representationBeanManagerImpl
unwrap()
void
validate(InjectionPoint ij)
Validate a certain injection point.void
validationFailed(Exception failure, org.jboss.weld.bootstrap.api.Environment environment)
jakarta.el.ExpressionFactory
wrapExpressionFactory(jakarta.el.ExpressionFactory expressionFactory)
Returns a wrapperExpressionFactory
that delegatesMethodExpression
andValueExpression
creation to the givenExpressionFactory
.
-
-
-
Method Detail
-
newRootManager
public static BeanManagerImpl newRootManager(String contextId, String id, org.jboss.weld.bootstrap.api.ServiceRegistry serviceRegistry)
Create a new, root, manager- Parameters:
serviceRegistry
-- Returns:
-
newManager
public static BeanManagerImpl newManager(BeanManagerImpl rootManager, String id, org.jboss.weld.bootstrap.api.ServiceRegistry services)
-
getContextId
public String getContextId()
-
addAccessibleBeanManager
public void addAccessibleBeanManager(BeanManagerImpl accessibleBeanManager)
-
getAccessibleManagers
public HashSet<BeanManagerImpl> getAccessibleManagers()
-
addBean
public void addBean(Bean<?> bean)
-
addBeans
public void addBeans(Collection<? extends Bean<?>> beans)
Optimization which modifies CopyOnWrite structures only once instead of once for every bean.- Parameters:
beans
-
-
addDecorator
public void addDecorator(Decorator<?> bean)
-
resolveObserverMethods
public <T> Set<ObserverMethod<? super T>> resolveObserverMethods(T event, Annotation... bindings)
Description copied from interface:BeanManager
Return an ordered set of observer methods for an event. Note that when called during invocation of anAfterBeanDiscovery
event observer, this method will only return observers discovered by the container before theAfterBeanDiscovery
event is fired.- Specified by:
resolveObserverMethods
in interfaceBeanManager
- Type Parameters:
T
- the type of the event- Parameters:
event
- the event objectbindings
- the event qualifiers- Returns:
- the resulting set of observer methods
-
addInterceptor
public void addInterceptor(Interceptor<?> bean)
-
getEnabled
public ModuleEnablement getEnabled()
Enabled Alternatives, Interceptors and Decorators- Returns:
-
setEnabled
public void setEnabled(ModuleEnablement enabled)
-
isBeanEnabled
public boolean isBeanEnabled(Bean<?> bean)
-
getBeans
public Set<Bean<?>> getBeans(Type beanType, Annotation... qualifiers)
Description copied from interface:BeanManager
Return the set of beans which have the given required type and qualifiers and are available for injection in the module or library containing the class into which theBeanManager
was injected or the Java EE component from whose JNDI environment namespace theBeanManager
was obtained, according to the rules of typesafe resolution. If no qualifiers are given, the default qualifier is assumed. Note that when called during invocation of anAfterBeanDiscovery
event observer, this method will only return beans discovered by the container before theAfterBeanDiscovery
event is fired.- Specified by:
getBeans
in interfaceBeanManager
- Parameters:
beanType
- the required bean typequalifiers
- the required qualifiers- Returns:
- the resulting set of beans
-
getBeans
public Set<Bean<?>> getBeans(Type beanType, Set<Annotation> qualifiers)
-
getBeans
public Set<Bean<?>> getBeans(InjectionPoint injectionPoint)
-
registerBeanNamespace
protected void registerBeanNamespace(Bean<?> bean)
-
getEnterpriseBeans
public Map<org.jboss.weld.ejb.spi.EjbDescriptor<?>,SessionBean<?>> getEnterpriseBeans()
Gets the class-mapped beans. For internal use.- Returns:
- The bean map
-
getBeans
public List<Bean<?>> getBeans()
The beans registered with the Web Bean manager which are resolvable. Does not include interceptor and decorator beans- Returns:
- The list of known beans
-
getInterceptors
public List<Interceptor<?>> getInterceptors()
-
getAccessibleBeans
public Set<Bean<?>> getAccessibleBeans()
UnlikegetDynamicAccessibleBeans()
this method returns a mutable set which is not updated automatically.- Returns:
- all accessible beans
-
getDynamicAccessibleInterceptors
public Iterable<Interceptor<?>> getDynamicAccessibleInterceptors()
-
addContext
public void addContext(Context context)
-
addObserver
public void addObserver(ObserverMethod<?> observer)
Does the actual observer registration- Parameters:
observer
- =
-
fireEvent
public void fireEvent(Object event, Annotation... qualifiers)
Fires an event object with given event object for given bindings- Specified by:
fireEvent
in interfaceBeanManager
- Parameters:
event
- The event object to pass alongqualifiers
- The binding types to match
-
getContext
public Context getContext(Class<? extends Annotation> scopeType)
Gets an active context of the given scope. Throws an exception if there are no active contexts found or if there are too many matches- Specified by:
getContext
in interfaceBeanManager
- Parameters:
scopeType
- The scope to match- Returns:
- A single active context of the given scope
- Throws:
IllegalStateException
- if there are multiple active scopes for a given context
-
getUnwrappedContext
public Context getUnwrappedContext(Class<? extends Annotation> scopeType)
-
isContextActive
public boolean isContextActive(Class<? extends Annotation> scopeType)
- Specified by:
isContextActive
in interfaceorg.jboss.weld.manager.api.WeldManager
-
getReference
public Object getReference(Bean<?> bean, Type requestedType, CreationalContext<?> creationalContext, boolean noProxy)
-
getReference
public Object getReference(Bean<?> bean, Type requestedType, CreationalContext<?> creationalContext)
Description copied from interface:BeanManager
Obtains a contextual reference for a certain bean and a certain bean type of the bean.
- Specified by:
getReference
in interfaceBeanManager
- Parameters:
bean
- theBean
object representing the beanrequestedType
- a bean type that must be implemented by any client proxy that is returnedcreationalContext
- aCreationalContext
that may be used to destroy any object with scopeDependent
that is created- Returns:
- a contextual reference representing the bean
-
getReference
@Deprecated public Object getReference(InjectionPoint injectionPoint, Bean<?> resolvedBean, CreationalContext<?> creationalContext)
Deprecated.The name of this method was misleading, usegetInjectableReference(InjectionPoint, Bean, CreationalContext)
instead.- Parameters:
injectionPoint
-resolvedBean
-creationalContext
-- Returns:
- the injectable reference
-
getInjectableReference
public Object getInjectableReference(InjectionPoint injectionPoint, Bean<?> resolvedBean, CreationalContext<?> creationalContext)
Get a reference, registering the injection point used.- Parameters:
injectionPoint
- the injection point to registerresolvedBean
- the bean to get a reference tocreationalContext
- the creationalContext- Returns:
- the injectable reference
-
getInjectableReference
public Object getInjectableReference(InjectionPoint injectionPoint, CreationalContext<?> creationalContext)
Description copied from interface:BeanManager
Obtains an injectable reference for a certain injection point.
- Specified by:
getInjectableReference
in interfaceBeanManager
- Parameters:
injectionPoint
- the target injection pointcreationalContext
- aCreationalContext
that may be used to destroy any object with scopeDependent
that is created- Returns:
- the injectable reference
-
getBean
public <T> Bean<T> getBean(Resolvable resolvable)
-
getBeans
public Set<Bean<?>> getBeans(String name)
Description copied from interface:BeanManager
Return the set of beans which have the given EL name and are available for injection in the module or library containing the class into which theBeanManager
was injected or the Java EE component from whose JNDI environment namespace theBeanManager
was obtained, according to the rules of EL name resolution. Note that when called during invocation of anAfterBeanDiscovery
event observer, this method will only return beans discovered by the container before theAfterBeanDiscovery
event is fired.- Specified by:
getBeans
in interfaceBeanManager
- Parameters:
name
- the EL name- Returns:
- the resulting set of beans
-
resolveDecorators
public List<Decorator<?>> resolveDecorators(Set<Type> types, Annotation... qualifiers)
Description copied from interface:BeanManager
Return an ordered list of decorators for a set of bean types and a set of qualifiers and which are enabled in the module or library containing the class into which theBeanManager
was injected or the Java EE component from whose JNDI environment namespace theBeanManager
was obtained. Note that when called during invocation of anAfterBeanDiscovery
event observer, this method will only return decorators discovered by the container before theAfterBeanDiscovery
event is fired.- Specified by:
resolveDecorators
in interfaceBeanManager
- Parameters:
types
- the set of bean types of the decorated beanqualifiers
- the qualifiers declared by the decorated bean- Returns:
- the resulting set of decorators
-
resolveDecorators
public List<Decorator<?>> resolveDecorators(Set<Type> types, Set<Annotation> qualifiers)
-
resolveInterceptors
public List<Interceptor<?>> resolveInterceptors(InterceptionType type, Annotation... interceptorBindings)
Resolves a list of interceptors based on interception type and interceptor bindings. Transitive interceptor bindings of the interceptor bindings passed as a parameter are considered in the resolution process.- Specified by:
resolveInterceptors
in interfaceBeanManager
- Parameters:
type
- The interception type to resolveinterceptorBindings
- The binding types to match- Returns:
- A list of matching interceptors
-
resolveInterceptors
public List<Interceptor<?>> resolveInterceptors(InterceptionType type, Collection<Annotation> interceptorBindings)
Resolves a list of interceptors based on interception type and interceptor bindings. Transitive interceptor bindings of the interceptor bindings passed as a parameter are NOT considered in the resolution process. Therefore, the caller is responsible for filtering of transitive interceptor bindings in order to comply with interceptor binding inheritance and overriding (See JSR-346 9.5.2). This is a Weld-specific method.- Parameters:
type
- The interception type to resolveinterceptorBindings
- The binding types to match- Returns:
- A list of matching interceptors
-
getBeanResolver
public TypeSafeBeanResolver getBeanResolver()
Get the web bean resolver. For internal use- Returns:
- The resolver
-
getDecoratorResolver
public TypeSafeDecoratorResolver getDecoratorResolver()
Get the decorator resolver. For internal use- Returns:
- The resolver
-
getInterceptorResolver
public TypeSafeInterceptorResolver getInterceptorResolver()
-
getNameBasedResolver
public NameBasedResolver getNameBasedResolver()
-
getAccessibleLenientObserverNotifier
public ObserverNotifier getAccessibleLenientObserverNotifier()
Get the lenient observer notifier for accessible observer methods. Should never be exposed to an application.- Returns:
- The
ObserverNotifier
-
getGlobalLenientObserverNotifier
public ObserverNotifier getGlobalLenientObserverNotifier()
Get the lenient global observer notifier. Should never be exposed to an application.- Returns:
- The
ObserverNotifier
-
getGlobalStrictObserverNotifier
public ObserverNotifier getGlobalStrictObserverNotifier()
Get the Strict global observer notifier. This one should be used for firing application / extension events.- Returns:
- The
ObserverNotifier
-
toString
public String toString()
Gets a string representation
-
getServices
public org.jboss.weld.bootstrap.api.ServiceRegistry getServices()
- Specified by:
getServices
in interfaceorg.jboss.weld.manager.api.WeldManager
-
readResolve
protected Object readResolve() throws ObjectStreamException
- Throws:
ObjectStreamException
-
getClientProxyProvider
public ClientProxyProvider getClientProxyProvider()
-
getContexts
protected Map<Class<? extends Annotation>,List<Context>> getContexts()
-
getAccessibleNamespaces
public List<String> getAccessibleNamespaces()
UnlikegetDynamicAccessibleNamespaces()
this method returns a mutable set which is not updated automatically.- Returns:
- the accessible namespaces
-
getId
public String getId()
- Specified by:
getId
in interfaceorg.jboss.weld.manager.api.WeldManager
-
getObservers
public List<ObserverMethod<?>> getObservers()
-
createInjectionTarget
public <T> InjectionTarget<T> createInjectionTarget(AnnotatedType<T> type)
Description copied from interface:BeanManager
Obtains an
InjectionTarget
for the givenAnnotatedType
. The container ignores the annotations and types declared by the elements of the actual Java class and uses the metadata provided via theAnnotated
interface instead.This method is deprecated from CDI 1.1 and
BeanManager.getInjectionTargetFactory(AnnotatedType)
should be used instead.- Specified by:
createInjectionTarget
in interfaceBeanManager
- Type Parameters:
T
- the type- Parameters:
type
- theAnnotatedType
- Returns:
- a container provided implementation of
InjectionTarget
-
createInjectionTarget
public <T> InjectionTarget<T> createInjectionTarget(org.jboss.weld.ejb.spi.EjbDescriptor<T> descriptor)
- Specified by:
createInjectionTarget
in interfaceorg.jboss.weld.manager.api.WeldManager
-
validate
public void validate(InjectionPoint ij)
Description copied from interface:BeanManager
Validate a certain injection point. Note that when called during invocation of anAfterBeanDiscovery
event observer, this method will only validate injection points discovered by the container before theAfterBeanDiscovery
event is fired.- Specified by:
validate
in interfaceBeanManager
- Parameters:
ij
- the injection point to validate
-
getInterceptorBindingDefinition
public Set<Annotation> getInterceptorBindingDefinition(Class<? extends Annotation> bindingType)
Description copied from interface:BeanManager
Obtains the set of meta-annotations for a certain interceptor binding type .- Specified by:
getInterceptorBindingDefinition
in interfaceBeanManager
- Parameters:
bindingType
- the interceptor binding type- Returns:
- the set of meta-annotations
-
getPassivationCapableBean
public Bean<?> getPassivationCapableBean(String id)
Description copied from interface:BeanManager
Returns thePassivationCapable
bean with the given identifier. Note that when called during invocation of anAfterBeanDiscovery
event observer, this method will only return beans discovered by the container before theAfterBeanDiscovery
event is fired.- Specified by:
getPassivationCapableBean
in interfaceBeanManager
- Parameters:
id
- the identifier- Returns:
- a
Bean
that implementsPassivationCapable
and has the given identifier, or a null value if there is no such bean
-
getPassivationCapableBean
public Bean<?> getPassivationCapableBean(org.jboss.weld.serialization.spi.BeanIdentifier identifier)
- Specified by:
getPassivationCapableBean
in interfaceorg.jboss.weld.manager.api.WeldManager
-
getStereotypeDefinition
public Set<Annotation> getStereotypeDefinition(Class<? extends Annotation> stereotype)
Description copied from interface:BeanManager
Obtains meta-annotations for a certain stereotype.- Specified by:
getStereotypeDefinition
in interfaceBeanManager
- Parameters:
stereotype
- the stereotype- Returns:
- the set of meta-annotations
-
isQualifier
public boolean isQualifier(Class<? extends Annotation> annotationType)
Description copied from interface:BeanManager
Test the given annotation type to determine if it is a qualifier type.- Specified by:
isQualifier
in interfaceBeanManager
- Parameters:
annotationType
- the annotation type- Returns:
true
if the annotation type is a qualifier type
-
isInterceptorBinding
public boolean isInterceptorBinding(Class<? extends Annotation> annotationType)
Description copied from interface:BeanManager
Test the given annotation type to determine if it is an interceptor binding type .- Specified by:
isInterceptorBinding
in interfaceBeanManager
- Parameters:
annotationType
- the annotation to test- Returns:
true
if the annotation type is a interceptor binding type
-
isNormalScope
public boolean isNormalScope(Class<? extends Annotation> annotationType)
Description copied from interface:BeanManager
Test the given annotation type to determine if it is a normal scope type.- Specified by:
isNormalScope
in interfaceBeanManager
- Parameters:
annotationType
- the annotation type- Returns:
true
if the annotation type is a normal scope type
-
isPassivatingScope
public boolean isPassivatingScope(Class<? extends Annotation> annotationType)
Description copied from interface:BeanManager
Test the given annotation type to determine if it is a passivating scope type.- Specified by:
isPassivatingScope
in interfaceBeanManager
- Parameters:
annotationType
- the annotation type- Returns:
true
if the annotation type is a passivating scope type
-
isScope
public boolean isScope(Class<? extends Annotation> annotationType)
Description copied from interface:BeanManager
Test the given annotation type to determine if it is a scope type.- Specified by:
isScope
in interfaceBeanManager
- Parameters:
annotationType
- the annotation type- Returns:
- true if the annotation type is a scope type
-
isStereotype
public boolean isStereotype(Class<? extends Annotation> annotationType)
Description copied from interface:BeanManager
Test the given annotation type to determine if it is a stereotype.- Specified by:
isStereotype
in interfaceBeanManager
- Parameters:
annotationType
- the annotation type- Returns:
true
if the annotation type is a stereotype
-
getELResolver
public jakarta.el.ELResolver getELResolver()
Description copied from interface:BeanManager
Returns aELResolver
that resolves beans by EL name.- Specified by:
getELResolver
in interfaceBeanManager
- Returns:
- the
ELResolver
-
wrapExpressionFactory
public jakarta.el.ExpressionFactory wrapExpressionFactory(jakarta.el.ExpressionFactory expressionFactory)
Description copied from interface:BeanManager
Returns a wrapperExpressionFactory
that delegatesMethodExpression
andValueExpression
creation to the givenExpressionFactory
. When a Unified EL expression is evaluated using aMethodExpression
orValueExpression
returned by the wrapperExpressionFactory
, the container handles destruction of objects with scopeDependent
.- Specified by:
wrapExpressionFactory
in interfaceBeanManager
- Parameters:
expressionFactory
- theExpressionFactory
to wrap- Returns:
- the wrapped
ExpressionFactory
-
createCreationalContext
public <T> WeldCreationalContext<T> createCreationalContext(Contextual<T> contextual)
Description copied from interface:BeanManager
Obtain an instance of aCreationalContext
for the given contextual type, or for a non-contextual object.- Specified by:
createCreationalContext
in interfaceBeanManager
- Specified by:
createCreationalContext
in interfaceorg.jboss.weld.manager.api.WeldManager
- Type Parameters:
T
- type of the instance- Parameters:
contextual
- theContextual
, or a null value in the case of a non-contextual object- Returns:
- the new
CreationalContext
-
createAnnotatedType
public <T> AnnotatedType<T> createAnnotatedType(Class<T> type)
Description copied from interface:BeanManager
Obtain anAnnotatedType
that may be used to read the annotations of the given class or interface.- Specified by:
createAnnotatedType
in interfaceBeanManager
- Type Parameters:
T
- the class or interface- Parameters:
type
- theClass
object- Returns:
- the
AnnotatedType
-
createEnhancedAnnotatedType
public <T> EnhancedAnnotatedType<T> createEnhancedAnnotatedType(Class<T> type)
-
createAnnotatedType
public <T> AnnotatedType<T> createAnnotatedType(Class<T> type, String id)
- Specified by:
createAnnotatedType
in interfaceorg.jboss.weld.manager.api.WeldManager
-
disposeAnnotatedType
public <T> void disposeAnnotatedType(Class<T> type, String id)
- Specified by:
disposeAnnotatedType
in interfaceorg.jboss.weld.manager.api.WeldManager
-
resolve
public <X> Bean<? extends X> resolve(Set<Bean<? extends X>> beans)
Description copied from interface:BeanManager
Apply the ambiguous dependency resolution rules to a set of beans. Note that when called during invocation of anAfterBeanDiscovery
event observer, this method will only return beans discovered by the container before theAfterBeanDiscovery
event is fired.- Specified by:
resolve
in interfaceBeanManager
- Type Parameters:
X
- a common type of the beans- Parameters:
beans
- a set of beans of the given type- Returns:
- the resolved bean, or null if null or an empty set is passed
-
getEjbDescriptor
public <T> org.jboss.weld.ejb.spi.EjbDescriptor<T> getEjbDescriptor(String beanName)
- Specified by:
getEjbDescriptor
in interfaceorg.jboss.weld.manager.api.WeldManager
-
getBean
public <T> SessionBean<T> getBean(org.jboss.weld.ejb.spi.EjbDescriptor<T> descriptor)
- Specified by:
getBean
in interfaceorg.jboss.weld.manager.api.WeldManager
-
cleanup
public void cleanup()
-
cleanupAfterBoot
public void cleanupAfterBoot()
For internal use only. This happens after bootstrap services cleanup but beforeRIBean.cleanupAfterBoot()
.- See Also:
Bootstrap.endInitialization()
-
getInterceptorModelRegistry
public ConcurrentMap<SlimAnnotatedType<?>,InterceptionModel> getInterceptorModelRegistry()
-
getInterceptorMetadataReader
public InterceptorMetadataReader getInterceptorMetadataReader()
-
fireProcessInjectionTarget
public <X> InjectionTarget<X> fireProcessInjectionTarget(AnnotatedType<X> annotatedType)
- Specified by:
fireProcessInjectionTarget
in interfaceorg.jboss.weld.manager.api.WeldManager
-
fireProcessInjectionTarget
public <X> InjectionTarget<X> fireProcessInjectionTarget(AnnotatedType<X> annotatedType, InjectionTarget<X> injectionTarget)
- Specified by:
fireProcessInjectionTarget
in interfaceorg.jboss.weld.manager.api.WeldManager
-
extractInterceptorBindingsForQualifierInstance
public Set<QualifierInstance> extractInterceptorBindingsForQualifierInstance(Iterable<QualifierInstance> annotations)
-
instance
public Instance<Object> instance()
- Specified by:
instance
in interfaceorg.jboss.weld.manager.api.WeldManager
-
getInstance
public <T> WeldInstance<Object> getInstance(CreationalContext<?> ctx)
-
createBeanAttributes
public <T> BeanAttributes<T> createBeanAttributes(AnnotatedType<T> type)
Description copied from interface:BeanManager
Obtains aBeanAttributes
for the givenAnnotatedType
. The container ignores the annotations and types declared by the elements of the actual Java class and uses the metadata provided via theAnnotated
interface instead.- Specified by:
createBeanAttributes
in interfaceBeanManager
- Type Parameters:
T
- the type- Parameters:
type
- theAnnotatedType
- Returns:
- a container provided implementation of
InjectionTarget
-
createBeanAttributes
public BeanAttributes<?> createBeanAttributes(AnnotatedMember<?> member)
Description copied from interface:BeanManager
Obtains aBeanAttributes
for the givenAnnotatedType
. The container ignores the annotations and types declared by the elements of the actual Java class and uses the metadata provided via theAnnotated
interface instead.- Specified by:
createBeanAttributes
in interfaceBeanManager
- Parameters:
member
- theAnnotatedType
- Returns:
- a container provided implementation of
InjectionTarget
-
internalCreateBeanAttributes
public <X> BeanAttributes<?> internalCreateBeanAttributes(AnnotatedMember<X> member)
-
createBean
public <T> Bean<T> createBean(BeanAttributes<T> attributes, Class<T> beanClass, InjectionTargetFactory<T> injectionTargetFactory)
Description copied from interface:BeanManager
Obtains a
Bean
for the givenBeanAttributes
, bean class andInjectionTarget
.The
InjectionTarget
creates and destroys instances of the bean, performs dependency injection and lifecycle callbacks, and determines the return value ofBean.getInjectionPoints()
. TheInjectionTarget
is obtained from theInjectionTargetFactory
.BeanManager.getInjectionTargetFactory(AnnotatedType)
allows use of a container createdInjectionTarget
.- Specified by:
createBean
in interfaceBeanManager
- Type Parameters:
T
- the type- Parameters:
attributes
- aBeanAttributes
which determines the bean types, qualifiers, scope, name and stereotypes of the returnedBean
, and the return values ofBeanAttributes.isAlternative()
andBean.isNullable()
beanClass
- a class, which determines the return value ofBean.getBeanClass()
injectionTargetFactory
- anInjectionTargetFactory
, used to obtain anInjectionTarget
- Returns:
- a container provided implementation of
Bean
-
createBean
public <T,X> Bean<T> createBean(BeanAttributes<T> attributes, Class<X> beanClass, ProducerFactory<X> producerFactory)
Description copied from interface:BeanManager
Obtains a
Bean
for the givenBeanAttributes
, bean class andProducer
.The
Producer
creates and destroys instances of the decorator, and determines the return value ofBean.getInjectionPoints()
. TheProducer
is obtained from theProducerFactory
.BeanManager.getProducerFactory(AnnotatedMethod, Bean)
orBeanManager.getProducerFactory(AnnotatedField, Bean)
allows use of a container createdProducer
.- Specified by:
createBean
in interfaceBeanManager
- Type Parameters:
T
- the typeX
- the type of the declaring bean- Parameters:
attributes
- aBeanAttributes
which determines the bean types, qualifiers, scope, name and stereotypes of the returnedBean
, and the return values ofBeanAttributes.isAlternative()
andBean.isNullable()
beanClass
- a class, which determines the return value ofBean.getClass()
producerFactory
- aProducerFactory
, used to obtain aProducer
- Returns:
- a container provided implementation of
Bean
-
createInjectionPoint
public FieldInjectionPointAttributes<?,?> createInjectionPoint(AnnotatedField<?> field)
Description copied from interface:BeanManager
Obtains a container provided implementation ofInjectionPoint
for the givenAnnotatedField
.- Specified by:
createInjectionPoint
in interfaceBeanManager
- Parameters:
field
- theAnnotatedField
defining the injection point- Returns:
- the container provided
InjectionPoint
-
createInjectionPoint
public ParameterInjectionPointAttributes<?,?> createInjectionPoint(AnnotatedParameter<?> parameter)
Description copied from interface:BeanManager
Obtains a container provided implementation ofInjectionPoint
for the givenAnnotatedParameter
.- Specified by:
createInjectionPoint
in interfaceBeanManager
- Parameters:
parameter
- theAnnotatedParameter
defining the injection point- Returns:
- the container provided
InjectionPoint
-
getExtension
public <T extends Extension> T getExtension(Class<T> extensionClass)
Description copied from interface:BeanManager
Obtains the container's instance of an Extension class declared inMETA-INF/services
.- Specified by:
getExtension
in interfaceBeanManager
- Type Parameters:
T
- the type of the extension- Parameters:
extensionClass
- the type of the extension class- Returns:
- the extension instance
-
createInterceptionFactory
public <T> InterceptionFactory<T> createInterceptionFactory(CreationalContext<T> ctx, Class<T> clazz)
Description copied from interface:BeanManager
Create anInterceptionFactory
for the givenCreationalContext
and type.- Specified by:
createInterceptionFactory
in interfaceBeanManager
- Type Parameters:
T
- type of the instance this factory will work on- Parameters:
ctx
-CreationalContext
for theInterceptionFactory
to createclazz
- class of the instance this factory will work on- Returns:
- a new
InterceptionFactory
to add services on on instances of T
-
getEvent
public Event<Object> getEvent()
Description copied from interface:BeanManager
Returns an instance of Event with specified typejava.lang.Object
and specified qualifier@Default
It allows typesafe synchronous or asynchronous event firing without injection ofEvent
built-in bean requirement.- Specified by:
getEvent
in interfaceBeanManager
- Returns:
- a new
Event
object whose event type isObject
and qualifier@Default
-
getContainerLifecycleEvents
public ContainerLifecycleEvents getContainerLifecycleEvents()
-
areQualifiersEquivalent
public boolean areQualifiersEquivalent(Annotation qualifier1, Annotation qualifier2)
Description copied from interface:BeanManager
Determine if two qualifiers are considered equivalent for the purposes of typesafe resolution, taking into account any members annotated withNonbinding
.- Specified by:
areQualifiersEquivalent
in interfaceBeanManager
- Parameters:
qualifier1
- a qualifier to checkqualifier2
- a qualifier to check- Returns:
- true if the two qualifiers are equivalent, otherwise false
-
areInterceptorBindingsEquivalent
public boolean areInterceptorBindingsEquivalent(Annotation interceptorBinding1, Annotation interceptorBinding2)
Description copied from interface:BeanManager
Determine if two interceptor bindings are considered equivalent for the purposes of typesafe resolution, taking into account any members annotated withNonbinding
.- Specified by:
areInterceptorBindingsEquivalent
in interfaceBeanManager
- Parameters:
interceptorBinding1
- an interceptor binding to checkinterceptorBinding2
- an interceptor binding to check- Returns:
- true if the two interceptor bindings are equivalent, otherwise false
-
getQualifierHashCode
public int getQualifierHashCode(Annotation qualifier)
Description copied from interface:BeanManager
Determine the hash code of a qualifier, using the JDK algorithm for determining an annotation hash code, ignoring any members annotated withNonbinding
.- Specified by:
getQualifierHashCode
in interfaceBeanManager
- Parameters:
qualifier
- the qualifier to consider- Returns:
- the hashCode for the qualifier
-
getInterceptorBindingHashCode
public int getInterceptorBindingHashCode(Annotation interceptorBinding)
Description copied from interface:BeanManager
Determine the hash code of an interceptor binding, using the JDK algorithm for determining an annotation hash code, ignoring any members annotated withNonbinding
.- Specified by:
getInterceptorBindingHashCode
in interfaceBeanManager
- Parameters:
interceptorBinding
- the interceptor binding to consider- Returns:
- the hashCode for the interceptor binding
-
getLocalInjectionTargetFactory
public <T> InjectionTargetFactoryImpl<T> getLocalInjectionTargetFactory(AnnotatedType<T> type)
Creates anInjectionTargetFactory
for a given type. The factory will be using thisBeanManager
.
-
getInjectionTargetFactory
public <T> org.jboss.weld.manager.api.WeldInjectionTargetFactory<T> getInjectionTargetFactory(AnnotatedType<T> type)
Creates anInjectionTargetFactory
for a given type. TheBeanManager
for theInjectionTarget
will be inferred usingCDI11Deployment.getBeanDeploymentArchive(Class)
.- Specified by:
getInjectionTargetFactory
in interfaceBeanManager
- Specified by:
getInjectionTargetFactory
in interfaceorg.jboss.weld.manager.api.WeldManager
- Type Parameters:
T
- the type- Parameters:
type
- the annotated type to create the injection target factory for- Returns:
- an
InjectionTargetFactory
-
getProducerFactory
public <X> FieldProducerFactory<X> getProducerFactory(AnnotatedField<? super X> field, Bean<X> declaringBean)
Description copied from interface:BeanManager
An implementation of
ProducerFactory
that provides container createdProducer
instances for the given field.This factory can be wrapped to add behavior to container created producers.
- Specified by:
getProducerFactory
in interfaceBeanManager
- Type Parameters:
X
- the declaring type- Parameters:
field
- the field to create the producer factory fordeclaringBean
- the bean declaring the producer. May be null if the producer is static or the declaring object is non-contextual- Returns:
- the producer factory for the field
-
getProducerFactory
public <X> MethodProducerFactory<X> getProducerFactory(AnnotatedMethod<? super X> method, Bean<X> declaringBean)
Description copied from interface:BeanManager
An implementation of
ProducerFactory
that provides container createdProducer
instances for the given method.This factory can be wrapped to add behavior to container created producers.
- Specified by:
getProducerFactory
in interfaceBeanManager
- Type Parameters:
X
- bean type- Parameters:
method
- the method to create the producer factory fordeclaringBean
- the bean declaring the producer. May be null if the producer is static or the declaring object is non-contextual- Returns:
- the producer factory for the method
-
createInjectionTargetBuilder
public <T> org.jboss.weld.manager.api.WeldInjectionTargetBuilder<T> createInjectionTargetBuilder(AnnotatedType<T> type)
- Specified by:
createInjectionTargetBuilder
in interfaceorg.jboss.weld.manager.api.WeldManager
-
createInstance
public WeldInstance<Object> createInstance()
Description copied from interface:BeanManager
Obtains anInstance
object to access to beans instances. The returnedInstance
object can only access instances of beans that are available for injection in the module or library containing the class into which theBeanManager
was injected or the Java EE component from whose JNDI environment namespace theBeanManager
was obtained, according to the rules of typesafe resolution. Note that when called during invocation of anAfterBeanDiscovery
event observer, theInstance
returned by this method will only give access to instances of beans discovered by the container before theAfterBeanDiscovery
event is fired. Instances of dependent scoped beans obtained with thisInstance
must be explicitly destroyed by callingInstance.destroy(Object)
If no qualifier is passed toInstance.select(java.lang.annotation.Annotation...)
method, the@Default
qualifier is assumed.- Specified by:
createInstance
in interfaceBeanManager
- Returns:
- an
Instance
object to request beans instances
-
unwrap
public BeanManagerImpl unwrap()
- Specified by:
unwrap
in interfaceorg.jboss.weld.manager.api.WeldManager
-
fireRequestContextInitialized
public void fireRequestContextInitialized(Object payload)
-
fireRequestContextBeforeDestroyed
public void fireRequestContextBeforeDestroyed(Object payload)
-
fireRequestContextDestroyed
public void fireRequestContextDestroyed(Object payload)
-
addValidationFailureCallback
public void addValidationFailureCallback(BiConsumer<Exception,org.jboss.weld.bootstrap.api.Environment> callback)
-
validationFailed
public void validationFailed(Exception failure, org.jboss.weld.bootstrap.api.Environment environment)
-
getScopes
public Collection<Class<? extends Annotation>> getScopes()
- Specified by:
getScopes
in interfaceorg.jboss.weld.manager.api.WeldManager
-
-