Files
NodeBB/src/websockets.js

193 lines
5.0 KiB
JavaScript
Raw Normal View History

2013-05-02 15:45:19 -04:00
var SocketIO = require('socket.io').listen(global.server,{log:false}),
2013-04-24 16:42:12 -04:00
cookie = require('cookie'),
connect = require('connect'),
config = require('../config.js');
2013-04-22 16:51:32 +00:00
(function(io) {
2013-04-24 16:42:12 -04:00
var modules = null,
users = {},
rooms = {
'users' : {},
'anonymous' : {}
};
2013-04-22 17:09:40 +00:00
global.io = io;
2013-04-22 16:51:32 +00:00
module.exports.init = function() {
modules = global.modules;
}
2013-04-24 16:42:12 -04:00
// Adapted from http://howtonode.org/socket-io-auth
io.set('authorization', function(handshakeData, accept) {
if (handshakeData.headers.cookie) {
handshakeData.cookie = cookie.parse(handshakeData.headers.cookie);
handshakeData.sessionID = connect.utils.parseSignedCookie(handshakeData.cookie['express.sid'], config.secret);
2013-04-24 16:42:12 -04:00
if (handshakeData.cookie['express.sid'] == handshakeData.sessionID) {
return accept('Cookie is invalid.', false);
}
} else {
// No cookie sent
return accept('No cookie transmitted', false);
}
// Otherwise, continue unimpeded.
2013-05-02 15:45:19 -04:00
var sessionID = handshakeData.sessionID;
global.modules.user.get_uid_by_session(sessionID, function(userId) {
if (userId)
{
users[sessionID] = userId;
}
else
users[sessionID] = 0;
accept(null, true);
});
2013-04-24 16:42:12 -04:00
});
2013-04-22 16:51:32 +00:00
io.sockets.on('connection', function(socket) {
2013-05-02 15:45:19 -04:00
var hs = socket.handshake;
var uid = users[hs.sessionID];
2013-04-22 16:51:32 +00:00
if (DEVELOPMENT === true) {
// refreshing templates
modules.templates.init();
}
2013-05-05 18:40:04 -04:00
/*process.on('uncaughtException', function(err) {
// handle the error safely
console.log("error message "+err);
socket.emit('event:consolelog',{type:'uncaughtException', stack:err.stack, error:err.toString()});
2013-05-05 18:40:04 -04:00
});*/
2013-04-22 16:51:32 +00:00
socket.emit('event:connect', {status: 1});
2013-04-22 16:51:32 +00:00
2013-05-02 15:45:19 -04:00
socket.on('disconnect', function() {
console.log('Got disconnect! SESSION ID : '+hs.sessionID+' USER ID : '+uid);
delete users[hs.sessionID];
console.log(users);
});
socket.on('event:enter_room', function(data) {
if (data.leave !== null) socket.leave (data.leave);
socket.join(data.enter);
rooms.users[data.enter] = rooms.users[data.enter] || {};
if (uid) {
rooms.users[data.enter][uid] = true;
if (rooms.users[data.leave]) {
delete rooms.users[data.leave][uid];
}
} else {
rooms.anonymous[data.enter] = (rooms.anonymous[data.enter] || 0) + 1;
rooms.anonymous[data.leave] = rooms.anonymous[data.leave] || 0;
}
var uids = Object.keys(rooms.users[data.enter] || {});
if (uids.length == 0) {
socket.emit('api:get_users_in_room', {
usernames: [],
uids: [],
anonymous: rooms.anonymous[data.enter] || 0
});
}
modules.user.get_usernames_by_uids(uids, function(usernames) {
socket.emit('api:get_users_in_room', {
usernames: usernames,
uids: uids,
anonymous: rooms.anonymous[data.enter] || 0
});
});
});
2013-04-22 16:51:32 +00:00
// BEGIN: API calls (todo: organize)
// julian: :^)
2013-05-05 17:38:08 -04:00
socket.on('api:updateHeader', function(data) {
if(uid) {
modules.user.getUserFields(uid, data.fields, function(fields) {
fields.uid = uid;
socket.emit('api:updateHeader', fields);
});
}
else {
socket.emit('api:updateHeader', {
uid:0,
username: "Anonymous User",
email: '',
picture: 'http://www.gravatar.com/avatar/d41d8cd98f00b204e9800998ecf8427e?s=24'
});
}
2013-05-02 16:28:04 -04:00
});
socket.on('api:user.getNameByUid', function(data) {
modules.user.get_username_by_uid(data.uid, function(data){
socket.emit('api:user.getNameByUid', data);
});
});
2013-04-22 16:51:32 +00:00
socket.on('user.exists', function(data) {
modules.user.exists(socket, data.username);
2013-04-22 16:51:32 +00:00
});
socket.on('user.count', function(data) {
modules.user.count(socket, data);
2013-04-22 16:51:32 +00:00
});
socket.on('user.latest', function(data) {
modules.user.latest(socket, data);
2013-04-22 19:01:45 +00:00
});
socket.on('user.email.exists', function(data) {
modules.user.email.exists(socket, data.email);
});
socket.on('user:reset.send', function(data) {
modules.user.reset.send(socket, data.email);
});
socket.on('user:reset.valid', function(data) {
modules.user.reset.validate(socket, data.code);
});
2013-04-23 23:28:34 -04:00
socket.on('user:reset.commit', function(data) {
modules.user.reset.commit(socket, data.code, data.password);
2013-04-23 23:28:34 -04:00
});
socket.on('api:topics.post', function(data) {
modules.topics.post(socket, uid, data.title, data.content);
});
2013-05-01 20:58:36 +00:00
socket.on('api:posts.reply', function(data) {
modules.posts.reply(socket, data.topic_id, uid, data.content);
2013-05-01 20:58:36 +00:00
});
socket.on('api:user.active.get', function() {
modules.user.active.get();
});
2013-05-01 16:14:09 +00:00
2013-05-03 17:52:20 +00:00
socket.on('api:posts.favourite', function(data) {
modules.posts.favourite(io, data.pid, data.room_id, uid);
});
socket.on('api:posts.unfavourite', function(data) {
modules.posts.unfavourite(io, data.pid, data.room_id, uid);
});
2013-05-03 17:52:20 +00:00
2013-05-01 16:14:09 +00:00
socket.on('api:user.active.get_record', function() {
modules.user.active.get_record(socket);
2013-05-01 16:14:09 +00:00
});
2013-04-22 16:51:32 +00:00
});
}(SocketIO));