org.apache.camel.spi.RestRegistry 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.camel.spi;
import java.util.List;
import org.apache.camel.Consumer;
import org.apache.camel.StaticService;
/**
* A registry of all REST services running within the {@link org.apache.camel.CamelContext} which have been defined and
* created using the Rest DSL.
*/
public interface RestRegistry extends StaticService {
/**
* Details about the REST service
*/
interface RestService {
/**
* Gets the consumer of the REST service
*/
Consumer getConsumer();
/**
* Is the rest service based on code-first or contract-first
*/
boolean isContractFirst();
/**
* Gets the state of the REST service (started, stopped, etc)
*/
String getState();
/**
* Gets the absolute url to the REST service (baseUrl + uriTemplate)
*/
String getUrl();
/**
* Gets the base url to the REST service
*/
String getBaseUrl();
/**
* Gets the base path to the REST service
*/
String getBasePath();
/**
* Gets the uri template
*/
String getUriTemplate();
/**
* Gets the HTTP method (GET, POST, PUT etc)
*/
String getMethod();
/**
* Optional details about what media-types the REST service accepts
*/
String getConsumes();
/**
* Optional details about what media-types the REST service returns
*/
String getProduces();
/**
* Optional detail about input binding to a FQN class name.
*
* If the input accepts a list, then List<class name> is enclosed the name.
*/
String getInType();
/**
* Optional detail about output binding to a FQN class name.
*
* If the output accepts a list, then List<class name> is enclosed the name.
*/
String getOutType();
/**
* Optional description about this rest service.
*/
String getDescription();
}
/**
* Adds a new REST service to the registry.
*
* @param consumer the consumer
* @param contractFirst is the rest service based on code-first or contract-first
* @param url the absolute url of the REST service
* @param baseUrl the base url of the REST service
* @param basePath the base path
* @param uriTemplate the uri template
* @param method the HTTP method
* @param consumes optional details about what media-types the REST service accepts
* @param produces optional details about what media-types the REST service returns
* @param inType optional detail input binding to a FQN class name
* @param outType optional detail output binding to a FQN class name
* @param routeId the id of the route this rest service will be using
* @param description optional description about the service
*/
void addRestService(
Consumer consumer, boolean contractFirst, String url, String baseUrl, String basePath, String uriTemplate,
String method,
String consumes, String produces, String inType, String outType, String routeId, String description);
/**
* Removes the REST service from the registry
*
* @param consumer the consumer
*/
void removeRestService(Consumer consumer);
/**
* List all REST services from this registry.
*
* @return all the REST services
*/
List listAllRestServices();
/**
* Number of rest services in the registry.
*
* @return number of rest services in the registry.
*/
int size();
/**
* Outputs the Rest services API documentation in JSON (requires camel-openapi-java on classpath)
*
* @return the API docs in JSon, or null if camel-openapi-java is not on classpath
*/
String apiDocAsJson();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy