-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.js
More file actions
78 lines (73 loc) · 2.28 KB
/
index.js
File metadata and controls
78 lines (73 loc) · 2.28 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/**
* Generic message queue
* @class
* */
class MessageQueue {
/**
* Create a message queue, injecting a client (e.g. SQS)
* @param {string} clientType - client type ('sqs', 'sns', or 'rabbitmq')
* @param {*} options
* @param {string} options.topicPrefix topic name prefix
* @param {string} options.topicPostfix topic name postfix
*/
constructor (clientType, options = {}) {
let client
const baseOpts = {
endpoint: process.env.MESSAGE_QUEUE_ENDPOINT
}
if (clientType === 'sqs') {
client = new (require('./sqs-client'))(baseOpts)
} else if (clientType === 'sns') {
client = new (require('./sns-client'))(baseOpts)
} else if (clientType === 'rabbitmq') {
client = new (require('./rabbitmq-client'))(baseOpts)
} else {
throw new Error('MessageQueue clientType is not supported')
}
this.topicPrefix = options.topicPrefix
this.topicPostfix = options.topicPostfix
this.client = client
}
queueName (eventName) {
const prefix = this.topicPrefix ? `${this.topicPrefix}-` : ''
const postfix = this.topicPostfix ? `-${this.topicPostfix}` : ''
return `${prefix}${eventName}${postfix}`
}
/**
* Append a message to the queue
*
* @param {string} eventName
* @param {*} message
*/
async publish (eventName, message) {
const queue = this.queueName(eventName)
console.info(`Message Queue: ${queue}: Publishing ${JSON.stringify(message)}`)
try {
await this.client.publish(queue, message)
} catch (err) {
console.error(`Message Queue: ${queue}: Failed to publish "${err.message}"`)
}
}
/**
* Callback from subscribing to a message queue, one call per message
* @async
* @callback MessageHandler
* @param {*} message
* @return {boolean} true if the message was handled successfully (and can be deleted from the queue)
*/
/**
* Subscribe to receive messages from the queue
* @param {string} eventName
* @param {MessageHandler} messageHandler
*/
subscribe (eventName, messageHandler) {
const queue = this.queueName(eventName)
this.client.subscribe(queue, (message) => {
console.info(`Message Queue: ${queue}: Receiving ${JSON.stringify(message)}`)
return messageHandler(message)
})
}
}
module.exports = {
MessageQueue
}