A node.js module which provides you a publisher and a subscriber for the mqtt protocol, allowing you to easily run repetitive tasks. With Typescript support.
To install mqtt-now:
$ npm install mqtt-now
Simple:
const mqttNow = require('mqtt-now');
const options = {
  host: 'localhost',
  interval: 1000,
  actions: [
    {
      topic: 'public',
      message: 'my message'
    },
    {
      topic: 'random',
      message: () => ( 'random ' + Math.random() )
    }
  ]
}
mqttNow.publish(options);
With Buffer:
const mqttNow = require('mqtt-now');
const options = {
  host: 'localhost',
  interval: 1000,
  actions: [
    {
      topic: 'public',
      message: Buffer.alloc(10, 'my message')
    }
  ]
}
mqttNow.publish(options);
With Web Sockets:
const { publish, Protocol } = require('mqtt-now');
const options = {
  type: Protocol.WS,
  host: 'localhost',
  interval: 1000,
  actions: [{ topic: 'public', message: 'my message' }]
}
publish(options);
With further configurations:
const mqttNow = require('mqtt-now');
const options = {
  url: 'mqtt://localhost:3000',
  actions: [
    {
      topic: 'public',
      message: 'my message',
      onError: error => console.error('Error in public')
    },
    {
      topic: 'random',
      message: () => ( 'random ' + Math.random() ),
      interval: 100
    }
  ],
  interval: 1000,
  onError: error => console.error('Error in publishing', error)
}
mqttNow.publish(options);
Simple:
const mqttNow = require('mqtt-now');
const options = {
  host: 'localhost',
  actions: [{ topic: 'public' }, { topic: 'random' }],
  onMessage: message => console.log('Message received ', message),
  messageType: mqttNow.MessageType.STRING
}
mqttNow.subscribe(options);
With Web Sockets:
const { subscribe, Protocol, MessageType } = require('mqtt-now');
const options = {
  type: Protocol.WS,
  host: 'localhost',
  actions: [{ topic: 'public' }, { topic: 'random' }],
  onMessage: message => console.log('Message received ', message),
  messageType: MessageType.STRING
}
subscribe(options);
With further configurations:
const mqttNow = require('mqtt-now');
const options = {
  protocol: 'mqtt',
  port: '1883',
  host: 'localhost',
  actions: [
    {
      topic: 'public',
      onError: error => console.error('Error in subscribing to "public" ', error)
    },
    {
      topic: 'random',
      onMessage: message => console.log('Random message received ', message)
    },
    {
      topic: 'buffer',
      messageType: mqttNow.MessageType.BUFFER,
      onMessage: message => console.log('This remains a buffer ', message)
    }
  ],
  messageType: mqttNow.MessageType.STRING,
  onMessage: message => console.log('Message received ', message),
  onError: error => console.error('Error in subscribing ', error)
}
mqttNow.subscribe(options);
A Publisher is a function with two optional arguments: an array of topics and generic data. When called, all the specified topics will be published as specified in the options and, if topic's message is generated by a function, the generic data is passed to that function.
const mqttNow = require('mqtt-now');
const options = {
  host: 'localhost',
  actions: [
    {
      topic: 'public',
      message: 'my message'
    },
    {
      topic: 'random',
      message: () => ( 'random ' + Math.random() )
    },
    {
      topic: 'now',
      message: data => ( data + 'ms are passed from 01/01/1970' )
    }
  ]
}
mqttNow.getPublisher(options)
  .then(publisher => {
    publisher('public');
    publisher(['public', 'random']);
    publisher('', Date.now());
  });
