mirror of
https://github.com/s00500/nodeMessageBoard.git
synced 2025-01-23 02:27:12 +00:00
Database load working
This commit is contained in:
parent
95ea248d25
commit
5c3d9216c6
40
app.js
40
app.js
@ -9,43 +9,3 @@ handle["/"] = requestHandlers.sendInterface;
|
||||
handle["/interface"] = requestHandlers.sendInterface;
|
||||
|
||||
server.start(router.route,handle,debug);
|
||||
|
||||
|
||||
|
||||
|
||||
// old app.js
|
||||
/*
|
||||
console.log("hello world\r");
|
||||
var port = 3000;
|
||||
var express = require('express')
|
||||
var app = express()
|
||||
|
||||
app.get('/', function (req, res) {
|
||||
res.send('Hello World')
|
||||
});
|
||||
|
||||
app.listen(port, function () {
|
||||
console.log('Example app listening on port '+port+'!');
|
||||
});
|
||||
|
||||
var serialport = require("serialport");
|
||||
var SerialPort = serialport.SerialPort;
|
||||
var serialPort = new SerialPort("/dev/tty.usbmodemFD121", {
|
||||
baudrate: 19200,
|
||||
parser: serialport.parsers.readline("\n")
|
||||
});
|
||||
|
||||
|
||||
serialPort.on("open", function () {
|
||||
console.log('open');
|
||||
serialPort.on("data", function (data) {
|
||||
console.log("here: "+data);
|
||||
|
||||
app.get('/', function (req, res) {
|
||||
res.send(data)
|
||||
})
|
||||
});
|
||||
|
||||
serialPort.write("AT+CPIN?\r");
|
||||
});
|
||||
*/
|
||||
|
38
board.html
38
board.html
@ -49,23 +49,20 @@
|
||||
{
|
||||
iosocket = io.connect();
|
||||
iosocket.on('onconnection', function(value) {
|
||||
pollOneH = value.pollOneValue/2; // recieve start poll value from server
|
||||
initButton();
|
||||
|
||||
// recieve changed values by other client from server
|
||||
iosocket.on('updateData', function(recievedData) {
|
||||
pollOneH = recievedData.pollOneValue/2; // recieve start poll value from server
|
||||
iosocket.on('debugMessage', function(message) {
|
||||
alert(message);
|
||||
});
|
||||
|
||||
iosocket.on('newMessage', function(message) {
|
||||
var date = new Date();
|
||||
|
||||
iosocket.on('newMessage', function(number,message) {
|
||||
var mainTable = document.getElementById("mainTable");
|
||||
var newRow = mainTable.insertRow(mainTable.rows.length);
|
||||
|
||||
var dateCell = newRow.insertCell(0);
|
||||
var textCell = newRow.insertCell(1);
|
||||
dateCell.innerHTML = date.toLocaleString();
|
||||
var numberCell = newRow.insertCell(1);
|
||||
var textCell = newRow.insertCell(2);
|
||||
dateCell.innerHTML = "Insert serverdate";
|
||||
numberCell.innerHTML = number;
|
||||
textCell.innerHTML = message;
|
||||
});
|
||||
});
|
||||
@ -74,14 +71,17 @@
|
||||
|
||||
function initButton()
|
||||
{
|
||||
$( "#check" ).button();
|
||||
$("#check").button();
|
||||
}
|
||||
|
||||
window.onload = function() {
|
||||
initSocketIO();
|
||||
iosocket.emit('getLastMessages',10);
|
||||
};
|
||||
|
||||
$(document).ready(function() {
|
||||
//request last messages from server
|
||||
|
||||
$('#check').click(function() {
|
||||
toggleVal += 1;
|
||||
toggleVal %= 2;
|
||||
@ -91,23 +91,19 @@
|
||||
</script>
|
||||
</head>
|
||||
<body>
|
||||
<div id="rData">
|
||||
<div style="text-align:center;">
|
||||
<h2>Data from Sim900</h2>
|
||||
|
||||
<table id="mainTable" border="1">
|
||||
<table id="mainTable" border="1" align="center">
|
||||
<tr>
|
||||
<td>Uhrzeit</td><td>Nachricht</td>
|
||||
<td>Uhrzeit</td><td>Nummer</td><td>Nachricht</td>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
</div>
|
||||
<div id="sData">
|
||||
<br>
|
||||
<br>
|
||||
<h2>Debug functions</h2>
|
||||
<div id="btnHolder">
|
||||
<input type="checkbox" id="check" value="toggle"/><label for="check">Toggle LED</label>
|
||||
<input type="checkbox" id="check" value="toggle"/><label for="check">Send AT</label>
|
||||
</div>
|
||||
<p id="sliderTxt">LED Dimmer</p>
|
||||
<div id="slider"></div>
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
|
30
server.js
30
server.js
@ -3,6 +3,9 @@ http = require('http'),
|
||||
socketio = require('socket.io'),
|
||||
url = require("url"),
|
||||
serialport = require("serialport");
|
||||
low = require('lowdb'),
|
||||
storage = require('lowdb/file-async'),
|
||||
db = low('db.json', { storage });
|
||||
|
||||
var SerialPort = serialport.SerialPort;
|
||||
|
||||
@ -10,6 +13,7 @@ var socketServer;
|
||||
var serialPort;
|
||||
var portName = '/dev/tty.usbmodemFD121'; //change this to your Arduino port
|
||||
var sendData = "";
|
||||
var numberStringRecieved = "";
|
||||
var numberRecieved = "";
|
||||
|
||||
// handle contains locations to browse to (vote and poll); pathnames.
|
||||
@ -45,10 +49,22 @@ function initSocketIO(httpServer,debug)
|
||||
socketServer.on('update', function(data) {
|
||||
socket.emit('updateData',{pollOneValue:data});
|
||||
});
|
||||
|
||||
socket.on('sendAT', function(data) {
|
||||
serialPort.write('AT\r');
|
||||
console.log('sending AT...');
|
||||
});
|
||||
|
||||
socket.on('getLastMessages', function(number) {
|
||||
console.log('retrieving messages');
|
||||
var numbers = db('messages').chain().takeRight(number).map('number').value();
|
||||
var messages = db('messages').chain().takeRight(number).map('message').value();
|
||||
|
||||
for(var i = 0; i < messages.length; i++){
|
||||
socket.emit('newMessage',numbers[i],messages[i]);
|
||||
}
|
||||
});
|
||||
|
||||
});
|
||||
}
|
||||
|
||||
@ -70,16 +86,20 @@ function serialListener(debug)
|
||||
console.log("\r"); //+data.length
|
||||
// send the incoming data to clients using the socket.
|
||||
if(data.startsWith("+CMT:")){ // if message ok
|
||||
numberRecieved = data;
|
||||
numberStringRecieved = data;
|
||||
numberRecieved = data.substring(data.indexOf('+CMT: "') + 7, data.indexOf('",'));
|
||||
} else if (data.length > 1) {
|
||||
//add a new message to the board directly
|
||||
|
||||
if(numberRecieved){
|
||||
console.log("emit");
|
||||
socketServer.emit('newMessage', numberRecieved+" "+data);
|
||||
//console.log("emit");
|
||||
db('messages').push({ numberString: numberStringRecieved,number: numberRecieved, message: data });
|
||||
//add a new message to the board directly
|
||||
socketServer.emit('newMessage', numberRecieved,data);
|
||||
numberStringRecieved = null;
|
||||
numberRecieved = null;
|
||||
}
|
||||
else {
|
||||
console.log("nothing");
|
||||
//console.log("nothing");
|
||||
}
|
||||
} else {
|
||||
//debugMessages trigger an alert on the clients
|
||||
|
Loading…
x
Reference in New Issue
Block a user