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

org.apache.camel.spi.RestConsumerFactory Maven / Gradle / Ivy

There is a newer version: 4.9.0
Show newest version
/*
 * 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.camel.spi;

import java.util.Map;

import org.apache.camel.CamelContext;
import org.apache.camel.Consumer;
import org.apache.camel.Processor;

/**
 * Allows SPI to plugin a {@link RestConsumerFactory} that creates the Camel {@link Consumer} responsible for handling
 * incoming HTTP requests from clients that request to access REST services which has been created using the
 * rest-dsl.
 *
 * @see RestApiConsumerFactory
 * @see RestOpenApiConsumerFactory
 * @see RestApiProcessorFactory
 */
public interface RestConsumerFactory {

    /**
     * Creates a new REST Event Driven Consumer, which
     * consumes messages from the endpoint using the given processor
     *
     * @param  camelContext  the camel context
     * @param  processor     the processor
     * @param  verb          HTTP verb such as GET, POST
     * @param  basePath      base path
     * @param  uriTemplate   uri template
     * @param  consumes      media-types for what this REST service consume as input (accept-type), is null or
     *                       */* for anything
     * @param  produces      media-types for what this REST service produces as output, can be null
     * @param  configuration REST configuration
     * @param  parameters    additional parameters
     * @return               a newly created REST consumer
     * @throws Exception     can be thrown
     */
    Consumer createConsumer(
            CamelContext camelContext, Processor processor, String verb, String basePath, String uriTemplate,
            String consumes, String produces, RestConfiguration configuration, Map parameters)
            throws Exception;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy