@jsnw/nestjs-rabbitmq 1.2.1 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,11 +1,13 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.RabbitmqSubscriber = exports.RabbitmqQueue = exports.RabbitmqExchange = exports.Rabbitmq = void 0;
3
+ exports.RabbitmqSubscriber = exports.RabbitmqMessage = exports.RabbitmqQueue = exports.RabbitmqExchange = exports.Rabbitmq = void 0;
4
4
  var rabbitmq_1 = require("./rabbitmq");
5
5
  Object.defineProperty(exports, "Rabbitmq", { enumerable: true, get: function () { return rabbitmq_1.Rabbitmq; } });
6
6
  var rabbitmq_exchange_1 = require("./rabbitmq-exchange");
7
7
  Object.defineProperty(exports, "RabbitmqExchange", { enumerable: true, get: function () { return rabbitmq_exchange_1.RabbitmqExchange; } });
8
8
  var rabbitmq_queue_1 = require("./rabbitmq-queue");
9
9
  Object.defineProperty(exports, "RabbitmqQueue", { enumerable: true, get: function () { return rabbitmq_queue_1.RabbitmqQueue; } });
10
+ var rabbitmq_message_1 = require("./rabbitmq-message");
11
+ Object.defineProperty(exports, "RabbitmqMessage", { enumerable: true, get: function () { return rabbitmq_message_1.RabbitmqMessage; } });
10
12
  var rabbitmq_subscriber_1 = require("./rabbitmq-subscriber");
11
13
  Object.defineProperty(exports, "RabbitmqSubscriber", { enumerable: true, get: function () { return rabbitmq_subscriber_1.RabbitmqSubscriber; } });
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RabbitmqMessage = void 0;
4
+ class RabbitmqMessage {
5
+ _template;
6
+ /**
7
+ * @param {T} template
8
+ * @return {RabbitmqMessageTemplate<T>}
9
+ */
10
+ static template(template) {
11
+ return new RabbitmqMessage(template);
12
+ }
13
+ /**
14
+ * @template {RabbitmqMessageTemplate} T
15
+ * @param {T} template
16
+ * @protected
17
+ */
18
+ constructor(template) {
19
+ this._template = template;
20
+ }
21
+ /**
22
+ * @param {InputData<T>} data
23
+ * @return {RabbitmqPublishOptions}
24
+ */
25
+ make(data) {
26
+ const payload = this._template.schema
27
+ ? this._template.schema.parse(data)
28
+ : data;
29
+ return {
30
+ type: this._template.type,
31
+ exchange: this._template.exchange,
32
+ durable: this._template.durable,
33
+ routingKey: this._template.routingKey,
34
+ ttlMs: this._template.ttlMs,
35
+ message: payload
36
+ };
37
+ }
38
+ }
39
+ exports.RabbitmqMessage = RabbitmqMessage;
@@ -181,9 +181,10 @@ class Rabbitmq {
181
181
  * @param {RabbitmqPublishOptions} options
182
182
  * @return {Promise<void>}
183
183
  */
184
- publish(options) {
184
+ async publish(options) {
185
185
  if (!this.publisher)
186
186
  this.publisher = this.connection.createPublisher();
187
+ await this.declareExchange(options.exchange);
187
188
  return this.publisher.send({
188
189
  exchange: options.exchange.name,
189
190
  routingKey: options.routingKey,
@@ -1,4 +1,5 @@
1
1
  export { Rabbitmq, type RabbitmqConstructorParams, type RabbitmqResponse, type RabbitmqSubscribeParams, type RabbitmqMessageValidation, type RabbitmqSubscriberFunction, type RabbitmqPublishOptions, type RabbitmqQueueStats } from './rabbitmq';
2
2
  export { RabbitmqExchange, type RabbitmqExchangeType, type RabbitmqExchangeDeclaration } from './rabbitmq-exchange';
3
3
  export { RabbitmqQueue, type RabbitmqQueueArguments, type RabbitmqQueueBinding, type RabbitmqQueueDeclaration } from './rabbitmq-queue';
4
+ export { RabbitmqMessage, type RabbitmqMessageType, type RabbitmqMessageTemplate } from './rabbitmq-message';
4
5
  export { RabbitmqSubscriber } from './rabbitmq-subscriber';
@@ -0,0 +1,34 @@
1
+ import { z } from 'zod';
2
+ import { type RabbitmqPublishOptions } from './rabbitmq';
3
+ import { RabbitmqExchange } from './rabbitmq-exchange';
4
+ import { Jsonifiable } from 'type-fest';
5
+ export type RabbitmqMessageType = 'raw' | 'json';
6
+ export type RabbitmqMessageTemplate = {
7
+ type: RabbitmqMessageType;
8
+ exchange: RabbitmqExchange;
9
+ durable: boolean;
10
+ routingKey: string;
11
+ schema?: z.ZodTypeAny;
12
+ ttlMs?: number;
13
+ };
14
+ type InputData<T extends RabbitmqMessageTemplate> = T['schema'] extends z.ZodTypeAny ? z.input<T['schema']> : T['type'] extends 'json' ? Jsonifiable : any;
15
+ export declare class RabbitmqMessage<T extends RabbitmqMessageTemplate> {
16
+ private readonly _template;
17
+ /**
18
+ * @param {T} template
19
+ * @return {RabbitmqMessageTemplate<T>}
20
+ */
21
+ static template<T extends RabbitmqMessageTemplate>(template: T): RabbitmqMessage<T>;
22
+ /**
23
+ * @template {RabbitmqMessageTemplate} T
24
+ * @param {T} template
25
+ * @protected
26
+ */
27
+ protected constructor(template: T);
28
+ /**
29
+ * @param {InputData<T>} data
30
+ * @return {RabbitmqPublishOptions}
31
+ */
32
+ make(data: InputData<T>): RabbitmqPublishOptions;
33
+ }
34
+ export {};
@@ -32,7 +32,21 @@ export type RabbitmqSubscribeParams = {
32
32
  queue: RabbitmqQueue;
33
33
  requeue?: boolean;
34
34
  concurrency?: number;
35
+ /** The client can request that messages be sent in advance so that when
36
+ * the client finishes processing a message, the following message is
37
+ * already held locally, rather than needing to be sent down the channel.
38
+ * Prefetching gives a performance improvement. This field specifies the
39
+ * prefetch window size in octets. The server will send a message in
40
+ * advance if it is equal to or smaller in size than the available prefetch
41
+ * size (and also falls into other prefetch limits). May be set to zero,
42
+ * meaning "no specific limit", although other prefetch limits may still
43
+ * apply. The prefetch-size is ignored if the no-ack option is set. */
35
44
  prefetchSize?: number;
45
+ /** Specifies a prefetch window in terms of whole messages. This field may
46
+ * be used in combination with the prefetch-size field; a message will only
47
+ * be sent in advance if both prefetch windows (and those at the channel
48
+ * and connection level) allow it. The prefetch-count is ignored if the
49
+ * no-ack option is set. */
36
50
  prefetchCount?: number;
37
51
  validation?: RabbitmqMessageValidation;
38
52
  autoStart?: boolean;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@jsnw/nestjs-rabbitmq",
3
- "version": "1.2.1",
3
+ "version": "1.3.0",
4
4
  "description": "NestJS module for RabbitMQ integration with decorator-based consumers, message validation, and dead-letter exchange support",
5
5
  "main": "./dist/index.js",
6
6
  "types": "./dist/types/index.d.ts",