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.6.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 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 - 2024 Weber Informatics LLC | Privacy Policy