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

org.glassfish.jersey.process.internal.ExecutorProviders Maven / Gradle / Ivy

Go to download

A bundle project producing JAX-RS RI bundles. The primary artifact is an "all-in-one" OSGi-fied JAX-RS RI bundle (jaxrs-ri.jar). Attached to that are two compressed JAX-RS RI archives. The first archive (jaxrs-ri.zip) consists of binary RI bits and contains the API jar (under "api" directory), RI libraries (under "lib" directory) as well as all external RI dependencies (under "ext" directory). The secondary archive (jaxrs-ri-src.zip) contains buildable JAX-RS RI source bundle and contains the API jar (under "api" directory), RI sources (under "src" directory) as well as all external RI dependencies (under "ext" directory). The second archive also contains "build.xml" ANT script that builds the RI sources. To build the JAX-RS RI simply unzip the archive, cd to the created jaxrs-ri directory and invoke "ant" from the command line.

The newest version!
/*
 * Copyright (c) 2012, 2020 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0, which is available at
 * http://www.eclipse.org/legal/epl-2.0.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the
 * Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
 * version 2 with the GNU Classpath Exception, which is available at
 * https://www.gnu.org/software/classpath/license.html.
 *
 * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
 */

package org.glassfish.jersey.process.internal;

import java.lang.annotation.Annotation;
import java.util.HashMap;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.ScheduledExecutorService;
import java.util.logging.Level;
import java.util.logging.Logger;

import jakarta.inject.Named;
import jakarta.inject.Qualifier;
import jakarta.inject.Singleton;

import org.glassfish.jersey.internal.LocalizationMessages;
import org.glassfish.jersey.internal.inject.Bindings;
import org.glassfish.jersey.internal.inject.DisposableSupplier;
import org.glassfish.jersey.internal.inject.InjectionManager;
import org.glassfish.jersey.internal.inject.Providers;
import org.glassfish.jersey.internal.inject.SupplierInstanceBinding;
import org.glassfish.jersey.internal.util.ExtendedLogger;
import org.glassfish.jersey.internal.util.ReflectionHelper;
import org.glassfish.jersey.spi.ExecutorServiceProvider;
import org.glassfish.jersey.spi.ScheduledExecutorServiceProvider;

/**
 * A utility class with a methods for handling executor injection registration and proper disposal.
 *
 * @author Marek Potociar
 */
public final class ExecutorProviders {

    private static final ExtendedLogger LOGGER =
            new ExtendedLogger(Logger.getLogger(ExecutorProviders.class.getName()), Level.FINEST);

    private ExecutorProviders() {
        throw new AssertionError("Instantiation not allowed.");
    }

