All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jboss.as.ee.component.ComponentConfiguration Maven / Gradle / Ivy

There is a newer version: 35.0.0.Beta1
Show newest version
/*
 * Copyright The WildFly Authors
 * SPDX-License-Identifier: Apache-2.0
 */

package org.jboss.as.ee.component;

import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashSet;
import java.util.IdentityHashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;

import org.jboss.as.ee.logging.EeLogger;
import org.jboss.as.ee.component.interceptors.OrderedItemContainer;
import org.jboss.as.ee.concurrent.ConcurrentContext;
import org.jboss.as.naming.context.NamespaceContextSelector;
import org.jboss.as.server.deployment.reflect.ClassReflectionIndex;
import org.jboss.invocation.InterceptorFactory;
import org.jboss.modules.ModuleLoader;
import org.jboss.msc.service.Service;

/**
 * The construction parameter set passed in to an abstract component.
 * 

*

Interceptors

* * NOTE: References in this file to Interceptors refer to the Jakarta Interceptors unless otherwise noted. * * The interceptor factories provided herein are assembled from the component's EE module class as well as the EE * module classes of the declared interceptor classes for this component by way of a configurator. * * @author David M. Lloyd */ public class ComponentConfiguration { private final ComponentDescription componentDescription; // Core component config private final ClassReflectionIndex classIndex; private final ModuleLoader moduleLoader; private final ClassLoader moduleClassLoader; private final ConcurrentContext concurrentContext; private ComponentCreateServiceFactory componentCreateServiceFactory = ComponentCreateServiceFactory.BASIC; // Interceptor config private final OrderedItemContainer> aroundConstructInterceptors = new OrderedItemContainer<>(); private final OrderedItemContainer> postConstructInterceptors = new OrderedItemContainer<>(); private final OrderedItemContainer> preDestroyInterceptors = new OrderedItemContainer<>(); private final OrderedItemContainer> prePassivateInterceptors = new OrderedItemContainer<>(); private final OrderedItemContainer> postActivateInterceptors = new OrderedItemContainer<>(); private final Map>> componentInterceptors = new IdentityHashMap<>(); //TODO: move this into an Jakarta Enterprise Beans specific configuration private final Map> timeoutInterceptors = new IdentityHashMap<>(); // Component instance management private ComponentFactory instanceFactory; private final List>> createDependencies = new ArrayList>>(); private final List> startDependencies = new ArrayList>(); // Views private final List views = new ArrayList(); private InterceptorFactory namespaceContextInterceptorFactory; private NamespaceContextSelector namespaceContextSelector; private final Set interceptorContextKeys = new HashSet(); /** * Contains a set of all lifecycle methods defined by the bean */ private final Set lifecycleMethods = new HashSet<>(); public ComponentConfiguration(final ComponentDescription componentDescription, final ClassReflectionIndex classIndex, final ClassLoader moduleClassLoader, final ModuleLoader moduleLoader) { this.componentDescription = componentDescription; this.classIndex = classIndex; this.moduleClassLoader = moduleClassLoader; this.moduleLoader = moduleLoader; this.concurrentContext = new ConcurrentContext(); } /** * Get the component description. * * @return the component description */ public ComponentDescription getComponentDescription() { return componentDescription; } /** * Get the component class. * * @return the component class */ public Class getComponentClass() { return classIndex.getIndexedClass(); } /** * Get the component name. * * @return the component name */ public String getComponentName() { return componentDescription.getComponentName(); } /** * Get the set of currently known component methods. This is an identity set. * * @return the set of methods */ public Set getDefinedComponentMethods() { return classIndex.getClassMethods(); } /** * Gets the interceptor list for a given method. This should not be called until * all interceptors have been added. * * @param method the component method * @return the deque */ public List getComponentInterceptors(Method method) { Map>> map = componentInterceptors; OrderedItemContainer> interceptors = map.get(method); if (interceptors == null) { return Collections.emptyList(); } List> sortedItems = interceptors.getSortedItems(); List ret = new ArrayList<>(); for(List item : sortedItems) { ret.addAll(item); } return ret; } /** * Gets the around timeout interceptor list for a given method. This should not be called until * all interceptors have been added. * * @param method the component method * @return the deque */ public List getAroundTimeoutInterceptors(Method method) { Map> map = timeoutInterceptors; OrderedItemContainer interceptors = map.get(method); if (interceptors == null) { return Collections.emptyList(); } return interceptors.getSortedItems(); } /** * Adds an interceptor factory to every method on the component. * * @param factory The interceptor factory to add * @param priority The interceptors relative order * @param publicOnly If true then then interceptor is only added to public methods */ public void addComponentInterceptor(InterceptorFactory factory, int priority, boolean publicOnly) { addComponentInterceptors(Collections.singletonList(factory), priority, publicOnly); } /** * Adds an interceptor factory to every method on the component. * * @param factory The interceptor factory to add * @param priority The interceptors relative order * @param publicOnly If true then then interceptor is only added to public methods */ public void addComponentInterceptors(List factory, int priority, boolean publicOnly) { for (Method method : (Iterable)classIndex.getClassMethods()) { if (publicOnly && !Modifier.isPublic(method.getModifiers())) { continue; } OrderedItemContainer> interceptors = componentInterceptors.get(method); if (interceptors == null) { componentInterceptors.put(method, interceptors = new OrderedItemContainer>()); } interceptors.add(factory, priority); } } /** * Adds an interceptor factory to a given method. The method parameter *must* be retrived from either the * {@link org.jboss.as.server.deployment.reflect.DeploymentReflectionIndex} or from {@link #getDefinedComponentMethods()}, * as the methods are stored in an identity hash map * * @param method The method to add the interceptor to * @param factory The interceptor factory to add * @param priority The interceptors relative order */ public void addComponentInterceptor(Method method, InterceptorFactory factory, int priority) { addComponentInterceptors(method, Collections.singletonList(factory), priority); } /** * Adds an interceptor factory to a given method. The method parameter *must* be retrived from either the * {@link org.jboss.as.server.deployment.reflect.DeploymentReflectionIndex} or from {@link #getDefinedComponentMethods()}, * as the methods are stored in an identity hash map * * @param method The method to add the interceptor to * @param factory The interceptor factory to add * @param priority The interceptors relative order */ public void addComponentInterceptors(Method method, List factory, int priority) { OrderedItemContainer> interceptors = componentInterceptors.get(method); if (interceptors == null) { componentInterceptors.put(method, interceptors = new OrderedItemContainer>()); } interceptors.add(factory, priority); } /** * Adds a timeout interceptor factory to every method on the component. * * @param factory The interceptor factory to add * @param priority The interceptors relative order */ public void addTimeoutViewInterceptor(InterceptorFactory factory, int priority) { for (Method method : (Iterable)classIndex.getClassMethods()) { OrderedItemContainer interceptors = timeoutInterceptors.get(method); if (interceptors == null) { timeoutInterceptors.put(method, interceptors = new OrderedItemContainer()); } interceptors.add(factory, priority); } } /** * Adds a timeout interceptor factory to every method on the component. * * @param method The method to add it to * @param factory The interceptor factory to add * @param priority The interceptors relative order */ public void addTimeoutViewInterceptor(final Method method, InterceptorFactory factory, int priority) { OrderedItemContainer interceptors = timeoutInterceptors.get(method); if (interceptors == null) { timeoutInterceptors.put(method, interceptors = new OrderedItemContainer()); } interceptors.add(factory, priority); } /** * Get the create dependencies list. * * @return the create dependencies list */ public List>> getCreateDependencies() { return createDependencies; } /** * Get the start dependencies list. * * @return the start dependencies list */ public List> getStartDependencies() { return startDependencies; } /** * Get the list of views for this component. * * @return the list of views */ public List getViews() { return views; } /** * Get the around-construct interceptors. *

* This method should only be called after all interceptors have been added * * @return the sorted interceptors */ public List getAroundConstructInterceptors() { List> sortedItems = aroundConstructInterceptors.getSortedItems(); List interceptorFactories = new ArrayList<>(); for(List i : sortedItems) { interceptorFactories.addAll(i); } return interceptorFactories; } /** * Adds an around-construct interceptor * * @param factories The interceptors to add * @param priority The priority */ public void addAroundConstructInterceptors(List factories, int priority) { aroundConstructInterceptors.add(factories, priority); } /** * Adds an around-construct interceptor * * @param interceptorFactory The interceptor to add * @param priority The priority */ public void addAroundConstructInterceptor(InterceptorFactory interceptorFactory, int priority) { aroundConstructInterceptors.add(Collections.singletonList(interceptorFactory), priority); } /** * Get the post-construct interceptors. *

* This method should only be called after all interceptors have been added * * @return the sorted interceptors */ public List getPostConstructInterceptors() { List> sortedItems = postConstructInterceptors.getSortedItems(); List interceptorFactories = new ArrayList<>(); for(List i : sortedItems) { interceptorFactories.addAll(i); } return interceptorFactories; } /** * Adds a post construct interceptor * * @param interceptorFactory The interceptor to add * @param priority The priority */ public void addPostConstructInterceptors(List interceptorFactory, int priority) { postConstructInterceptors.add(interceptorFactory, priority); } /** * Adds a post construct interceptor * * @param interceptorFactory The interceptor to add * @param priority The priority */ public void addPostConstructInterceptor(InterceptorFactory interceptorFactory, int priority) { postConstructInterceptors.add(Collections.singletonList(interceptorFactory), priority); } /** * Get the pre-destroy interceptors. *

* This method should only be called after all interceptors have been added * * @return the sorted interceptor */ public List getPreDestroyInterceptors() { List> sortedItems = preDestroyInterceptors.getSortedItems(); List interceptorFactories = new ArrayList<>(); for(List i : sortedItems) { interceptorFactories.addAll(i); } return interceptorFactories; } /** * Adds a pre destroy interceptor * * @param factories The interceptor factory to add * @param priority The factories priority */ public void addPreDestroyInterceptors(List factories, int priority) { preDestroyInterceptors.add(factories, priority); } /** * Adds a pre destroy interceptor * * @param interceptorFactory The interceptor factory to add * @param priority The factories priority */ public void addPreDestroyInterceptor(InterceptorFactory interceptorFactory, int priority) { preDestroyInterceptors.add(Collections.singletonList(interceptorFactory), priority); } /** * Get the pre-passivate interceptors. *

* This method should only be called after all interceptors have been added * * @return the sorted interceptors */ public List getPrePassivateInterceptors() { List> sortedItems = prePassivateInterceptors.getSortedItems(); List interceptorFactories = new ArrayList<>(); for(List i : sortedItems) { interceptorFactories.addAll(i); } return interceptorFactories; } /** * Adds a pre passivate interceptor * * @param factories The interceptor to add * @param priority The priority */ public void addPrePassivateInterceptors(List factories, int priority) { prePassivateInterceptors.add(factories, priority); } /** * Adds a pre passivate interceptor * * @param interceptorFactory The interceptor to add * @param priority The priority */ public void addPrePassivateInterceptor(InterceptorFactory interceptorFactory, int priority) { prePassivateInterceptors.add(Collections.singletonList(interceptorFactory), priority); } /** * Get the post-activate interceptors. *

* This method should only be called after all interceptors have been added * * @return the sorted interceptors */ public List getPostActivateInterceptors() { List> sortedItems = postActivateInterceptors.getSortedItems(); List interceptorFactories = new ArrayList<>(); for(List i : sortedItems) { interceptorFactories.addAll(i); } return interceptorFactories; } /** * Adds a post activate interceptor * * @param interceptorFactory The interceptor to add * @param priority The priority */ public void addPostActivateInterceptors(List interceptorFactory, int priority) { postActivateInterceptors.add(interceptorFactory, priority); } /** * Adds a post activate interceptor * * @param interceptorFactory The interceptor to add * @param priority The priority */ public void addPostActivateInterceptor(InterceptorFactory interceptorFactory, int priority) { postActivateInterceptors.add(Collections.singletonList(interceptorFactory), priority); } /** * Get the application name. * * @return the application name */ public String getApplicationName() { return componentDescription.getApplicationName(); } /** * Get the module name. * * @return the module name */ public String getModuleName() { return componentDescription.getModuleName(); } /** * Get the instance factory for this component. * * @return the instance factory */ public ComponentFactory getInstanceFactory() { return instanceFactory; } /** * Set the instance factory for this component. * * @param instanceFactory the instance factory */ public void setInstanceFactory(final ComponentFactory instanceFactory) { this.instanceFactory = instanceFactory; } public ClassReflectionIndex getClassIndex() { return classIndex; } /** * Get the component create service factory for this component. * * @return the component create service factory */ public ComponentCreateServiceFactory getComponentCreateServiceFactory() { return componentCreateServiceFactory; } /** * Set the component create service factory for this component. * * @param componentCreateServiceFactory the component create service factory */ public void setComponentCreateServiceFactory(final ComponentCreateServiceFactory componentCreateServiceFactory) { if (componentCreateServiceFactory == null) { throw EeLogger.ROOT_LOGGER.nullVar("componentCreateServiceFactory", "component", getComponentName()); } this.componentCreateServiceFactory = componentCreateServiceFactory; } public String toString() { return getClass().getName() + "[name=" + componentDescription.getComponentName() + " class=" + componentDescription.getComponentClassName() + "]"; } public InterceptorFactory getNamespaceContextInterceptorFactory() { return namespaceContextInterceptorFactory; } public void setNamespaceContextInterceptorFactory(InterceptorFactory interceptorFactory) { this.namespaceContextInterceptorFactory = interceptorFactory; } public ClassLoader getModuleClassLoader() { return moduleClassLoader; } public ModuleLoader getModuleLoader() { return moduleLoader; } /** * @return The components namespace context selector, if any */ public NamespaceContextSelector getNamespaceContextSelector() { return namespaceContextSelector; } public void setNamespaceContextSelector(final NamespaceContextSelector namespaceContextSelector) { this.namespaceContextSelector = namespaceContextSelector; } public Set getInterceptorContextKeys() { return interceptorContextKeys; } public ConcurrentContext getConcurrentContext() { return concurrentContext; } /** * Adds a lifecycle method to the lifecycle methods set * * @param method The lifecycle method */ public void addLifecycleMethod(Method method) { lifecycleMethods.add(method); } /** * Returns a set of all lifecycle methods defined on the bean * * @return All lifecycle methods defined on the component class and its superclasses */ public Set getLifecycleMethods() { return Collections.unmodifiableSet(lifecycleMethods); } }