@Retention(value=RUNTIME) @Target(value=TYPE) public @interface ImportResource
CamelContext elements and other Camel primitives are automatically deployed as CDI beans during the container
bootstrap so that they become available for injection at runtime. If such an element has an explicit id
attribute set, the corresponding CDI bean is qualified with the @Named qualifier, e.g., given the following
Camel XML configuration:
<camelContext id="foo">
<endpoint id="bar" uri="seda:inbound">
<property key="queue" value="#queue"/>
<property key="concurrentConsumers" value="10"/>
</endpoint>
<camelContext/>
Corresponding CDI beans are automatically deployed and can be injected, e.g.:
@Inject
@ContextName("foo")
CamelContext context;
@Inject
@Named("bar")
Endpoint endpoint;
Note that CamelContext beans are automatically qualified with both the Named and ContextName
qualifiers. If the imported CamelContext element doesn't have an id attribute, the corresponding bean
is deployed with the built-in Default qualifier.
Conversely, CDI beans deployed in the application can be referred to from the Camel XML configuration, usually using
the ref attribute, e.g., given the following bean declared:
@Produces
@Named("baz")
Processor processor = exchange -> exchange.getIn().setHeader("qux", "quux");
A reference to that bean can be declared in the imported Camel XML configuration, e.g.:
<camelContext id="foo">
<route>
<from uri="..."/>
<process ref="baz"/>
</route>
<camelContext/>
public abstract String[] value
Apache Camel