-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathserver.js
More file actions
87 lines (68 loc) · 3.01 KB
/
server.js
File metadata and controls
87 lines (68 loc) · 3.01 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
var express = require('express');
var socket = require('socket.io');
var fs = require('fs');
// ----------- creating WR object to use
var waterrower = require('./waterrower.js');
// -----------------------------------------------------------------
// ------------- web server + socket setup + file backup -----------
// -----------------------------------------------------------------
// start webserver and set default directory
var app = express();
var server = app.listen(3000);
app.use(express.static('public'));
//setup socket connections (sever side)
var io = socket(server);
//function to handle connections
io.sockets.on('connection', newConnection);
function newConnection(socket) {
var collectData = []; // data object collecting data
var incomSocketID; // saving socketID to save session data
if (io.sockets.connected[socket.id]) {
console.log('new connection id=' + socket.id);
incomSocketID = socket.id;
//passing SocketID to allow messaging of Stroke Start/Stroke end event
waterrower.putSocketid(io, socket.id);
//console.log("server io:" + io);
}
console.log('amount of total connections' + io.engine.clientsCount);
// start to emit to inbound socket
setInterval(function() {
if (io.sockets.connected[socket.id]) {
jsonDate = (new Date()).toJSON();
// getting recorded data from waterrower object --------------
var record=waterrower.getRecord();
var payload = {
"timestamp": jsonDate,
"watts": record['watts'],
"distance": record['distance'],
"totalStroke": record['totalStroke'],
"iSpeed": record['iSpeed'],
"aSpeed": record['aSpeed'],
"hRate": record['hRate'],
"strokeRate": record['strokeRate']
}
// faking rower data ------------------------------------------
// var payload = {
// "timestamp": jsonDate,
// "watts": Math.round(Math.random()*200),
// "distance": 0,
// "totalStroke": 0,
// "iSpeed": Math.round(Math.random()*1.5),
// "aSpeed":Math.round(Math.random()*2),
// "hRate": Math.round(Math.random()*185),
// "strokeRate": Math.round(Math.random()*30)
// }
io.sockets.connected[socket.id].emit('WR', payload);
collectData.push(payload);
};
// end ---- actual rowing data capture
}, 1000);
socket.on('disconnect', function(){
console.log('user disconnected');
// dump data collected into a JSON file
var json = JSON.stringify(collectData); // dump all payload
var output = fs.writeFile('tmp/'+incomSocketID+'.json', json, 'utf8'); // need to add callback fct.
console.log("data backuped ")
delete incomSocketID;
});
}