-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
69 lines (55 loc) · 1.78 KB
/
server.js
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
var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
var port = process.env.PORT || 3000;
var mysql = require('mysql');
var users = {};
// Mysql connection
var con = mysql.createConnection({
host: "127.0.0.1",
user: "root",
password: "",
database: "socket_chat",
debug: false,
});
con.connect(function(err) {
if (err) throw err;
//console.log("Connected!");
});
app.get('/', function(req, res){
res.sendFile(__dirname + '/index.html');
});
io.on('connection', function(socket){
socket.on('chat message', function(msg){
if(msg.send_to == '') {
io.emit('chat message', '<strong>' + msg.send_from + ' say:</strong> ' + msg.message);
} else {
socket.broadcast.to(msg.send_to).emit('chat message', '<strong>' + msg.send_from + ' say (private):</strong> ' + msg.message);
socket.emit('chat message', '<strong>' + msg.send_from + ' say (private):</strong> ' + msg.message);
}
console.log(msg);
var sql = "INSERT INTO messages (id, message) VALUES ('', '" + msg.message + "')";
con.query(sql, function (err, result) {
if (err) throw err;
console.log("Record inserted");
});
});
socket.on('name', function(name){
socket.broadcast.emit('name', name);
users[socket.id] = name;
socket.emit('set_id', { id: socket.id });
io.emit('online', { users: users });
});
// Socket connected and disconnected
/*socket.on('connect', function () {
socket.emit('online', { users: users, id: socket.id });
});*/
socket.on('disconnect', function () {
socket.broadcast.emit('offline', users[socket.id]);
delete users[socket.id];
io.emit('online', { users: users });
});
});
http.listen(port, function(){
console.log('listening on *:' + port);
});