    /**
     * Create qualified {@link ExecutorService} and {@link ScheduledExecutorService} injection bindings based on the registered
     * providers implementing the {@link ExecutorServiceProvider} and/or {@link ScheduledExecutorServiceProvider} SPI.
     * 

* This method supports creation of qualified injection bindings based on custom {@link Qualifier qualifier annotations} * attached to the registered provider implementation classes as well as named injection bindings based on the {@link Named} * qualifier annotation attached to the registered provider implementation classes. {@link ExecutorServiceProvider} and * {@link ScheduledExecutorServiceProvider} will be retrieved from {@link InjectionManager}. * * @param injectionManager application's injection manager. */ public static void registerExecutorBindings(InjectionManager injectionManager) { List executorProviders = getExecutorProviders(injectionManager, ExecutorServiceProvider.class); List scheduledProviders = getExecutorProviders(injectionManager, ScheduledExecutorServiceProvider.class); registerExecutorBindings(injectionManager, executorProviders, scheduledProviders); } private static List getExecutorProviders(InjectionManager injectionManager, Class providerClass) { Set customProviders = Providers.getCustomProviders(injectionManager, providerClass); Set defaultProviders = Providers.getProviders(injectionManager, providerClass); // Get only default providers defaultProviders.removeAll(customProviders); List executorProviders = new LinkedList<>(customProviders); executorProviders.addAll(defaultProviders); return executorProviders; } /** * Create qualified {@link ExecutorService} and {@link ScheduledExecutorService} injection bindings based on the registered * providers implementing the {@link ExecutorServiceProvider} and/or {@link ScheduledExecutorServiceProvider} SPI. *

* This method supports creation of qualified injection bindings based on custom {@link Qualifier qualifier annotations} * attached to the registered provider implementation classes as well as named injection bindings based on the {@link Named} * qualifier annotation attached to the registered provider implementation classes. * * @param injectionManager injection manager to register newly created executor bindings. * @param executorProviders all executor providers registered internally in Jersey and in configuration. * @param scheduledProviders all scheduled executor providers registered internally in Jersey and in configuration. */ public static void registerExecutorBindings( InjectionManager injectionManager, List executorProviders, List scheduledProviders) { Map, List> executorProviderMap = getQualifierToProviderMap(executorProviders); /* * Add ExecutorService into DI framework. */ for (Map.Entry, List> qualifierToProviders : executorProviderMap.entrySet()) { Class qualifierAnnotationClass = qualifierToProviders.getKey(); Iterator bucketProviderIterator = qualifierToProviders.getValue().iterator(); ExecutorServiceProvider executorProvider = bucketProviderIterator.next(); logExecutorServiceProvider(qualifierAnnotationClass, bucketProviderIterator, executorProvider); SupplierInstanceBinding descriptor = Bindings.supplier(new ExecutorServiceSupplier(executorProvider)) .in(Singleton.class) .to(ExecutorService.class); Annotation qualifier = executorProvider.getClass().getAnnotation(qualifierAnnotationClass); if (qualifier instanceof Named) { descriptor.named(((Named) qualifier).value()); } else { descriptor.qualifiedBy(qualifier); } injectionManager.register(descriptor); } Map, List> schedulerProviderMap = getQualifierToProviderMap(scheduledProviders); /* * Add ScheduledExecutorService into DI framework. */ for (Map.Entry, List> qualifierToProviders : schedulerProviderMap.entrySet()) { Class qualifierAnnotationClass = qualifierToProviders.getKey(); Iterator bucketProviderIterator = qualifierToProviders.getValue().iterator(); ScheduledExecutorServiceProvider executorProvider = bucketProviderIterator.next(); logScheduledExecutorProvider(qualifierAnnotationClass, bucketProviderIterator, executorProvider); SupplierInstanceBinding descriptor = Bindings.supplier(new ScheduledExecutorServiceSupplier(executorProvider)) .in(Singleton.class) .to(ScheduledExecutorService.class); if (!executorProviderMap.containsKey(qualifierAnnotationClass)) { // it is safe to register binding for ExecutorService too... descriptor.to(ExecutorService.class); } Annotation qualifier = executorProvider.getClass().getAnnotation(qualifierAnnotationClass); if (qualifier instanceof Named) { descriptor.named(((Named) qualifier).value()); } else { descriptor.qualifiedBy(qualifier); } injectionManager.register(descriptor); } } private static void logScheduledExecutorProvider(Class qualifierAnnotationClass, Iterator bucketProviderIterator, ScheduledExecutorServiceProvider executorProvider) { if (LOGGER.isLoggable(Level.CONFIG)) { LOGGER.config(LocalizationMessages.USING_SCHEDULER_PROVIDER( executorProvider.getClass().getName(), qualifierAnnotationClass.getName())); if (bucketProviderIterator.hasNext()) { StringBuilder msg = new StringBuilder(bucketProviderIterator.next().getClass().getName()); while (bucketProviderIterator.hasNext()) { msg.append(", ").append(bucketProviderIterator.next().getClass().getName()); } LOGGER.config(LocalizationMessages.IGNORED_SCHEDULER_PROVIDERS( msg.toString(), qualifierAnnotationClass.getName())); } } } private static void logExecutorServiceProvider(Class qualifierAnnotationClass, Iterator bucketProviderIterator, ExecutorServiceProvider executorProvider) { if (LOGGER.isLoggable(Level.CONFIG)) { LOGGER.config(LocalizationMessages.USING_EXECUTOR_PROVIDER( executorProvider.getClass().getName(), qualifierAnnotationClass.getName())); if (bucketProviderIterator.hasNext()) { StringBuilder msg = new StringBuilder(bucketProviderIterator.next().getClass().getName()); while (bucketProviderIterator.hasNext()) { msg.append(", ").append(bucketProviderIterator.next().getClass().getName()); } LOGGER.config(LocalizationMessages.IGNORED_EXECUTOR_PROVIDERS( msg.toString(), qualifierAnnotationClass.getName())); } } } private static Map, List> getQualifierToProviderMap( List executorProviders) { // iterate over providers and map them by Qualifier annotations (custom ones will be added to the buckets first) final Map, List> executorProviderMap = new HashMap<>(); for (T provider : executorProviders) { for (Class qualifier : ReflectionHelper.getAnnotationTypes(provider.getClass(), Qualifier.class)) { List providersForQualifier; if (!executorProviderMap.containsKey(qualifier)) { providersForQualifier = new LinkedList<>(); executorProviderMap.put(qualifier, providersForQualifier); } else { providersForQualifier = executorProviderMap.get(qualifier); } providersForQualifier.add(provider); } } return executorProviderMap; } private static class ExecutorServiceSupplier implements DisposableSupplier { private final ExecutorServiceProvider executorProvider; private ExecutorServiceSupplier(ExecutorServiceProvider executorServiceProvider) { executorProvider = executorServiceProvider; } @Override public ExecutorService get() { return executorProvider.getExecutorService(); } @Override public void dispose(final ExecutorService instance) { executorProvider.dispose(instance); } } private static class ScheduledExecutorServiceSupplier implements DisposableSupplier { private final ScheduledExecutorServiceProvider executorProvider; private ScheduledExecutorServiceSupplier(ScheduledExecutorServiceProvider executorServiceProvider) { executorProvider = executorServiceProvider; } @Override public ScheduledExecutorService get() { return executorProvider.getExecutorService(); } @Override public void dispose(final ScheduledExecutorService instance) { executorProvider.dispose(instance); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy