207 lines
4.7 KiB
JavaScript
207 lines
4.7 KiB
JavaScript
var express = require('express'), fs = require('fs'), sqlite3 = require('sqlite3').verbose();
|
|
var EventEmitter = require('events');
|
|
var log4js = require('log4js');
|
|
var logger = log4js.getLogger();
|
|
|
|
var router = express.Router();
|
|
|
|
var EventEmitter = require('events');
|
|
var busEmitter = new EventEmitter();
|
|
|
|
|
|
var temp_db;
|
|
var file = process.env.DB_HOME + '/' + "temp.db";
|
|
var exists;
|
|
/* GET users listing. */
|
|
|
|
function createDB() {
|
|
logger.debug('Creating Temp db...');
|
|
logger.debug(file);
|
|
if (!fs.existsSync(file)) {
|
|
logger.debug('creating db file');
|
|
fs.openSync(file, 'w');
|
|
|
|
temp_db = new sqlite3.Database(file, createTable);
|
|
|
|
temp_db.close();
|
|
}
|
|
else {
|
|
logger.info('Database already created.');
|
|
connectDB();
|
|
}
|
|
|
|
|
|
}
|
|
|
|
function startEventHandler() {
|
|
"use strict";
|
|
|
|
}
|
|
function connectDB() {
|
|
"use strict";
|
|
logger.debug('Connect db.');
|
|
temp_db = new sqlite3.Database(file);
|
|
console.log(temp_db);
|
|
|
|
return temp_db;
|
|
}
|
|
|
|
function createTable() {
|
|
logger.debug('Creating temp table...');
|
|
temp_db.run('CREATE TABLE IF NOT EXISTS temp (date text, reading real);');
|
|
}
|
|
|
|
|
|
function closeDB() {
|
|
"use strict";
|
|
console.log('Closing db.');
|
|
temp_db.close();
|
|
}
|
|
|
|
function insertTempReading(time, reading) {
|
|
console.log('Inserting reading:' + reading);
|
|
|
|
// var sql = db.prepare('INSERT into temperature(date, reading) VALUES
|
|
// (?,?)',[time],[reading]);
|
|
temp_db.run('BEGIN TRANSACTION');
|
|
|
|
temp_db.run('INSERT into temp(date, reading) VALUES (?,?);', [time, reading]);
|
|
|
|
// temp_db.run('END');
|
|
|
|
temp_db.run('commit');
|
|
}
|
|
|
|
/*router.get('/', function (req, res, next) {
|
|
var now = new Date();
|
|
|
|
var t = req.query;
|
|
|
|
console.log('t:');
|
|
console.log(JSON.stringify(t));
|
|
if (req.query != {} && req.query.temp != null) {
|
|
// createDB();
|
|
|
|
|
|
res.writeHead(200, {"ContentType": "text/html"});
|
|
//res.send(JSON.stringify(t));
|
|
res.end('ok');
|
|
} else {
|
|
res.writeHead(200, {"ContentType": "text/html"});
|
|
//res.send(JSON.stringify(t));
|
|
res.end('error?');
|
|
}
|
|
|
|
|
|
});*/
|
|
|
|
/*router.get('/:id', function (req, res, next) {
|
|
var id = req.params.id;
|
|
|
|
console.log('id: ' + id);
|
|
res.writeHead(200, {"ContentType": "text/html"});
|
|
//res.send(JSON.stringify(t));
|
|
res.end('ok');
|
|
});*/
|
|
|
|
router.get('/reading', function (req, res, next) {
|
|
var now = new Date();
|
|
|
|
var t = req.query;
|
|
|
|
console.log('t:');
|
|
console.log(JSON.stringify(t));
|
|
|
|
res.writeHead(200, {"ContentType": "application/json"});
|
|
//res.send(JSON.stringify(t));
|
|
res.end(JSON.stringify({}));
|
|
});
|
|
|
|
|
|
router.post('/', function (req, res, next) {
|
|
"use strict";
|
|
|
|
var t = req.body;
|
|
var now = new Date();
|
|
var dataJSON;
|
|
console.log('~~~~');
|
|
logger.debug(t);
|
|
console.log(typeof t);
|
|
//t = JSON.parse(t);
|
|
if(t.hasOwnProperty('data')){
|
|
logger.debug('We have data');
|
|
var data = t.data;
|
|
var s = data.toString();
|
|
logger.debug(typeof s);
|
|
logger.debug(s);
|
|
/*dataJSON = JSON.parse(s);
|
|
logger.debug(typeof dataJSON);*/
|
|
/* if (data.hasOwnProperty(temp)) {
|
|
logger.log('We have temp! ' + data.temp);
|
|
}*/
|
|
|
|
//dataJSON = JSON.parse(data);
|
|
//logger.debug(dataJSON);
|
|
|
|
/* var data = t.data;
|
|
dataJSON = JSON.parse(data);
|
|
if(dataJSON.hasOwnProperty('temp')) {
|
|
|
|
}
|
|
else
|
|
{
|
|
logger.error('No temp data!');
|
|
}*/
|
|
}
|
|
else
|
|
{
|
|
logger.error('No data block!');
|
|
}
|
|
/*console.log(JSON.stringify(t));
|
|
if (dataJSON != {} && dataJSON.temp != null) {
|
|
busEmitter.emit("saveTempData", {time: now.toJSON(), value: parseFloat(dataJSON.temp)});
|
|
}*/
|
|
|
|
res.writeHead(200, {"ContentType": "text/html"});
|
|
res.end('ok');
|
|
});
|
|
|
|
|
|
router.get('/all', function (req, res, next) {
|
|
"use strict";
|
|
console.log('Selecint all..');
|
|
var db = connectDB();
|
|
|
|
db.all('SELECT * from temp', function (err, rows) {
|
|
|
|
var out = [];
|
|
console.log(err);
|
|
console.log(rows);
|
|
rows.forEach(function (row) {
|
|
console.log(row.date + ', ' + row.reading);
|
|
// var t = ;
|
|
// out.push({"date": Date(row.date), "reading":row.reading});
|
|
out.push({"date": row.date, "reading": row.reading});
|
|
});
|
|
|
|
res.writeHead(200, {"ContentType": "application/json"});
|
|
//res.send(JSON.stringify(t));
|
|
res.end(JSON.stringify(out));
|
|
|
|
//closeDB();
|
|
});
|
|
|
|
|
|
});
|
|
|
|
module.exports = router;
|
|
|
|
createDB();
|
|
|
|
|
|
var sendSocketHandler = (obj) => {
|
|
// logger.info('sendSocket: ' + JSON.stringify(obj));
|
|
insertTempReading(obj.time, obj.value);
|
|
}
|
|
busEmitter.on('saveTempData', sendSocketHandler);
|