/**
|
* Created by bin.shen on 5/30/16.
|
*/
|
|
var net = require('net');
|
var moment = require('moment');
|
var mongoClient = require('mongodb').MongoClient;
|
var config = require('./config');
|
var method = require('./method');
|
var queue = require('./queue');
|
|
var map = {
|
"5a0000010001": 32, //心跳命令行
|
"5a0000010002": 102, //云地址写入WIFI模块
|
"5a0000010003": 162, //传感器数据上传
|
"5a0000010004": 32, //云端时间
|
"5a0000010006": 122, //配网数据
|
"5a0000010007": 32, //主机休眠前发送即将休眠的命令
|
"5a000001000c": 20 //联云通知
|
};
|
|
function handleData(db, socket, value) {
|
|
//1.心跳命令行
|
if(value.startsWith('5a0000010001')) {
|
var output = [ 0x6A, 0x00, 0x00, 0x01, 0x00, 0x01, 0xA1, 0x1A, 0xC7, 0x6B ];
|
method.getAppStatus(db, value, function(doc) {
|
var app_status = doc.app_status;
|
var app_last_updated = doc.app_last_updated;
|
if(app_status == 1 && app_last_updated != null && Date.now() - app_last_updated <= 30000) {
|
output[7] = 0x1B;
|
}
|
socket.write(new Buffer(output));
|
});
|
return;
|
}
|
|
//3.传感器数据上传
|
if(value.startsWith('5a0000010003')) {
|
var output = [ 0x6A, 0x00, 0x00, 0x01, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x6B ];
|
method.insertData(db, value, function(data, rank) {
|
//method.insertDocument2(db, value, rank, function(data) {});
|
var fields = method.padLeft(rank.toString(16), 8).match(/.{2}/g);
|
output[6] = method.toDec(fields[0]);
|
output[7] = method.toDec(fields[1]);
|
output[8] = method.toDec(fields[2]);
|
output[9] = method.toDec(fields[3]);
|
socket.write(new Buffer(output));
|
});
|
return;
|
}
|
|
//7.主机休眠前发送即将休眠的命令
|
if(value.startsWith('5a0000010007')) {
|
method.updateDeviceSleep(db, value, function(data) {});
|
return;
|
}
|
|
//4.云端时间
|
if(value.startsWith('5a0000010004')) {
|
method.updateDeviceWakeup(db, value, function(data) {});
|
var current_time = moment();
|
var output = [
|
0x6A, 0x00, 0x00, 0x01, 0x00, 0x04, //包头(0-5)
|
parseInt(current_time.format('s')), //秒
|
parseInt(current_time.format('m')), //分
|
parseInt(current_time.format('H')), //小时
|
parseInt(current_time.format('D')), //日
|
parseInt(current_time.format('M')), //月
|
parseInt(current_time.format('E')), //星期
|
parseInt(current_time.format('YY')), //年
|
0x36, //校验和
|
0x6B //包尾
|
];
|
socket.write(new Buffer(output));
|
return;
|
}
|
|
//2.云地址写入WIFI模块
|
if(value.startsWith('5a0000010002')) {
|
method.insertDocument(db, value, function(data) {});
|
socket.write(new Buffer(config.OUTPUT_2));
|
return;
|
}
|
|
//6.配网数据
|
if(value.startsWith('5a0000010006')) {
|
method.registerDevice(db, value, function(data) {});
|
socket.write(new Buffer(config.OUTPUT_6));
|
return;
|
}
|
|
//12.联云通知
|
if(value.startsWith('5a000001000c')) {
|
socket.write(new Buffer(config.OUTPUT_6));
|
return;
|
}
|
}
|
|
function doWork(db, socket, data) {
|
if(data == "") return;
|
var length = map[data.slice(0, 12)];
|
if(length > 0) {
|
var value = data.slice(0, length);
|
console.log(moment().format('YYYY-MM-DD HH:mm:ss') + " => " + value);
|
|
queue.publishMessage(value);
|
|
handleData(db, socket, value);
|
|
doWork(db, socket, data.slice(length));
|
}
|
}
|
|
mongoClient.connect(config.URL, function(err, db) {
|
if (err) {
|
console.log(err.message);
|
return;
|
}
|
console.log('Connecting to Mongo DB at ' + config.URL);
|
|
net.createServer().on('connection', function(socket){
|
console.log('CONNECTED: ' + socket.remoteAddress +':'+ socket.remotePort);
|
|
socket.on('data', function(data) {
|
if(data == null) {
|
console.log("Error - invalid data - null or undefined");
|
return;
|
}
|
|
var value = data.toString('hex').toLowerCase();
|
if(value.length < 12) {
|
console.log("Error - invalid data - less than 12 character long");
|
return;
|
}
|
|
//console.log(moment().format('YYYY-MM-DD HH:mm:ss') + " => " + value);
|
|
doWork(db, socket, value);
|
});
|
|
socket.on('end', function(){
|
|
});
|
|
socket.on('error', function(error) {
|
console.log(error);
|
socket.end();
|
});
|
|
socket.on('timeout',function(){
|
socket.end();
|
});
|
|
socket.on('close', function(data) {
|
console.log('Closed socket: ' + socket.remoteAddress +' '+ socket.remotePort);
|
});
|
}).listen(config.PORT, config.HOST);
|
|
console.log('TCP Server listening on ' + config.HOST + ':' + config.PORT);
|
});
|