Skip to content

Latest commit

 

History

History
92 lines (65 loc) · 2.19 KB

messagingclient.md

File metadata and controls

92 lines (65 loc) · 2.19 KB
description
Creates messaging client reader for given transport layer

messagingClient

Importing

import { messagingClient } from '@marblejs/messaging';

Type declaration

messagingClient :: MessagingClientConfig
    -> Reader<Context, Promise<MessagingClient>>

Parameters

parameter definition
config MessagingClientConfig

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/" %}

Example (AMQP):

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),
];

Example (REDIS):

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),
];