summaryrefslogtreecommitdiff
path: root/server/chat
diff options
context:
space:
mode:
Diffstat (limited to 'server/chat')
-rw-r--r--server/chat/chat.js183
-rw-r--r--server/chat/workers/messageParser.js145
2 files changed, 328 insertions, 0 deletions
diff --git a/server/chat/chat.js b/server/chat/chat.js
new file mode 100644
index 0000000..a1242c2
--- /dev/null
+++ b/server/chat/chat.js
@@ -0,0 +1,183 @@
+var Config = require('../../config/chat.js'),
+ conf = new Config(),
+ io = require('socket.io').listen(conf.port),
+ url = require('url'),
+ http = require("http"),
+ Worker = require('webworker-threads').Worker;
+
+io.set('transports', ['websocket']);
+io.enable('browser client minification');
+io.enable('browser client etag');
+io.enable('browser client gzip');
+io.set('log level', 1);
+
+var Chat = function(socket){
+ function handleSet(data){
+ socket.handle=data.handle;
+ userOnline();
+ }
+
+ function userOnline(){
+ socket.broadcast.emit(
+ 'online',
+ {
+ id : socket.id,
+ handle : socket.handle
+ }
+ )
+ }
+
+ function userOffline(){
+ if(!socket.handle)
+ return;
+
+ socket.broadcast.emit(
+ 'offline',
+ {
+ id : socket.id,
+ handle : socket.handle
+ }
+ )
+ }
+
+ function joinRoom(data) {
+ socket.join(
+ data.room
+ );
+ socket.room=data.room;
+ //Emit event to room that someone has joined
+ }
+
+ function leaveRoom(data) {
+ socket.leave(
+ data.room
+ );
+ socket.room=null;
+ //Emit event to room that someone has left
+ }
+
+ function toRoom(data) {
+ if(!socket.room)
+ return;
+
+ data.handle=socket.handle;
+
+ var messageParser = new Worker(
+ __dirname+'/workers/messageParser.js'
+ );
+
+ messageParser.onmessage=function(msg){
+ if(msg.data.fetchAudio){
+
+ http.get(
+ msg.data.fetchAudio,
+ function(response) {
+ var body='';
+
+ response.setEncoding('binary');
+ response.on(
+ 'data',
+ function (data) {
+ body+=data;
+ }
+ );
+ response.on(
+ 'end',
+ function(){
+ io.sockets.in(
+ socket.room
+ ).emit(
+ 'playlist.add',
+ {
+ url : msg.data.fetchAudio,
+ file: new Buffer(body,'binary').toString('base64')
+ }
+ );
+ }
+ );
+ }
+ );
+ return;
+ }
+ data.msg=msg.data;
+ io.sockets.in(
+ socket.room
+ ).emit(
+ 'room.chat',
+ data
+ );
+ };
+ messageParser.postMessage(
+ {
+ msg : data.msg
+ }
+ );
+
+ }
+
+ function toUser(data) {
+ io.sockets.manager[data.to.id].emit(
+ 'user.message',
+ {
+ from:{
+ id : socket.id,
+ handle : socket.handle
+ },
+ data:data
+ }
+ )
+ }
+
+ return {
+ set : {
+ handle : handleSet
+ },
+ room : {
+ join : joinRoom,
+ leave: leaveRoom,
+ chat : toRoom
+ },
+ user : {
+ online : userOnline,
+ offline : userOffline,
+ chat : toUser
+ }
+ }
+}
+
+io.sockets.on(
+ 'connection',
+ function (socket) {
+ var chat=new Chat(socket);
+
+ socket.on(
+ 'set.handle',
+ chat.set.handle
+ );
+
+ socket.on(
+ 'room.join',
+ chat.room.join
+ );
+
+ socket.on(
+ 'room.leave',
+ chat.room.leave
+ );
+
+ socket.on(
+ 'room.chat',
+ chat.room.chat
+ );
+
+ socket.on(
+ 'user.chat',
+ chat.user.chat
+ );
+
+ socket.on(
+ 'disconnect',
+ chat.user.offline
+ );
+ }
+); \ No newline at end of file
diff --git a/server/chat/workers/messageParser.js b/server/chat/workers/messageParser.js
new file mode 100644
index 0000000..3831f0e
--- /dev/null
+++ b/server/chat/workers/messageParser.js
@@ -0,0 +1,145 @@
+var URLExp = /(https?:\/\/[^\s,]+)/ig,
+ emailExp= /\"([^\"]+)\"\s+\<([^\>]+)\>/ig;
+
+var types={
+ img : {
+ jpg : true,
+ jpeg: true,
+ gif : true,
+ png : true,
+ bmp : true,
+ svg : true,
+ tiff: true,
+ webp: true,
+ wbmp: true
+ },
+ audio : {
+ mp3 : true,
+ wav : true,
+ aac : true
+ },
+ video : {
+ ogg : true,
+ webm: true,
+ mp4 : true
+ }
+}
+
+function convertToHTML(url){
+ if(url.match('@'))
+ return [
+ '<a href="maito:',
+ url,
+ '">',
+ url,
+ '</a>'
+ ].join('');
+
+ var data=url.split('.');
+
+ var extention=data.slice(-1);
+
+ if(types.img[extention])
+ return formatToImg(url,extention);
+
+ if(types.video[extention])
+ return formatToVideo(url,extention);
+
+ if(types.audio[extention]){
+ postMessage(
+ {
+ fetchAudio:url
+ }
+ );
+ return formatToAudio(url);
+ }
+
+ return formatToIFrame(url);
+}
+
+function formatToImg(url,extention){
+ return [
+ '<img class="message-img" src="',
+ url,
+ '"/>'
+ ].join('');
+}
+
+function formatToAudio(url,extention){
+ return [
+ '<hr>',
+ '<audio class="message-audio" controls><source src="',
+ url,
+ '"></audio>',
+ '<hr>'
+ ].join('');
+}
+
+function formatToVideo(url,extention){
+ return [
+ '<hr>',
+ '<video class="message-video" controls><source src="',
+ url,
+ '"></video>',
+ '<hr>'
+ ].join('');
+}
+
+function formatToEmail(url){
+ return [
+ '<a class="message-email" href="maito:',
+ url,
+ '">',
+ url,
+ '</a>'
+ ].join('');
+}
+
+function formatToLink(url){
+ return [
+ '<a class="message-link" href="',
+ url,
+ '">',
+ url,
+ '</a>'
+ ].join('');
+}
+
+function formatToIFrame(url){
+ return [
+ '<hr>',
+ url,
+ '<iFrame class="message-iframe" src="',
+ url,
+ '"></iFrame>',
+ '<hr>'
+ ].join('');
+}
+
+onmessage=function(data){
+ var msg = data.data.msg,
+ urls = msg.match(URLExp),
+ emails = msg.match(emailExp);
+
+ if(!urls){
+ postMessage(msg);
+ return;
+ }
+
+ for(i in urls){
+ msg=msg.replace(
+ urls[i],
+ convertToHTML(urls[i])
+ )
+ }
+
+ for(i in emails){
+ msg=msg.replace(
+ emails[i],
+ convertToHTML(emails[i])
+ )
+ }
+
+ postMessage(msg);
+ close();
+} \ No newline at end of file