2017-11-09 00:05:30 +00:00
|
|
|
const mqtt = require('mqtt');
|
|
|
|
|
|
|
|
const em = require('events').EventEmitter;
|
|
|
|
const util = require('util');
|
|
|
|
const logger = require('log4js').getLogger('MQTT');
|
|
|
|
logger.level = 'trace';
|
|
|
|
|
|
|
|
const MqttController = function() {
|
|
|
|
const _this = this;
|
|
|
|
|
|
|
|
const options = {
|
|
|
|
'keepalive': 3600,
|
|
|
|
'clientId': 'aida',
|
|
|
|
'clean' : false
|
|
|
|
};
|
|
|
|
|
|
|
|
this.on('newListener', listener => {
|
|
|
|
logger.info(`Event Listener: ${ listener}`);
|
|
|
|
});
|
|
|
|
|
|
|
|
logger.debug('Trying to connect');
|
2018-07-14 16:52:55 +00:00
|
|
|
this.client = mqtt.connect('mqtt://192.168.1.156', options);
|
2017-11-09 00:05:30 +00:00
|
|
|
|
|
|
|
this.client.on('error', function(m) {
|
|
|
|
logger.error(m);
|
|
|
|
}.bind(this));
|
|
|
|
|
|
|
|
this.client.on('connect', function () {
|
|
|
|
logger.debug('MQTT Connected');
|
|
|
|
this.client.subscribe('bedroomTemp');
|
|
|
|
this.emit('found');
|
|
|
|
}.bind(this));
|
|
|
|
|
|
|
|
this.client.on('message', function (topic, message) {
|
|
|
|
// message is Buffer
|
|
|
|
const msg = message.toString();
|
|
|
|
const json = JSON.parse(msg);
|
|
|
|
// client.end()
|
|
|
|
this.emit(topic, json.temp);
|
|
|
|
}.bind(this));
|
|
|
|
|
|
|
|
return this;
|
|
|
|
};
|
|
|
|
|
|
|
|
util.inherits(MqttController, em);
|
|
|
|
|
|
|
|
module.exports = MqttController;
|