@digipair/skill-rabbitmq 0.132.8

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/README.md ADDED
@@ -0,0 +1,8 @@
1
+ # skill-rabbitmq
2
+
3
+ This library was generated with [Nx](https://nx.dev).
4
+
5
+ ## Building
6
+
7
+ Run `nx build skill-rabbitmq` to build the library.
8
+
@@ -0,0 +1,68 @@
1
+ 'use strict';
2
+
3
+ var engine = require('@digipair/engine');
4
+ var amqplib = require('amqplib');
5
+
6
+ function _interopNamespaceDefault(e) {
7
+ var n = Object.create(null);
8
+ if (e) {
9
+ Object.keys(e).forEach(function (k) {
10
+ if (k !== 'default') {
11
+ var d = Object.getOwnPropertyDescriptor(e, k);
12
+ Object.defineProperty(n, k, d.get ? d : {
13
+ enumerable: true,
14
+ get: function () { return e[k]; }
15
+ });
16
+ }
17
+ });
18
+ }
19
+ n.default = e;
20
+ return Object.freeze(n);
21
+ }
22
+
23
+ var amqplib__namespace = /*#__PURE__*/_interopNamespaceDefault(amqplib);
24
+
25
+ let RabbitMqService = class RabbitMqService {
26
+ async rabbit(params, _pins, context) {
27
+ const { url = context.privates.RABBITMQ_URL ?? process.env['RABBITMQ_URL'] } = params;
28
+ return await amqplib__namespace.connect(url);
29
+ }
30
+ async produce(params, _pins, context) {
31
+ const { client = context.privates.CLIENT_RABBITMQ, queue, message } = params;
32
+ const connection = await engine.executePinsList(client, context, `${context.__PATH__}.client`);
33
+ const channel = await connection.createChannel();
34
+ await channel.sendToQueue(queue, Buffer.from(message));
35
+ await channel.close();
36
+ await connection.close();
37
+ }
38
+ async consume(params, _pinsSettingsList, context) {
39
+ const { client = context.privates.CLIENT_RABBITMQ, execute, queue } = params;
40
+ const connection = await engine.executePinsList(client, context, `${context.__PATH__}.client`);
41
+ const channel = await connection.createChannel();
42
+ await channel.consume(queue, async (message)=>{
43
+ await engine.executePinsList(execute, {
44
+ ...context,
45
+ message: message?.content?.toString()
46
+ }, `${context.__PATH__}.execute`);
47
+ channel.ack(message);
48
+ });
49
+ return {
50
+ connection,
51
+ channel
52
+ };
53
+ }
54
+ async consumerDisconnect(params, _pinsSettingsList, context) {
55
+ const { connection, channel } = params;
56
+ await channel.close();
57
+ await connection.close();
58
+ }
59
+ };
60
+ const rabbit = (params, pinsSettingsList, context)=>new RabbitMqService().rabbit(params, pinsSettingsList, context);
61
+ const produce = (params, pinsSettingsList, context)=>new RabbitMqService().produce(params, pinsSettingsList, context);
62
+ const consume = (params, pinsSettingsList, context)=>new RabbitMqService().consume(params, pinsSettingsList, context);
63
+ const consumerDisconnect = (params, pinsSettingsList, context)=>new RabbitMqService().consumerDisconnect(params, pinsSettingsList, context);
64
+
65
+ exports.consume = consume;
66
+ exports.consumerDisconnect = consumerDisconnect;
67
+ exports.produce = produce;
68
+ exports.rabbit = rabbit;
@@ -0,0 +1 @@
1
+ export * from "./src/index";