/** * 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.lang.annotation.Documented; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** * Represents an annotated Camel <a href="http://camel.apache.org/endpoint.html">Endpoint</a> * which can have its properties (and the properties on its consumer) injected from the * Camel URI path and its query parameters */ @Retention(RetentionPolicy.RUNTIME) @Documented @Target({ElementType.TYPE}) public @interface UriEndpoint { /** * The first version this endpoint was added to Apache Camel. */ String firstVersion() default ""; /** * Represents the URI scheme name of this endpoint. * <p/> * Multiple scheme names can be defined as a comma separated value. * For example to associate <tt>http</tt> and <tt>https</tt> to the same endpoint implementation. * <p/> * The order of the scheme names here should be the same order as in {@link #extendsScheme()} so their are paired. */ String scheme(); /** * Used when an endpoint is extending another endpoint * <p/> * Multiple scheme names can be defined as a comma separated value. * For example to associate <tt>ftp</tt> and <tt>ftps</tt> to the same endpoint implementation. * The order of the scheme names here should be the same order as in {@link #scheme()} so their are paired. */ String extendsScheme() default ""; /** * Represent the URI syntax the endpoint must use. * <p/> * The syntax follows the patterns such as: * <ul> * <li>scheme:host:port</li> * <li>scheme:host:port/path</li> * <li>scheme:path</li> * <li>scheme:path/path2</li> * </ul> * Where each path maps to the name of the endpoint {@link org.apache.camel.spi.UriPath} option. * The query parameters is implied and should not be included in the syntax. * <p/> * Some examples: * <ul> * <li>file:directoryName</li> * <li>ftp:host:port/directoryName</li> * <li>jms:destinationType:destinationName</li> * </ul> */ String syntax(); /** * If the endpoint supports specifying username and/or password in the UserInfo part of the URI, then the * alternative syntax can represent this such as: * <ul> * <li>ftp:userName:password@host:port/directoryName</li> * <li>ssh:username:password@host:port</li> * </ul> */ String alternativeSyntax() default ""; /** * Represents the consumer class which is injected and created by consumers */ Class<?> consumerClass() default Object.class; /** * The configuration parameter name prefix used on parameter names to separate the endpoint * properties from the consumer properties */ String consumerPrefix() default ""; /** * A human readable title of this entity, such as the component name of the this endpoint. * <p/> * For example: JMS, MQTT, Netty HTTP, SAP NetWeaver */ String title(); /** * To associate this endpoint with label(s). * <p/> * Multiple labels can be defined as a comma separated value. * <p/> * The labels is intended for grouping the endpoints, such as <tt>core</tt>, <tt>file</tt>, <tt>messaging</tt>, <tt>database</tt>, etc. */ String label() default ""; /** * Whether this endpoint can only be used as a producer. * <p/> * By default its assumed the endpoint can be used as both consumer and producer. */ boolean producerOnly() default false; /** * Whether this endpoint can only be used as a consumer. * <p/> * By default its assumed the endpoint can be used as both consumer and producer. */ boolean consumerOnly() default false; /** * Should all properties be known or does the endpoint allow unknown options? * <p/> * <tt>lenient = false</tt> means that the endpoint should validate that all * given options is known and configured properly. * <tt>lenient = true</tt> means that the endpoint allows additional unknown options to * be passed to it but does not throw a ResolveEndpointFailedException when creating * the endpoint. * <p/> * This options is used by a few components for instance the HTTP based that can have * dynamic URI options appended that is targeted for an external system. * <p/> * Most endpoints is configured to be <b>not</b> lenient. */ boolean lenientProperties() default false; /** * To exclude one or more properties in this endpoint. * <p/> * This is used when a Camel component extend another component, and then may need to not use some of the properties from * the parent component. Multiple properties can be separated by comma. */ String excludeProperties() default ""; }