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

org.glassfish.jersey.server.spi.ContainerProvider Maven / Gradle / Ivy

/*
 * Copyright (c) 2010, 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.server.spi;

import jakarta.ws.rs.ConstrainedTo;
import jakarta.ws.rs.ProcessingException;
import jakarta.ws.rs.RuntimeType;
import jakarta.ws.rs.core.Application;

import org.glassfish.jersey.server.ApplicationHandler;
import org.glassfish.jersey.spi.Contract;

/**
 * Service-provider interface for creating container instances.
 *
 * If supported by the provider, a container instance of the requested Java type
 * will be created.
 * 

* The created container is responsible for listening on a communication chanel * for new client requests, dispatching these requests to the registered * {@link ApplicationHandler Jersey application handler} using the handler's * {@link ApplicationHandler#handle(org.glassfish.jersey.server.ContainerRequest)} * handle(requestContext)} method and sending the responses provided by the * application back to the client. *

*

* A provider shall support a one-to-one mapping between a type, provided the type * is not {@link Object}. A provider may also support mapping of sub-types of a type * (provided the type is not {@code Object}). It is expected that each provider * supports mapping for distinct set of types and subtypes so that different providers * do not conflict with each other. *

*

* An implementation can identify itself by placing a Java service provider configuration * file (if not already present) - {@code org.glassfish.jersey.server.spi.ContainerProvider} * - in the resource directory {@code META-INF/services}, and adding the fully * qualified service-provider-class of the implementation in the file. *

* * @author Paul Sandoz * @author Jakub Podlesak * @author Marek Potociar */ @Contract @ConstrainedTo(RuntimeType.SERVER) public interface ContainerProvider { /** * Create an container of a given type. * * @param the type of the container. * @param type the type of the container. * @param application JAX-RS / Jersey application. * @return the container, otherwise {@code null} if the provider does not support the requested {@code type}. * * @throws ProcessingException if there is an error creating the container. */ public T createContainer(Class type, Application application) throws ProcessingException; }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy