@diia-inhouse/diia-queue 7.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/LICENCE.md +287 -0
- package/README.md +93 -0
- package/dist/constants.js +7 -0
- package/dist/constants.js.map +1 -0
- package/dist/index.js +19 -0
- package/dist/index.js.map +1 -0
- package/dist/interfaces/deps.js +3 -0
- package/dist/interfaces/deps.js.map +1 -0
- package/dist/interfaces/externalCommunicator.js +3 -0
- package/dist/interfaces/externalCommunicator.js.map +1 -0
- package/dist/interfaces/index.js +27 -0
- package/dist/interfaces/index.js.map +1 -0
- package/dist/interfaces/metrics/index.js +3 -0
- package/dist/interfaces/metrics/index.js.map +1 -0
- package/dist/interfaces/providers/rabbitmq/amqpConnection.js +14 -0
- package/dist/interfaces/providers/rabbitmq/amqpConnection.js.map +1 -0
- package/dist/interfaces/providers/rabbitmq/amqpListener.js +3 -0
- package/dist/interfaces/providers/rabbitmq/amqpListener.js.map +1 -0
- package/dist/interfaces/providers/rabbitmq/amqpPublisher.js +12 -0
- package/dist/interfaces/providers/rabbitmq/amqpPublisher.js.map +1 -0
- package/dist/interfaces/providers/rabbitmq/index.js +25 -0
- package/dist/interfaces/providers/rabbitmq/index.js.map +1 -0
- package/dist/interfaces/queueConfig/configs.js +9 -0
- package/dist/interfaces/queueConfig/configs.js.map +1 -0
- package/dist/interfaces/queueConfig/index.js +18 -0
- package/dist/interfaces/queueConfig/index.js.map +1 -0
- package/dist/interfaces/queueStatus.js +3 -0
- package/dist/interfaces/queueStatus.js.map +1 -0
- package/dist/metrics/index.js +9 -0
- package/dist/metrics/index.js.map +1 -0
- package/dist/providers/rabbitmq/amqpConnection.js +129 -0
- package/dist/providers/rabbitmq/amqpConnection.js.map +1 -0
- package/dist/providers/rabbitmq/amqpListener.js +171 -0
- package/dist/providers/rabbitmq/amqpListener.js.map +1 -0
- package/dist/providers/rabbitmq/amqpPublisher.js +140 -0
- package/dist/providers/rabbitmq/amqpPublisher.js.map +1 -0
- package/dist/providers/rabbitmq/index.js +367 -0
- package/dist/providers/rabbitmq/index.js.map +1 -0
- package/dist/services/eventBus.js +63 -0
- package/dist/services/eventBus.js.map +1 -0
- package/dist/services/eventMessageHandler.js +145 -0
- package/dist/services/eventMessageHandler.js.map +1 -0
- package/dist/services/eventMessageValidator.js +44 -0
- package/dist/services/eventMessageValidator.js.map +1 -0
- package/dist/services/externalCommunicator.js +134 -0
- package/dist/services/externalCommunicator.js.map +1 -0
- package/dist/services/externalCommunicatorChannel.js +31 -0
- package/dist/services/externalCommunicatorChannel.js.map +1 -0
- package/dist/services/externalEventBus.js +71 -0
- package/dist/services/externalEventBus.js.map +1 -0
- package/dist/services/index.js +26 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/queue.js +56 -0
- package/dist/services/queue.js.map +1 -0
- package/dist/services/scheduledTask.js +65 -0
- package/dist/services/scheduledTask.js.map +1 -0
- package/dist/services/task.js +56 -0
- package/dist/services/task.js.map +1 -0
- package/dist/types/constants.d.ts +5 -0
- package/dist/types/index.d.ts +3 -0
- package/dist/types/interfaces/deps.d.ts +17 -0
- package/dist/types/interfaces/externalCommunicator.d.ts +35 -0
- package/dist/types/interfaces/index.d.ts +89 -0
- package/dist/types/interfaces/metrics/index.d.ts +7 -0
- package/dist/types/interfaces/providers/rabbitmq/amqpConnection.d.ts +26 -0
- package/dist/types/interfaces/providers/rabbitmq/amqpListener.d.ts +7 -0
- package/dist/types/interfaces/providers/rabbitmq/amqpPublisher.d.ts +24 -0
- package/dist/types/interfaces/providers/rabbitmq/index.d.ts +50 -0
- package/dist/types/interfaces/queueConfig/configs.d.ts +39 -0
- package/dist/types/interfaces/queueConfig/index.d.ts +1 -0
- package/dist/types/interfaces/queueStatus.d.ts +6 -0
- package/dist/types/metrics/index.d.ts +4 -0
- package/dist/types/providers/rabbitmq/amqpConnection.d.ts +24 -0
- package/dist/types/providers/rabbitmq/amqpListener.d.ts +26 -0
- package/dist/types/providers/rabbitmq/amqpPublisher.d.ts +25 -0
- package/dist/types/providers/rabbitmq/index.d.ts +55 -0
- package/dist/types/services/eventBus.d.ts +16 -0
- package/dist/types/services/eventMessageHandler.d.ts +21 -0
- package/dist/types/services/eventMessageValidator.d.ts +9 -0
- package/dist/types/services/externalCommunicator.d.ts +24 -0
- package/dist/types/services/externalCommunicatorChannel.d.ts +11 -0
- package/dist/types/services/externalEventBus.d.ts +18 -0
- package/dist/types/services/index.d.ts +9 -0
- package/dist/types/services/queue.d.ts +18 -0
- package/dist/types/services/scheduledTask.d.ts +17 -0
- package/dist/types/services/task.d.ts +18 -0
- package/dist/types/utils.d.ts +3 -0
- package/dist/utils.js +12 -0
- package/dist/utils.js.map +1 -0
- package/package.json +105 -0
|
@@ -0,0 +1,367 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.RabbitMQProvider = void 0;
|
|
7
|
+
const node_events_1 = require("node:events");
|
|
8
|
+
const lodash_1 = require("lodash");
|
|
9
|
+
const p_timeout_1 = __importDefault(require("p-timeout"));
|
|
10
|
+
const uuid_1 = require("uuid");
|
|
11
|
+
const interfaces_1 = require("../../interfaces");
|
|
12
|
+
const queueConfig_1 = require("../../interfaces/queueConfig");
|
|
13
|
+
const amqpConnection_1 = require("./amqpConnection");
|
|
14
|
+
const amqpListener_1 = require("./amqpListener");
|
|
15
|
+
const amqpPublisher_1 = require("./amqpPublisher");
|
|
16
|
+
// eslint-disable-next-line unicorn/prefer-event-target
|
|
17
|
+
class RabbitMQProvider extends node_events_1.EventEmitter {
|
|
18
|
+
serviceName;
|
|
19
|
+
rabbitmqConfig;
|
|
20
|
+
serviceConfig;
|
|
21
|
+
topicsConfig;
|
|
22
|
+
portalEvents;
|
|
23
|
+
internalEvents;
|
|
24
|
+
type;
|
|
25
|
+
logger;
|
|
26
|
+
asyncLocalStorage;
|
|
27
|
+
queuesConfig;
|
|
28
|
+
initializingLock;
|
|
29
|
+
listener;
|
|
30
|
+
publisher;
|
|
31
|
+
connectionList = {
|
|
32
|
+
[interfaces_1.ConnectionClientType.Listener]: {},
|
|
33
|
+
[interfaces_1.ConnectionClientType.Publisher]: {},
|
|
34
|
+
};
|
|
35
|
+
projectName = 'diia';
|
|
36
|
+
portalName = 'portal';
|
|
37
|
+
eventNameToTopicMap = new Map();
|
|
38
|
+
externalPublishEventsSet;
|
|
39
|
+
externalSubscribeEventsSet;
|
|
40
|
+
assertExternalExchanges;
|
|
41
|
+
constructor(serviceName, rabbitmqConfig, serviceConfig, topicsConfig, portalEvents, internalEvents, type, logger, asyncLocalStorage, queuesConfig) {
|
|
42
|
+
super();
|
|
43
|
+
this.serviceName = serviceName;
|
|
44
|
+
this.rabbitmqConfig = rabbitmqConfig;
|
|
45
|
+
this.serviceConfig = serviceConfig;
|
|
46
|
+
this.topicsConfig = topicsConfig;
|
|
47
|
+
this.portalEvents = portalEvents;
|
|
48
|
+
this.internalEvents = internalEvents;
|
|
49
|
+
this.type = type;
|
|
50
|
+
this.logger = logger;
|
|
51
|
+
this.asyncLocalStorage = asyncLocalStorage;
|
|
52
|
+
this.queuesConfig = queuesConfig;
|
|
53
|
+
for (const topicName of Object.keys(this.topicsConfig)) {
|
|
54
|
+
for (const eventName of this.topicsConfig[topicName].events) {
|
|
55
|
+
this.eventNameToTopicMap.set(eventName, topicName);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
if (this.type === queueConfig_1.QueueConfigType.External) {
|
|
59
|
+
const config = this.serviceConfig;
|
|
60
|
+
this.externalPublishEventsSet = new Set(config?.publish);
|
|
61
|
+
this.externalSubscribeEventsSet = new Set(config?.subscribe);
|
|
62
|
+
this.assertExternalExchanges = rabbitmqConfig.assertExchanges;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
getServiceName() {
|
|
66
|
+
return this.serviceName;
|
|
67
|
+
}
|
|
68
|
+
getConfig() {
|
|
69
|
+
return this.rabbitmqConfig;
|
|
70
|
+
}
|
|
71
|
+
async init(listenerOptions) {
|
|
72
|
+
if (this.initializingLock) {
|
|
73
|
+
return await this.initializingLock;
|
|
74
|
+
}
|
|
75
|
+
this.initializingLock = new Promise((resolve) => Promise.all([this.setListener(listenerOptions), this.setPublisher()]).then(() => resolve()));
|
|
76
|
+
await this.initializingLock;
|
|
77
|
+
this.emit('initialized');
|
|
78
|
+
}
|
|
79
|
+
async subscribe(subscriptionName, messageHandler, options) {
|
|
80
|
+
if (!this.serviceConfig.subscribe?.includes(subscriptionName)) {
|
|
81
|
+
this.logger.error(`Subscription [${subscriptionName}] is not related to the service [${this.serviceName}]`);
|
|
82
|
+
return false;
|
|
83
|
+
}
|
|
84
|
+
const queueName = this.makeQueueName(subscriptionName, options);
|
|
85
|
+
await this.init(options?.listener);
|
|
86
|
+
await this.listener.listenQueue(queueName, messageHandler);
|
|
87
|
+
if ((0, lodash_1.isEmpty)(this.queuesConfig[subscriptionName].topics)) {
|
|
88
|
+
this.logger.info(`Can't find topics for subscription [${subscriptionName}]`);
|
|
89
|
+
return true;
|
|
90
|
+
}
|
|
91
|
+
const routingKey = options ? options.routingKey : undefined;
|
|
92
|
+
await Promise.all(this.queuesConfig[subscriptionName].topics.map((topic) => this.checkAndBindToExchange(topic, queueName, routingKey)));
|
|
93
|
+
return true;
|
|
94
|
+
}
|
|
95
|
+
async publish(eventName, message, options) {
|
|
96
|
+
if (!this.internalEvents.includes(eventName)) {
|
|
97
|
+
this.logger.error(`Event [${eventName}] is not implemented`);
|
|
98
|
+
return false;
|
|
99
|
+
}
|
|
100
|
+
const exchangeName = this.findTopicNameByEventName(eventName);
|
|
101
|
+
if (!exchangeName) {
|
|
102
|
+
this.logger.error(`Can't find topic name by event [${eventName}]`);
|
|
103
|
+
return false;
|
|
104
|
+
}
|
|
105
|
+
if (!this.serviceConfig.publish?.includes(exchangeName)) {
|
|
106
|
+
this.logger.error(`Event [${eventName}] is not allowed to publish by service [${this.serviceName}]`);
|
|
107
|
+
return false;
|
|
108
|
+
}
|
|
109
|
+
const { publishTimeout = Infinity, throwOnPublishTimeout = true, routingKey } = options || {};
|
|
110
|
+
// eslint-disable-next-line no-async-promise-executor
|
|
111
|
+
const publishTask = new Promise(async (resolve, reject) => {
|
|
112
|
+
try {
|
|
113
|
+
await this.init();
|
|
114
|
+
}
|
|
115
|
+
catch (err) {
|
|
116
|
+
return reject(err);
|
|
117
|
+
}
|
|
118
|
+
try {
|
|
119
|
+
await this.publisher.checkExchange(exchangeName);
|
|
120
|
+
}
|
|
121
|
+
catch {
|
|
122
|
+
return resolve(false);
|
|
123
|
+
}
|
|
124
|
+
try {
|
|
125
|
+
const publishResult = await this.publisher.publishToExchange({
|
|
126
|
+
eventName,
|
|
127
|
+
message,
|
|
128
|
+
exchangeName,
|
|
129
|
+
routingKey,
|
|
130
|
+
headers: this.preparePublisherHeaders(),
|
|
131
|
+
});
|
|
132
|
+
return resolve(publishResult);
|
|
133
|
+
}
|
|
134
|
+
catch (err) {
|
|
135
|
+
return reject(err);
|
|
136
|
+
}
|
|
137
|
+
});
|
|
138
|
+
const timeoutMsg = `Internal event [${eventName}] publish timeout exceed`;
|
|
139
|
+
if (throwOnPublishTimeout) {
|
|
140
|
+
return await (0, p_timeout_1.default)(publishTask, publishTimeout, timeoutMsg);
|
|
141
|
+
}
|
|
142
|
+
return await (0, p_timeout_1.default)(publishTask, publishTimeout, () => {
|
|
143
|
+
this.logger.error(timeoutMsg, { publishTimeout });
|
|
144
|
+
return false;
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
async subscribeTask(queueName, messageHandler, options = {}) {
|
|
148
|
+
const { listener, delayed } = options;
|
|
149
|
+
this.logger.info('Subscribing to the task', { queueName, options });
|
|
150
|
+
await this.init(listener);
|
|
151
|
+
await this.listener.listenQueue(queueName, messageHandler);
|
|
152
|
+
await (delayed
|
|
153
|
+
? this.publisher.checkExchange(queueName, interfaces_1.ExchangeType.XDelayedMessage, {
|
|
154
|
+
arguments: { 'x-delayed-type': this.publisher.defaultExchangeType },
|
|
155
|
+
})
|
|
156
|
+
: this.publisher.checkExchange(queueName));
|
|
157
|
+
await this.listener.bindQueueToExchange(queueName, queueName);
|
|
158
|
+
return true;
|
|
159
|
+
}
|
|
160
|
+
async publishTask(queueName, message, delay) {
|
|
161
|
+
await this.init();
|
|
162
|
+
const params = {
|
|
163
|
+
eventName: queueName,
|
|
164
|
+
message,
|
|
165
|
+
exchangeName: queueName,
|
|
166
|
+
headers: this.preparePublisherHeaders(),
|
|
167
|
+
};
|
|
168
|
+
if (delay) {
|
|
169
|
+
params.headers['x-delay'] = delay;
|
|
170
|
+
}
|
|
171
|
+
return await this.publisher.publishToExchange(params);
|
|
172
|
+
}
|
|
173
|
+
async subscribeExternal(messageHandler, options) {
|
|
174
|
+
await this.init(options.listener);
|
|
175
|
+
const config = this.serviceConfig;
|
|
176
|
+
const publishEvents = config?.publish || [];
|
|
177
|
+
const subscribeEvents = config?.subscribe || [];
|
|
178
|
+
if (publishEvents.length === 0 && subscribeEvents.length === 0) {
|
|
179
|
+
this.logger.info('No one external events to listen');
|
|
180
|
+
return;
|
|
181
|
+
}
|
|
182
|
+
const responseRoutingKeyPrefix = this.rabbitmqConfig.custom?.responseRoutingKeyPrefix;
|
|
183
|
+
const queueByEvent = new Map();
|
|
184
|
+
for (const externalEvent of publishEvents) {
|
|
185
|
+
queueByEvent.set(externalEvent, this.makeExternalResQueueName(externalEvent, responseRoutingKeyPrefix));
|
|
186
|
+
}
|
|
187
|
+
for (const externalEvent of subscribeEvents) {
|
|
188
|
+
queueByEvent.set(externalEvent, this.makeExternalReqQueueName(externalEvent, responseRoutingKeyPrefix));
|
|
189
|
+
}
|
|
190
|
+
const bindTasks = [...queueByEvent.entries()].map(([event, queueName]) => this.bindQueueToExternalExchange(queueName, event, messageHandler));
|
|
191
|
+
await Promise.all(bindTasks);
|
|
192
|
+
return true;
|
|
193
|
+
}
|
|
194
|
+
async publishExternalDirect(eventName, message, topic, options) {
|
|
195
|
+
await this.init();
|
|
196
|
+
const selectedTopic = topic ?? this.findTopicNameByEventName(eventName) ?? 'DirectRPC';
|
|
197
|
+
const exchangeName = this.prepareExternalTopicName(selectedTopic);
|
|
198
|
+
const routingKey = this.prepareExternalReqRoutingKey(eventName);
|
|
199
|
+
const headers = this.preparePublisherHeaders();
|
|
200
|
+
return await this.publisher.publishToExchangeDirect({
|
|
201
|
+
eventName,
|
|
202
|
+
message,
|
|
203
|
+
exchangeName,
|
|
204
|
+
routingKey,
|
|
205
|
+
headers,
|
|
206
|
+
options,
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
async publishExternal(eventName, message, options) {
|
|
210
|
+
const topicName = this.findTopicNameByEventName(eventName);
|
|
211
|
+
if (!topicName) {
|
|
212
|
+
this.logger.error(`Can't find external topic name for service [${this.serviceName}] and event [${eventName}]`);
|
|
213
|
+
return false;
|
|
214
|
+
}
|
|
215
|
+
const { publishTimeout = Infinity, throwOnPublishTimeout = true } = options || {};
|
|
216
|
+
// eslint-disable-next-line no-async-promise-executor
|
|
217
|
+
const publishTask = new Promise(async (resolve, reject) => {
|
|
218
|
+
try {
|
|
219
|
+
await this.init();
|
|
220
|
+
}
|
|
221
|
+
catch (err) {
|
|
222
|
+
return reject(err);
|
|
223
|
+
}
|
|
224
|
+
const headers = this.preparePublisherHeaders();
|
|
225
|
+
const exchangeName = this.prepareExternalTopicName(topicName);
|
|
226
|
+
const publishToExchangeParams = {
|
|
227
|
+
eventName,
|
|
228
|
+
message,
|
|
229
|
+
exchangeName,
|
|
230
|
+
headers,
|
|
231
|
+
options,
|
|
232
|
+
};
|
|
233
|
+
if (this.externalPublishEventsSet.has(eventName)) {
|
|
234
|
+
const { responseRoutingKeyPrefix } = this.rabbitmqConfig.custom || {};
|
|
235
|
+
publishToExchangeParams.routingKey = this.prepareExternalReqRoutingKey(eventName);
|
|
236
|
+
publishToExchangeParams.responseRoutingKey =
|
|
237
|
+
responseRoutingKeyPrefix && this.makeExternalResQueueName(eventName, responseRoutingKeyPrefix);
|
|
238
|
+
}
|
|
239
|
+
else if (this.externalSubscribeEventsSet.has(eventName)) {
|
|
240
|
+
publishToExchangeParams.routingKey = this.prepareExternalResRoutingKey(eventName);
|
|
241
|
+
}
|
|
242
|
+
else {
|
|
243
|
+
this.logger.error(`Can't find event in service config: [${eventName}]`);
|
|
244
|
+
return resolve(false);
|
|
245
|
+
}
|
|
246
|
+
try {
|
|
247
|
+
const publishResult = await this.publisher.publishToExchange(publishToExchangeParams);
|
|
248
|
+
return resolve(publishResult);
|
|
249
|
+
}
|
|
250
|
+
catch (err) {
|
|
251
|
+
return reject(err);
|
|
252
|
+
}
|
|
253
|
+
});
|
|
254
|
+
const timeoutMsg = `External event [${eventName}] publish timeout exceed`;
|
|
255
|
+
if (throwOnPublishTimeout) {
|
|
256
|
+
return await (0, p_timeout_1.default)(publishTask, publishTimeout, timeoutMsg);
|
|
257
|
+
}
|
|
258
|
+
return await (0, p_timeout_1.default)(publishTask, publishTimeout, () => {
|
|
259
|
+
this.logger.error(timeoutMsg, { publishTimeout });
|
|
260
|
+
return false;
|
|
261
|
+
});
|
|
262
|
+
}
|
|
263
|
+
getStatus() {
|
|
264
|
+
return {
|
|
265
|
+
listener: this.listener?.getStatus() || interfaces_1.ConnectionStatus.Down,
|
|
266
|
+
publisher: this.publisher?.getStatus() || interfaces_1.ConnectionStatus.Down,
|
|
267
|
+
};
|
|
268
|
+
}
|
|
269
|
+
preparePublisherHeaders() {
|
|
270
|
+
const logData = this.asyncLocalStorage?.getStore()?.logData ?? {};
|
|
271
|
+
const traceId = logData?.traceId ?? (0, uuid_1.v4)();
|
|
272
|
+
const serviceCode = logData?.serviceCode;
|
|
273
|
+
return { traceId, serviceCode };
|
|
274
|
+
}
|
|
275
|
+
findTopicNameByEventName(eventName) {
|
|
276
|
+
return this.eventNameToTopicMap.get(eventName);
|
|
277
|
+
}
|
|
278
|
+
async setListener(options = {}) {
|
|
279
|
+
options.queueOptions ??= this.rabbitmqConfig.listenerOptions?.queueOptions;
|
|
280
|
+
if (!this.listener) {
|
|
281
|
+
const connection = await this.getConnection(interfaces_1.ConnectionClientType.Listener);
|
|
282
|
+
this.listener = new amqpListener_1.AmqpListener(connection, this.logger, options);
|
|
283
|
+
await this.listener.init();
|
|
284
|
+
}
|
|
285
|
+
return this.listener;
|
|
286
|
+
}
|
|
287
|
+
async setPublisher() {
|
|
288
|
+
if (!this.publisher) {
|
|
289
|
+
const connection = await this.getConnection(interfaces_1.ConnectionClientType.Publisher);
|
|
290
|
+
this.publisher = new amqpPublisher_1.AmqpPublisher(connection, this.logger);
|
|
291
|
+
await this.publisher.init();
|
|
292
|
+
}
|
|
293
|
+
return this.publisher;
|
|
294
|
+
}
|
|
295
|
+
async getConnection(client) {
|
|
296
|
+
if (this.connectionList[client].lock) {
|
|
297
|
+
return await this.connectionList[client].lock;
|
|
298
|
+
}
|
|
299
|
+
const connection = new amqpConnection_1.AmqpConnection(this.rabbitmqConfig.connection, this.logger, this.rabbitmqConfig.reconnectOptions, (0, lodash_1.merge)({
|
|
300
|
+
clientProperties: {
|
|
301
|
+
connectionClientType: client,
|
|
302
|
+
},
|
|
303
|
+
}, this.rabbitmqConfig.socketOptions));
|
|
304
|
+
this.connectionList[client].lock = new Promise((resolve) => connection.connect().then(() => resolve(connection)));
|
|
305
|
+
return await this.connectionList[client].lock;
|
|
306
|
+
}
|
|
307
|
+
async checkAndBindToExchange(topic, queueName, routingKey) {
|
|
308
|
+
// eslint-disable-next-line no-async-promise-executor
|
|
309
|
+
return await new Promise(async (resolve) => {
|
|
310
|
+
// queue can't be bind to exchange when no exchange
|
|
311
|
+
await this.publisher.checkExchange(topic);
|
|
312
|
+
await this.listener.bindQueueToExchange(queueName, topic, routingKey);
|
|
313
|
+
return resolve();
|
|
314
|
+
});
|
|
315
|
+
}
|
|
316
|
+
async bindQueueToExternalExchange(queueName, eventName, messageHandler) {
|
|
317
|
+
const topicName = this.findTopicNameByEventName(eventName);
|
|
318
|
+
if (!topicName) {
|
|
319
|
+
this.logger.error(`Can't find external topic name for service [${this.serviceName}] and event [${eventName}]`);
|
|
320
|
+
return;
|
|
321
|
+
}
|
|
322
|
+
const externalTopicName = this.prepareExternalTopicName(topicName);
|
|
323
|
+
if (this.assertExternalExchanges) {
|
|
324
|
+
await this.publisher.checkExchange(externalTopicName);
|
|
325
|
+
}
|
|
326
|
+
await this.listener.listenQueue(queueName, messageHandler);
|
|
327
|
+
await this.listener.bindQueueToExchange(queueName, externalTopicName, queueName);
|
|
328
|
+
}
|
|
329
|
+
makeQueueName(subscriptionName, options) {
|
|
330
|
+
let queueName = subscriptionName;
|
|
331
|
+
if (options && options.queueSuffix) {
|
|
332
|
+
queueName = `${subscriptionName}_${options.queueSuffix}`;
|
|
333
|
+
}
|
|
334
|
+
return queueName;
|
|
335
|
+
}
|
|
336
|
+
makeExternalResQueueName(eventName, prefix) {
|
|
337
|
+
const result = `queue.${this.projectName}.${eventName}.res`;
|
|
338
|
+
if (prefix) {
|
|
339
|
+
return `${prefix}.${result}`;
|
|
340
|
+
}
|
|
341
|
+
return result;
|
|
342
|
+
}
|
|
343
|
+
makeExternalReqQueueName(eventName, prefix) {
|
|
344
|
+
const result = `${this.prepareExternalQueuePrefix(eventName)}.${eventName}.req`;
|
|
345
|
+
if (prefix) {
|
|
346
|
+
return `${prefix}.${result}`;
|
|
347
|
+
}
|
|
348
|
+
return result;
|
|
349
|
+
}
|
|
350
|
+
prepareExternalTopicName(topicName) {
|
|
351
|
+
return `TopicExternal${topicName}`;
|
|
352
|
+
}
|
|
353
|
+
prepareExternalReqRoutingKey(eventName) {
|
|
354
|
+
return `queue.${this.projectName}.${eventName}.req`;
|
|
355
|
+
}
|
|
356
|
+
prepareExternalResRoutingKey(eventName) {
|
|
357
|
+
return `${this.prepareExternalQueuePrefix(eventName)}.${eventName}.res`;
|
|
358
|
+
}
|
|
359
|
+
prepareExternalQueuePrefix(event) {
|
|
360
|
+
if (this.portalEvents.includes(event)) {
|
|
361
|
+
return `queue.${this.portalName}`;
|
|
362
|
+
}
|
|
363
|
+
return `queue.${this.projectName}`;
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
exports.RabbitMQProvider = RabbitMQProvider;
|
|
367
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/providers/rabbitmq/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.EventBus = void 0;
|
|
27
|
+
const Utils = __importStar(require("../utils"));
|
|
28
|
+
class EventBus {
|
|
29
|
+
queueProvider;
|
|
30
|
+
eventListenerList;
|
|
31
|
+
eventMessageHandler;
|
|
32
|
+
logger;
|
|
33
|
+
queueName;
|
|
34
|
+
constructor(queueProvider, eventListenerList, eventMessageHandler, logger, queueName) {
|
|
35
|
+
this.queueProvider = queueProvider;
|
|
36
|
+
this.eventListenerList = eventListenerList;
|
|
37
|
+
this.eventMessageHandler = eventMessageHandler;
|
|
38
|
+
this.logger = logger;
|
|
39
|
+
this.queueName = queueName;
|
|
40
|
+
}
|
|
41
|
+
async onInit() {
|
|
42
|
+
await this.queueProvider.init?.();
|
|
43
|
+
if (!this.queueName) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
const config = this.queueProvider.getConfig();
|
|
47
|
+
const eventListeners = Utils.collectEventBusListeners(this.eventListenerList);
|
|
48
|
+
await this.subscribe(this.queueName, this.eventMessageHandler.eventListenersMessageHandler.bind(this.eventMessageHandler, eventListeners), {
|
|
49
|
+
listener: config.listenerOptions,
|
|
50
|
+
});
|
|
51
|
+
for (const listener of this.eventListenerList) {
|
|
52
|
+
this.logger.info(`Event listener [${listener.event}] initialized successfully`);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
async subscribe(subscriptionName, messageHandler, options) {
|
|
56
|
+
return await this.queueProvider.subscribe(subscriptionName, messageHandler, options);
|
|
57
|
+
}
|
|
58
|
+
async publish(eventName, message, options) {
|
|
59
|
+
return await this.queueProvider.publish(eventName, message, options);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
exports.EventBus = EventBus;
|
|
63
|
+
//# sourceMappingURL=eventBus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"eventBus.js","sourceRoot":"","sources":["../../src/services/eventBus.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAYA,gDAAiC;AAIjC,MAAa,QAAQ;IAEI;IACA;IACA;IAEA;IACA;IANrB,YACqB,aAA+B,EAC/B,iBAAqC,EACrC,mBAAwC,EAExC,MAAc,EACd,SAAgC;QALhC,kBAAa,GAAb,aAAa,CAAkB;QAC/B,sBAAiB,GAAjB,iBAAiB,CAAoB;QACrC,wBAAmB,GAAnB,mBAAmB,CAAqB;QAExC,WAAM,GAAN,MAAM,CAAQ;QACd,cAAS,GAAT,SAAS,CAAuB;IAClD,CAAC;IAEJ,KAAK,CAAC,MAAM;QACR,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,EAAE,CAAA;QACjC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACjB,OAAM;SACT;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAA;QAC7C,MAAM,cAAc,GAAG,KAAK,CAAC,wBAAwB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAA;QAE7E,MAAM,IAAI,CAAC,SAAS,CAChB,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,mBAAmB,CAAC,4BAA4B,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,cAAc,CAAC,EACpG;YACI,QAAQ,EAAE,MAAM,CAAC,eAAe;SACnC,CACJ,CAAA;QAED,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC3C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,QAAQ,CAAC,KAAK,4BAA4B,CAAC,CAAA;SAClF;IACL,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,gBAA2B,EAAE,cAA8B,EAAE,OAA0B;QACnG,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,gBAAgB,EAAE,cAAc,EAAE,OAAO,CAAC,CAAA;IACxF,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,SAAoB,EAAE,OAAuB,EAAE,OAAqC;QAC9F,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC,CAAA;IACxE,CAAC;CACJ;AAvCD,4BAuCC"}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EventMessageHandler = void 0;
|
|
4
|
+
const api_1 = require("@opentelemetry/api");
|
|
5
|
+
const uuid_1 = require("uuid");
|
|
6
|
+
const errors_1 = require("@diia-inhouse/errors");
|
|
7
|
+
const utils_1 = require("@diia-inhouse/utils");
|
|
8
|
+
const metrics_1 = require("../metrics");
|
|
9
|
+
class EventMessageHandler {
|
|
10
|
+
eventMessageValidator;
|
|
11
|
+
externalChannel;
|
|
12
|
+
pubsub;
|
|
13
|
+
asyncLocalStorage;
|
|
14
|
+
logger;
|
|
15
|
+
constructor(eventMessageValidator, externalChannel, pubsub, asyncLocalStorage, logger) {
|
|
16
|
+
this.eventMessageValidator = eventMessageValidator;
|
|
17
|
+
this.externalChannel = externalChannel;
|
|
18
|
+
this.pubsub = pubsub;
|
|
19
|
+
this.asyncLocalStorage = asyncLocalStorage;
|
|
20
|
+
this.logger = logger;
|
|
21
|
+
}
|
|
22
|
+
async eventListenersMessageHandler(eventListeners, message) {
|
|
23
|
+
if (!message) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
const listener = eventListeners[message.data.event];
|
|
27
|
+
await this.eventListenerMessageHandler(listener, message);
|
|
28
|
+
}
|
|
29
|
+
async eventListenerMessageHandler(listener, message) {
|
|
30
|
+
const payloadValidationSchema = listener?.validationRules || {};
|
|
31
|
+
const { done, data, properties } = message;
|
|
32
|
+
const { event, payload, meta } = data;
|
|
33
|
+
const activeSpanTraceId = api_1.trace.getActiveSpan()?.spanContext().traceId;
|
|
34
|
+
const traceId = (0, api_1.isValidTraceId)(activeSpanTraceId) ? activeSpanTraceId : properties.headers?.traceId || (0, uuid_1.v4)();
|
|
35
|
+
const context = {
|
|
36
|
+
logData: {
|
|
37
|
+
traceId,
|
|
38
|
+
serviceCode: this.getServiceCode(listener, payload),
|
|
39
|
+
},
|
|
40
|
+
};
|
|
41
|
+
await this.asyncLocalStorage.run(context, async () => {
|
|
42
|
+
this.logger.io(`Handling event [${event}] with payload`, { payload });
|
|
43
|
+
if (!listener) {
|
|
44
|
+
this.logger.info(`No listener for the event [${event}]`);
|
|
45
|
+
return done();
|
|
46
|
+
}
|
|
47
|
+
if ('isSync' in listener && listener.isSync) {
|
|
48
|
+
return await this.syncMessageHandler(listener, message, payloadValidationSchema);
|
|
49
|
+
}
|
|
50
|
+
try {
|
|
51
|
+
this.eventMessageValidator.validateEventMessage(data, payloadValidationSchema);
|
|
52
|
+
const resp = await listener.handler?.(payload, meta);
|
|
53
|
+
return this.performDone(message, resp, false);
|
|
54
|
+
}
|
|
55
|
+
catch (err) {
|
|
56
|
+
if (err instanceof errors_1.ValidationError && 'validationErrorHandler' in listener && payload?.uuid) {
|
|
57
|
+
await listener.validationErrorHandler?.(err, payload.uuid).catch((err_) => err_);
|
|
58
|
+
}
|
|
59
|
+
this.logger.error(`Failed to handle event ${event}`, { err });
|
|
60
|
+
metrics_1.totalMessageHandlerErrorsMetrics.increment({ event });
|
|
61
|
+
// TODO(BACK-0): message.reject();
|
|
62
|
+
return this.performDone(message, err, true);
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
async syncMessageHandler(listener, message, payloadValidationSchema) {
|
|
67
|
+
const { done, data } = message;
|
|
68
|
+
const { event, payload, meta } = data;
|
|
69
|
+
if (!payload?.uuid) {
|
|
70
|
+
this.logger.error('Missing uuid in the message payload');
|
|
71
|
+
return done();
|
|
72
|
+
}
|
|
73
|
+
const channel = this.externalChannel.getChannel(event, payload.uuid);
|
|
74
|
+
const isChannelActive = await this.externalChannel.isChannelActive(channel);
|
|
75
|
+
if (!isChannelActive && listener.handler) {
|
|
76
|
+
try {
|
|
77
|
+
this.eventMessageValidator.validateSyncedEventMessage(data, payloadValidationSchema);
|
|
78
|
+
}
|
|
79
|
+
catch (err) {
|
|
80
|
+
this.logger.error(`Message in a wrong format was received from a synced event: ${event}`, { err });
|
|
81
|
+
return done();
|
|
82
|
+
}
|
|
83
|
+
if (payload.error) {
|
|
84
|
+
this.logger.error(`Error received for a synced event: ${event}`, payload.error);
|
|
85
|
+
return done();
|
|
86
|
+
}
|
|
87
|
+
try {
|
|
88
|
+
await listener.handler(payload, meta);
|
|
89
|
+
}
|
|
90
|
+
catch (err) {
|
|
91
|
+
this.logger.error(`Failed to handle the synced event [${event}] with payload`, { err });
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
await this.pubsub.publish(channel, data);
|
|
96
|
+
}
|
|
97
|
+
return done();
|
|
98
|
+
}
|
|
99
|
+
performDone(receivedMessage, data, error) {
|
|
100
|
+
const { done, data: { event, payload }, properties: { replyTo, correlationId }, } = receivedMessage;
|
|
101
|
+
const useDirectReply = replyTo && correlationId;
|
|
102
|
+
if (!useDirectReply) {
|
|
103
|
+
done();
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
if (error) {
|
|
107
|
+
return utils_1.utils.handleError(data, (err) => {
|
|
108
|
+
done({
|
|
109
|
+
event,
|
|
110
|
+
meta: {
|
|
111
|
+
date: new Date(),
|
|
112
|
+
},
|
|
113
|
+
payload: {
|
|
114
|
+
uuid: payload.uuid,
|
|
115
|
+
error: {
|
|
116
|
+
message: err.message,
|
|
117
|
+
http_code: err.getCode(),
|
|
118
|
+
data: err.getData(),
|
|
119
|
+
},
|
|
120
|
+
},
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
done({
|
|
125
|
+
event,
|
|
126
|
+
meta: {
|
|
127
|
+
date: new Date(),
|
|
128
|
+
},
|
|
129
|
+
payload: {
|
|
130
|
+
uuid: payload.uuid,
|
|
131
|
+
response: data,
|
|
132
|
+
},
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
getServiceCode(listener, payload) {
|
|
136
|
+
try {
|
|
137
|
+
return listener?.getServiceCode?.(payload);
|
|
138
|
+
}
|
|
139
|
+
catch (err) {
|
|
140
|
+
this.logger.error('Failed to get event listener service code', { err, listener });
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
exports.EventMessageHandler = EventMessageHandler;
|
|
145
|
+
//# sourceMappingURL=eventMessageHandler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"eventMessageHandler.js","sourceRoot":"","sources":["../../src/services/eventMessageHandler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EventMessageValidator = void 0;
|
|
4
|
+
class EventMessageValidator {
|
|
5
|
+
validator;
|
|
6
|
+
metaValidationSchema = {
|
|
7
|
+
date: { type: 'date', convert: true },
|
|
8
|
+
traceId: { type: 'string', optional: true },
|
|
9
|
+
};
|
|
10
|
+
constructor(validator) {
|
|
11
|
+
this.validator = validator;
|
|
12
|
+
}
|
|
13
|
+
validateEventMessage(data, payloadValidationSchema = {}) {
|
|
14
|
+
const validationSchema = {
|
|
15
|
+
event: { type: 'string' },
|
|
16
|
+
payload: { type: 'object', props: payloadValidationSchema },
|
|
17
|
+
meta: {
|
|
18
|
+
type: 'object',
|
|
19
|
+
props: this.metaValidationSchema,
|
|
20
|
+
},
|
|
21
|
+
};
|
|
22
|
+
this.validator.validate(data, validationSchema);
|
|
23
|
+
}
|
|
24
|
+
validateSyncedEventMessage(data, responseValidationSchema) {
|
|
25
|
+
const validation = {
|
|
26
|
+
uuid: { type: 'uuid' },
|
|
27
|
+
error: {
|
|
28
|
+
type: 'object',
|
|
29
|
+
optional: true,
|
|
30
|
+
props: {
|
|
31
|
+
http_code: { type: 'number' },
|
|
32
|
+
message: { type: 'string', optional: true },
|
|
33
|
+
data: { type: 'object', optional: true },
|
|
34
|
+
},
|
|
35
|
+
},
|
|
36
|
+
};
|
|
37
|
+
if (responseValidationSchema) {
|
|
38
|
+
validation.response = { type: 'object', optional: true, props: responseValidationSchema };
|
|
39
|
+
}
|
|
40
|
+
this.validateEventMessage(data, validation);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
exports.EventMessageValidator = EventMessageValidator;
|
|
44
|
+
//# sourceMappingURL=eventMessageValidator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"eventMessageValidator.js","sourceRoot":"","sources":["../../src/services/eventMessageValidator.ts"],"names":[],"mappings":";;;AAIA,MAAa,qBAAqB;IAMD;IALpB,oBAAoB,GAAqB;QAC9C,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE;QACrC,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE;KAC9C,CAAA;IAED,YAA6B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;IAAG,CAAC;IAExD,oBAAoB,CAAC,IAAsB,EAAE,0BAA4C,EAAE;QACvF,MAAM,gBAAgB,GAAqB;YACvC,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;YACzB,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,uBAAuB,EAAE;YAC3D,IAAI,EAAE;gBACF,IAAI,EAAE,QAAQ;gBACd,KAAK,EAAE,IAAI,CAAC,oBAAoB;aACnC;SACJ,CAAA;QAED,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAA;IACnD,CAAC;IAED,0BAA0B,CAAC,IAAsB,EAAE,wBAA2C;QAC1F,MAAM,UAAU,GAAqB;YACjC,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;YACtB,KAAK,EAAE;gBACH,IAAI,EAAE,QAAQ;gBACd,QAAQ,EAAE,IAAI;gBACd,KAAK,EAAE;oBACH,SAAS,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;oBAC7B,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE;oBAC3C,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE;iBAC3C;aACJ;SACJ,CAAA;QACD,IAAI,wBAAwB,EAAE;YAC1B,UAAU,CAAC,QAAQ,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,wBAAwB,EAAE,CAAA;SAC5F;QAED,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,UAAU,CAAC,CAAA;IAC/C,CAAC;CACJ;AAxCD,sDAwCC"}
|