@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.
- package/dist/rabbitmq/index.js +3 -1
- package/dist/rabbitmq/rabbitmq-message.js +39 -0
- package/dist/rabbitmq/rabbitmq.js +2 -1
- package/dist/types/rabbitmq/index.d.ts +1 -0
- package/dist/types/rabbitmq/rabbitmq-message.d.ts +34 -0
- package/dist/types/rabbitmq/rabbitmq.d.ts +14 -0
- package/package.json +1 -1
package/dist/rabbitmq/index.js
CHANGED
|
@@ -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.
|
|
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",
|