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

org.apache.webbeans.spi.BeanArchiveService Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements. See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership. The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License. You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied. See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package org.apache.webbeans.spi;

import java.net.URL;
import java.util.List;
import java.util.Set;

/**
 * This Service returns information about scanned beans.xml files.
 * The information needs to be available until {@link #release()}
 * gets invoked. This is usually at the end of the deployment phase.
 *
 * This SPI uses URLs as parameters because many virtual file
 * systems do not store their resources on a file system and also
 * are not able to move from the externalForm back to the original URL.
 */
public interface BeanArchiveService
{
    /**
     * Defines how CDI beans got discovered for each
     * JAR or ClassPath entry (aka BDA).
     */
    enum BeanDiscoveryMode
    {
        /**
         * Pick up all classes as CDI beans.
         * Classes with no 'bean defining annotations'
         * will get picked up as @Dependent scoped beans.
         * This is basically the backward compatible mode to CDI-1.0.
         */
        ALL(10),

        /**
         * Pick up all classes (like with {@link #ALL} and fire the
         * ProcessAnnotatedType event for them.
         * But only pick up the scanned class as CDI bean:
         * 
    *
  • if they have an explicit CDI scope annotation, or
  • *
  • if they are an Interceptor or Decorator
  • *
  • if they are a JavaEE managed bean
  • *
* Contrary to the {@link #ALL} mode beans without any scope will * not get picked up as @Dependent scoped beans! */ SCOPED(8), /** * Only classes with a 'bean defining annotation' will get * picked up as CDI beans. * A 'bean defining annotation' is any CDI or atinject Scope annotation * as well as Stereotypes (the later only since CDI-1.2) */ ANNOTATED(5), /** * Ignore all classes in this BDA when it comes to beans scanning. */ NONE(2); /** * used for internal sorting. higher ordinal means more scanning */ private final int ordinal; BeanDiscoveryMode(int ordinal) { this.ordinal = ordinal; } public int getOrdinal() { return ordinal; } public static BeanDiscoveryMode getByOrdinal(int ordinal) { for (BeanDiscoveryMode beanDiscoveryMode : values()) { if (beanDiscoveryMode.getOrdinal() == ordinal) { return beanDiscoveryMode; } } return null; } public static BeanDiscoveryMode max(BeanDiscoveryMode bdmA, BeanDiscoveryMode bdmB) { if (bdmA == null) { return bdmB; } if (bdmB == null) { return bdmA; } return getByOrdinal(Math.max(bdmA.getOrdinal(), bdmB.getOrdinal())); } } /** * Contains information about a single Bean Definition Archive (BDA). */ interface BeanArchiveInformation { /** * @return the version string of the beans.xml file (if any), or null if not set */ String getVersion(); /** * @return the BeanDiscoveryMode used by this very BDA */ BeanDiscoveryMode getBeanDiscoveryMode(); /** * @return whether the given class is excluded from scanning or not */ boolean isClassExcluded(String clazz); /** * @return whether the given package is excluded from scanning or not */ boolean isPackageExcluded(String packageName); /** * @return the class name of the Interceptors defined in the beans.xml * in a <interceptors><class> section or an empty List. */ List getInterceptors(); /** * @return the class name of Decorators defined in this beans.xml * in a <decorators><class> section or an empty List. */ List getDecorators(); /** * @return the class name of the Alternatives defined in this beans.xml * in a <alternatives><class> section or an empty List. */ List getAlternativeClasses(); /** * @return the class name of the Alternatives defined in this beans.xml * in a <alternatives><stereotype> section or an empty List. */ List getAlternativeStereotypes(); List getExcludedClasses(); List getExcludedPackages(); List getAllowProxyingClasses(); } /** * The beanArchiveUrl might either point to a beans.xml file or the root of a JAR * or other ClassPath entry. In case there is no beans.xml (implicit bean archive), * then we assume the 'default' behaviour of only scanning classes with * 'bean defining annotations'. * @return the {@link BeanArchiveInformation} of the given URL. * @see BeanDiscoveryMode */ BeanArchiveInformation getBeanArchiveInformation(URL beanArchiveUrl); /** * This method is useful to later on know which JARs and ClassPath entries * did get scanned. * Please note that we use a special UrlSet internally which only holds * the externalForm as key and thus does no DNS resolving via the URL. * @return a Set of all registered Bean Archives. */ Set getRegisteredBeanArchives(); /** * Release the gathered information to free up memory. * This should get called at the end of the deployment phase. */ void release(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy