-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathserver.js.sample
86 lines (74 loc) · 2.3 KB
/
server.js.sample
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
// FileSystem
var fs = require('fs');
// MQTT
var mqtt = require('mqtt');
// In case of MQTTS (TLS):
// var connectOptions = {
// host: "<MQTT_server_IP_or_hostname>",
// port: 8883,
// protocol: "mqtts",
// keepalive: 10,
// clientId: "test_client_01",
// protocolId: "MQTT",
// protocolVersion: 4,
// clean: true,
// reconnectPeriod: 2000,
// connectTimeout: 2000,
// cert: fs.readFileSync("ca.crt"),
// rejectUnauthorized: false,
// };
// In case of MQTT:
var connectOptions = {
host: "<MQTT_server_IP_or_hostname>",
port: 1883,
protocol: "mqtt",
keepalive: 10,
clientId: "test_client_01",
protocolId: "MQTT",
protocolVersion: 4,
clean: true,
reconnectPeriod: 2000,
connectTimeout: 2000
};
// Express HTTP Server =================================================
var express = require('express');
var app = express();
var server = require('http').createServer(app);
// Socket.io ===========================================================
var io = require('socket.io')(server);
app.get('/', function(req, res,next) {
res.sendFile(__dirname + '/public/index.html');
});
// MQTT ================================================================
var client = mqtt.connect(connectOptions);
var topic="<topic_to_subscribe>";
io.on('connection', function(socket) {
console.log('Client connected...');
socket.on('join', function(data) {
console.log('Browser says: ' + data);
socket.emit('messages', 'Hello from server');
client.subscribe(topic);
});
//handle incoming messages
client.on('message',(topic, message, packet) => {
// console.log("Topic: " + topic + " | Message: " + message);
var raw_decoded = (JSON.parse(message.toString())).object;
console.log(raw_decoded);
console.log("Topic: " + topic + " | Message: " + String(raw_decoded));
socket.emit('messages', raw_decoded);
});
});
client.on("connect",() => {
if (client.connected) {
client.publish("test", "I'm connected!");
console.log("MQTT client connected to " + connectOptions.host + ":" + connectOptions.port)
}
})
//handle errors
client.on("error",(error) => {
console.log("Can't connect" + error);
process.exit(1)
});
server.listen(4200, () => {
console.log('Server listening on *:4200');
});