Given this code:
const mqttNow = require('mqtt-now');
const publishOptions = {
  host: 'localhost',
  actions: [
    {
      topic: 'public',
      message: 'my message',
      interval: 500
    },
    {
      topic: 'random',
      message: () => ( 'random ' + Math.random() )
    }
  ],
  interval: 1000
}
const subscribeOptions = {
  host: 'localhost',
  actions: [
    { topic: 'public' },
    {
      topic: 'random',
      onMessage: message => console.log('Random message received ', message)
    }
  ],
  messageType: mqttNow.MessageType.STRING,
  onMessage: message => console.log('Message received ', message)
}
mqttNow.publish(publishOptions);
mqttNow.subscribe(subscribeOptions);
Supposing that there is a mqtt instance running in localhost,
The console will result in this:
Message received  my message
Random message received  random 0.48166328598140296
Message received  my message
Message received  my message
Random message received  random 0.8821357744971647
Message received  my message
Message received  my message
Random message received  random 0.8432069519144318
Message received  my message
Message received  my message
Random message received  random 0.13065012342886484
..................................................
Syntax:
mqttNow.publish(options)
Description:
This function publishes every a certain amount of time the data to the topics specified by the options. See Usage to have an example.
Parameters:
Options parameters:
Protocol.MQTT. If not overwritten, the protocol and the port of the url will be determined by this property.undefined. Specifies the protocol to use in the url string. Note: overwrites the protocol specified by type property but is overwritten by url property.localhost. Specifies the host to use in the url string. Note: overwritten by url property.undefined. Specifies the port to use in the url string. Note: overwrites the port specified by type property but is overwritten by url property.undefined. Specifies the url used by the connection. Note: overwrites all the other properties that specify the url.error => {}. Specifies what will be executed in case of an error. Note: overwritten by the more-specific onError option whether specified in a certain topic.[]. The actions (topic and message) that you want to publish. See MqttPublishAction to further information.1. The time in milliseconds between every publication of a topic. Note: overwritten by the more-specific interval option whether specified in a certain topic.MqttPublishAction
Syntax:
mqttNow.subscribe(options)
Description:
This function subscribes to the topics specified by the options and handle the received messages in the way specified by the options. See Usage to have an example.
Parameters:
Options parameters:
Protocol.MQTT. If not overwritten, the protocol and the port of the url will be determined by this property.undefined. Specifies the protocol to use in the url string. Note: overwrites the protocol specified by type property but is overwritten by url property.localhost. Specifies the host to use in the url string. Note: overwritten by url property.undefined. Specifies the port to use in the url string. Note: overwrites the port specified by type property but is overwritten by url property.undefined. Specifies the url used by the connection. Note: overwrites all the other properties that specify the url.error => {}. Specifies what will be executed in case of an error. Note: overwritten by the more-specific onError option whether specified in a certain topic.[]. The actions that specifies which topics you want to subscribe to and what to do with the received messages. See MqttSubscribeAction to further information.message => {}. What will be done with the received messages. Note: overwritten by the more-specific onMessage option whether specified in a certain topic.MessageType.BUFFER. The type of the message given as argument of onMessage callback. Note: overwritten by the more-specific messageType option whether specified in a certain topic.MqttSubscribeAction
MessageType.BUFFER. The type of the message given as argument of onMessage callback. Note: overwrites the messageType callback specified by the options.Syntax:
const promise = mqttNow.getPublisher(options)
Description:
This function returns a promise with a Publisher, which is a function that takes a list of topics and in case some data as arguments and when is called publishes everything is specified in the options given to this function. In the returned function: If no topic or an empty string is passed, it publishes all the topics. Also, in case data is passed as second argument, it will passed as the argument of each function that generates the message for a topic. See Usage to have an example.
Parameters:
Options parameters:
Protocol.MQTT. If not overwritten, the protocol and the port of the url will be determined by this property.undefined. Specifies the protocol to use in the url string. Note: overwrites the protocol specified by type property but is overwritten by url property.localhost. Specifies the host to use in the url string. Note: overwritten by url property.undefined. Specifies the port to use in the url string. Note: overwrites the port specified by type property but is overwritten by url property.undefined. Specifies the url used by the connection. Note: overwrites all the other properties that specify the url.error => {}. Specifies what will be executed in case of an error. Note: overwritten by the more-specific onError option whether specified in a certain topic.[]. The actions (topic and message) that you want to publish. See MqttPublisherAction to further information.MqttPublisherAction
Please notice that an mqtt instance have to run in your localhost in order to the above examples to work.
To build the module make sure you have Typescript installed or install the dev dependencies. After this, run:
$ npm run transpile
The source folder will be compiled in the dist folder.
Generated using TypeDoc