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

x-camel-bridge.4.4.6.source-code.index.adoc Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR3
Show newest version
= Vert.x Camel Bridge
:toc: left

Apache Camel (http://camel.apache.org) is an open source Java framework that focuses on making integration easier
and more accessible to developers. This bridge lets Vert.x applications interact with Camel endpoints:

* the application can send messages to Camel.
* the application can receive message from Camel.

The bridge relies on the Vert.x event bus and associate an event bus address to a Camel endpoint.

CAUTION: This component is not _polyglot_ as it requires some classes from Camel that can only be used in Java.

== Using vertx-camel-bridge

To use the Vert.x Camel Bridge, add the following dependency to the _dependencies_ section of your
build descriptor:

* Maven (in your `pom.xml`):

[source,xml,subs="+attributes"]
----

  ${maven.groupId}
  ${maven.artifactId}
  ${maven.version}

----

* Gradle (in your `build.gradle` file):

[source,groovy,subs="+attributes"]
----
compile '${maven.groupId}:${maven.artifactId}:${maven.version}'
----

== Bridge configuration

Before being used, the bridge needs to be configured and started:

[source,$lang]
----
{@link examples.Examples#example1(io.vertx.core.Vertx)}
----

The bridge requires a `CamelContext`. It will find the endpoint from the context. The bridge needs to be started
before being used. Be aware the the `start` method is asynchronous. You can use
{@link io.vertx.camel.CamelBridge#start(io.vertx.core.Handler)} to be notified when the bridge has been started.



=== Inbound mapping

Inbound mapping associates a Camel endpoint to an event bus address. Messages received on this endpoint are
transformed to event bus messages.

[source,$lang]
----
{@link examples.Examples#example2(io.vertx.core.Vertx, org.apache.camel.CamelContext)}
----

The snippet above shows different ways to configure an inbound mapping:

* you can configure the Camel endpoint either using the `Endpoint` object or its uri
* you can disables the header copy (Camel message headers are copied to the event bus message)
* you can uses `publish` instead of `send` to broadcast the message to all event bus consumers
* you can configures the type of the event bus message body. If not set it uses the Camel message payload. If
sets, it looks in the Camel context for a converter between the Camel message payload and the desired type.

_Note_: `org.fusesource.hawtbuf.Buffer` are automatically converted to {@link io.vertx.core.buffer.Buffer}.

If `send` is used (so not `publish`), and when the Camel exchange expect a reply (_In Out_ exchange), the Vert.x
code expect as reply to the sent message. When the reply arrives it is propagated to the exchange:

[source,$lang]
----
{@link examples.Examples#example6(io.vertx.core.Vertx, org.apache.camel.CamelContext)}
----

You can also configure the reply `timeout` using {@link io.vertx.camel.InboundMapping#setTimeout(int)}.

=== Outbound mapping

Outbound mapping associates an event bus address to a Camel endpoint. Messages received on this event bus address
are transformed to Camel messages and sent to the endpoint.

[source,$lang]
----
{@link examples.Examples#example3(io.vertx.core.Vertx, org.apache.camel.CamelContext)}
----

The snippet above shows different ways to configure an outbound mapping.

You can connect your outbound mapping to a Camel route:

[source,$lang]
----
{@link examples.Examples#example4(io.vertx.core.Vertx, org.apache.camel.CamelContext)}
----

If when you send the message on the event bus you register a reply handler, it configures the Camel exchange to
expect a response (it uses the request-reply pattern of the EIP). The response is passed in the reply body. If the
route fails, you get a reply failure (recipient failure), with the message as cause:

[source,$lang]
----
{@link examples.Examples#example5(io.vertx.core.Vertx, org.apache.camel.CamelContext)}
----

If the processing you apply is blocking, you*must** set _blocking_ to `true`. This avoid executing the
processing on the event loop thread:

[source,$lang]
----
{@link examples.Examples#example51(io.vertx.core.Vertx, org.apache.camel.CamelContext)}
----

By default it uses the default worker thread pool, this is customizable using the
{@link io.vertx.camel.OutboundMapping#setWorkerExecutor(io.vertx.core.WorkerExecutor)} method.

== Stopping the bridge

Don't forget to stop the bridge using the `stop` method. The `stop` method is asynchronous. You can use
{@link io.vertx.camel.CamelBridge#stop(io.vertx.core.Handler)} to be notified when the bridge has been stopped.

[language, java]
----
== Exchanging custom object

If you want to send and receive custom objects, you need to register a codec on the event bus:

[source,$lang]
\----
{@link examples.Examples#registerCodec(io.vertx.core.Vertx, io.vertx.core.eventbus.MessageCodec)}
\----

----




© 2015 - 2025 Weber Informatics LLC | Privacy Policy