I have 2 servers that talk to each other. When Users want to check the health of the Sensor, it hits the API /check/health which in turn talks to Monitoring server to get the Status field of the Sensor.. This status is sent back to Provisioning and sent to the User.
I tested this and it works fine..ie when I do a http://localhost:3000/check/health/4 (3 is the Sensor ID ), i get the response as Good. When i do another request say http://localhost:3000/check/health/3, i get an error on the Provisioning server as below :
Does anyone know why I can't do a second GET request.. I seem to get it working only for the 1st health check not subsequent ones..
Output/error:
Server listening at port 3000
Connected to Monitoring Server!
Server got a health check for Sensor ID : 4
The Status of the Sensor is : Good
Server got a health check for Sensor ID : 3
The Status of the Sensor is : Undefined
_http_outgoing.js:344
throw new Error('Can\'t set headers after they are sent.');
^
Error: Can't set headers after they are sent.
at ServerResponse.OutgoingMessage.setHeader (_http_outgoing.js:344:11)
Provisioning server:
// Code to communicate with Monitoring server
var io = require('socket.io-client');
var socket = io.connect('http://localhost:4000', { reconnect: true });
socket.on('connect', function(socket) {
console.log('Connected to Monitoring Server!');
});
// Code to serve the Sensor users
var express = require('express');
var app= express();
var path = require('path');
var bodyParser= require('body-parser');
var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/sensor_db');
var Schema = mongoose.Schema;
var sensorSchema = new Schema({
value:{ type:Number, default:0},
format:{type:String, default:"default"},
id:{type:Number,required:true,unique:true},
description:{type:String},
type:{type:String},
groupId:{type:Number},
users:{type:Array,default:[]},
admin:{type:String,default:'Undefined'},
status:{type:String,default:'InActive'},
owner:{type:String,default:'Undefined'},
templateId:{type:Number}
});
var Sensor = mongoose.model('Sensor',sensorSchema);
// API to get the health of the Sensor by looking up its Status, pass the Sensor ID to check
app.get('/check/health/:id', function (req, res) {
var id = req.params.id;
console.log("Server got a health check for Sensor ID :", id);
socket.emit('eventToClient',{ id: id })
socket.on('reply', function (data) {
console.log("The Status of the Sensor is :",data.status);
res.json(data.status);
});
})
app.listen(3000);
console.log('Server listening at port 3000');
Monitoring Server:
var app = require('express')();
var server = require('http').Server(app);
var io = require('socket.io')(server);
var express = require('express');
var mongoose = require('mongoose');
mongoose.connect('mongodb://127.0.0.1:27017/sensor_db') ;
var Schema = mongoose.Schema;
var sensorSchema = new Schema({
value:{ type:Number, default:0},
format:{type:String, default:"default"},
id:{type:Number,required:true,unique:true},
description:{type:String},
type:{type:String},
groupId:{type:Number},
users:{type:Array,default:[]},
admin:{type:String,default:'Undefined'},
status:{type:String,default:'Undefined'},
owner:{type:String,default:'Undefined'},
templateId:{type:Number}
});
var Sensor = mongoose.model('Sensor',sensorSchema);
io.on('connection', function(socket){
console.log('connection received from Provisioning');
// To get messages from Provisioning server
socket.on('eventToClient',function(data) {
var id = data.id
Sensor.findOne({id: id}, function (err, doc) {
if (err) return res.status(500).send({error: err});
socket.emit('reply',doc)
})
});
});
server.listen(4000, function(){
console.log('socket.io server listening on *:4000');
});