@naturacosmeticos/iris-nodejs-messenger
v2.0.2
Published
[](https://snyk.io/test/github/natura-cosmeticos/iris-nodejs-messenger?targetFile=package.json) [;
// Create a AmqpMessageBus
const messageBus = Factory.create({
amqpOptions: {
serverUrl: 'amqp://rabbitmq',
},
developmentMode: true,
});
// Publish
messageBus.publish('checkout', { message: 'my message' });You can verify the message created accessing RabbitMQ Dashboard:
- http://rabbitmq.messaging.localtest.me/#/
- user: quest
- password: quest
Receiving messages
Now to receive the messages posted you just need to pass an object where the attributes need to be the name of our exchange and the value a promise that will be executed.
const { Queue: { Factory } } = require('@naturacosmeticos/iris-nodejs-messenger');
const messageBus = Factory.create({
amqpOptions: {
serverUrl: 'amqp://rabbitmq',
},
developmentMode: true,
});
messageBus.receive({
checkout: (message) => {
return new Promise((resolve) => {
console.log(message);
resolve(message);
});
},
});AWS
Sending messages
Before you test the following example you need to change some configurations in the docker-compose.yml:
- Remove
SNS_ENDPOINTandSQS_ENDPOINT. Those variables are only used when you want to test using the localstack container - Update
AWS_ACCOUNT_ID,AWS_ACCESS_KEY_IDandAWS_SECRET_ACCESS_KEYwith your AWS user credentials. Also you may need to change theAWS_REGIONvariable, if you are not usingus-east-1
const { PubSub: { Factory } } = require('@naturacosmeticos/iris-nodejs-messenger');
// Create a SNSMessageBus
const messageBus = Factory.create({
awsSnsOptions: {
friendlyNamesToArn: {
checkout: process.env.ORDER_TOPIC_ARN,
},
},
developmentMode: false,
});
// Publish
messageBus.publish('checkout', { message: 'my message' })
.then((message) => {
console.log('message sent:', message);
});Receiving messages
Use this option when you have an SQS queue connected to a lambda function.
Exports your lambda handler like this:
const { Queue: { Aws: { LambdaHandler } } } = require('@naturacosmeticos/iris-nodejs-messenger');
const handler = new LambdaHandler({
[process.env.CHECKOUT_SQS_ARN]: {
friendlyName: 'checkout',
url: process.env.CHECKOUT_SQS_URL,
},
}, {
checkout: (message) => {
return new Promise((resolve) => {
console.log(message);
resolve(message);
});
},
});
exports.index = handler.handle.bind(handler);How to contribute
You can contribute submitting pull requests.
Setup
To setup your local env, you need to following these steps:
docker network create messagingdocker-compose run messaging bash, inside the container runnpm install. After the packages installation, exit from the containerdocker-compose up
Testing
Just run npm test inside the container (docker-compose exec messaging bash).
Lint
To verify if any lint rule was broken run inside the container: npm run lint.
Update docs
Run npm run docs to generate a new documentation version.
