description |
---|
Creates messaging client reader for given transport layer |
import { messagingClient } from '@marblejs/messaging';
messagingClient :: MessagingClientConfig
-> Reader<Context, Promise<MessagingClient>>
parameter | definition |
---|---|
config | MessagingClientConfig |
parameter | definition |
---|---|
msgTransformer | <optional> TransportMessageTransformer |
transport | Transport (see: #createMicroservice) |
options | StrategyOptions (see: #createMicroservice) |
{% hint style="warning" %} Because of asynchronous nature of messaging client, all created readers have to be bound to server creators via eager binding 👉 #bindEagerlyTo {% endhint %}
To learn more about messagingClient
output interface please visit:
{% page-ref page="../../../messaging/microservices/" %}
import { bindEagerlyTo, createContextToken } from '@marblejs/core';
import { messagingClient, Transport } from '@marblejs/messaging';
const AmqpClientToken = createContextToken<MessagingClient>('AmqpClient');
const AmqpClient = messagingClient({
transport: Transport.AMQP,
options: {
host: 'amqp://localhost:5672',
queue: 'some_queue_name',
queueOptions: { durable: false },
timeout: 360 * 1000,
},
});
...
const dependencies = [
bindEagerlyTo(AmqpClientToken)(AmqpClient),
];
import { bindEagerlyTo, createContextToken } from '@marblejs/core';
import { messagingClient, Transport } from '@marblejs/messaging';
const RedisClientToken = createContextToken<MessagingClient>('RedisClient');
const RedisClient = messagingClient({
transport: Transport.REDIS,
options: {
host: 'redis://127.0.0.1:6379',
channel: 'some_channel_name',
timeout: 360 * 1000,
},
});
...
const dependencies = [
bindEagerlyTo(RedisClientToken)(RedisClient),
];