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

override.eventbus.adoc Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR1
Show newest version
==== Message Codecs

You can send any object you like across the event bus if you define and register a {@link io.vertx.core.eventbus.MessageCodec message codec} for it.

Message codecs have a name and you specify that name in the {@link io.vertx.core.eventbus.DeliveryOptions}
when sending or publishing the message:

[source,java]
----
{@link docoverride.eventbus.Examples#example10}
----

If you always want the same codec to be used for a particular type then you can register a default codec for it, then
you don't have to specify the codec on each send in the delivery options:

[source,java]
----
{@link docoverride.eventbus.Examples#example11}
----

You unregister a message codec with {@link io.vertx.core.eventbus.EventBus#unregisterCodec}.

Message codecs don't always have to encode and decode as the same type. For example you can write a codec that
allows a MyPOJO class to be sent, but when that message is sent to a handler it arrives as a MyOtherPOJO class.

Vert.x has built-in codecs for certain data types:

- basic types (string, byte array, byte, int, long, double, boolean, short, char), or
- some Vert.x data types (buffers, JSON array, JSON objects), or
- types implementing the {@link io.vertx.core.shareddata.ClusterSerializable} interface, or
- types implementing the `java.io.Serializable` interface.

[IMPORTANT]
====
In clustered mode, {@link io.vertx.core.shareddata.ClusterSerializable} and `java.io.Serializable` objects are rejected by default, for security reasons.

You can define which classes are allowed for encoding and decoding by providing functions which inspect the name of the class:

- {@link io.vertx.core.eventbus.EventBus#clusterSerializableChecker EventBus.clusterSerializableChecker()}, and
- {@link io.vertx.core.eventbus.EventBus#serializableChecker EventBus.serializableChecker()}.
====




© 2015 - 2024 Weber Informatics LLC | Privacy Policy