var mqtt = require('mqtt'); var request = require('request'); var util = require('util'); var logger = require('log4js').getLogger(); var EventEmitter = require('events'); var Minibus = require('minibus'); // var db = require('../server/db-connector').dbConnection; //var nano = require('nano')('http://martind2000:1V3D4m526i@localhost:5984'); //var nano = require('nano')('http://localhost:5984'); var busEmitter = new EventEmitter(); var db_name = 'mqtt'; //var dbCouch = nano.use(db_name); var globalMode = 'FanOff'; var lastDispatch = 0; busEmitter.on('send', function (mode) { var url = ['https://maker.ifttt.com/trigger/', mode, '/with/key/cWvECkeiyAPwmiOPBkXL2D'].join(''); console.log(url); if (mode !== globalMode) { console.log('Sending..'); globalMode = mode; request(url, function (error, response, body) { // if (!error && response.statusCode === 200) { console.log(response, body); // } }); var d = new Date(); lastDispatch = d.getTime(); } else { console.log('Not sent...'); } }); var mqttClient = function () { var orgId = ''; var userName = ''; var appKey = 'bob'; this.livingRoom = { temp: 0, last: 0 }; var mode = 'FanOff'; var d = new Date(); this.lastMsg = d.getTime(); this.fanTimer = function () { 'use strict'; var now = new Date; var mod = 900000 - (now.getTime() % 900000); // var if (globalMode === 'FanOff') { console.log('Fans off, temp should be <= 19.5'); mode = (parseFloat(this.livingRoom.temp) <= 19.5) ? 'FanOn' : 'FanOff'; } else { console.log('Fans on, temp should not be less than 22.5'); mode = (parseFloat(this.livingRoom.temp) <= 22.5) ? 'FanOn' : 'FanOff'; } var n = new Date(); n = n.getTime() - this.lastMsg; console.log('Last msg', n); if (n >= 600000) { console.error('No message received for over 10 minutes'); mode = 'FanOff'; throw new error('Ejecting for restart'); } logger.info('LR temp:', this.livingRoom.temp); busEmitter.emit('send', mode); setTimeout(this.fanTimer.bind(this), mod + 10); }; this.lighting = 'lights'; this.connected = false; var options = { keepalive: 3600, clientId: 'a:' + orgId + ':' + Date.now(), username: userName, password: new Buffer(appKey) }; this.client = mqtt.connect('mqtt://' + orgId + 'silvrtree.co.uk', options); this.client.on('connect', function () { connected = true; logger.info('Connected to SIlvr Broker'); this.fanTimer(); }.bind(this)); this.client.subscribe('livingroomTemp'); this.client.on('message', function (topic, message) { var json = JSON.parse(message.toString()); logger.debug(json); logger.debug(json.temp); logger.debug('GlobalMode',globalMode); this.livingRoom.temp = parseFloat(json.temp); console.log('lr:',this.livingRoom.temp, this.livingRoom.temp >= 22.6); if (this.livingRoom.temp >= 22.7) { console.log('Max temp reached, turn off' ); busEmitter.emit('send', 'FanOff'); } var d = new Date(); this.lastMsg = d.getTime(); }.bind(this)); this.isConnected = function () { return this.connected; }; }; /* Client = mqtt.connect(); client.subscribe('presence'); client.on('message', function(topic, message) { console.log(message); }); */ mqttClient.prototype.lightsIn = function () { var destinationName = 'lightsIn'; this.client.publish(destinationName, '0'); var destinationName = 'lightsIn'; this.client.publish(destinationName, '1'); }; mqttClient.prototype.lightsOut = function () { var destinationName = 'lightsOut'; this.client.publish(destinationName, 'f'); destinationName = 'lightsOut'; this.client.publish(destinationName, 'g'); }; module.exports.mqttClient = mqttClient;