diff options
| author | Mohammad Amoush <mohammad_amoush@brown.edu> | 2019-10-20 17:00:06 -0400 |
|---|---|---|
| committer | Mohammad Amoush <mohammad_amoush@brown.edu> | 2019-10-20 17:00:06 -0400 |
| commit | f5fc9d12c2843d6d9241045150983d30e4eaa4d1 (patch) | |
| tree | 8f5ed54b40f8eb7f8e83be6e06cf0917c670de8e /src/server | |
| parent | c11ecfb40021d108ee1d035637fac08976948095 (diff) | |
Server side pretty much done for 2 person call
Diffstat (limited to 'src/server')
| -rw-r--r-- | src/server/Message.ts | 10 | ||||
| -rw-r--r-- | src/server/index.ts | 46 |
2 files changed, 52 insertions, 4 deletions
diff --git a/src/server/Message.ts b/src/server/Message.ts index 7b72b693e..60ffa215f 100644 --- a/src/server/Message.ts +++ b/src/server/Message.ts @@ -42,6 +42,11 @@ export interface Diff extends Reference { readonly diff: any; } +export interface RoomMessage { + readonly message: string; + readonly room: string; +} + export namespace MessageStore { export const Foo = new Message<string>("Foo"); export const Bar = new Message<string>("Bar"); @@ -58,5 +63,8 @@ export namespace MessageStore { export const YoutubeApiQuery = new Message<YoutubeQueryInput>("Youtube Api Query"); export const DeleteField = new Message<string>("Delete field"); export const DeleteFields = new Message<string[]>("Delete fields"); - export const NotifyRoommates = new Message<string>("Notify Roommates"); + export const NotifyRoommates = new Message<RoomMessage>("Notify Roommates"); + export const HangUpCall = new Message<string>("bye"); + + } diff --git a/src/server/index.ts b/src/server/index.ts index 6b884d099..b37822eec 100644 --- a/src/server/index.ts +++ b/src/server/index.ts @@ -24,7 +24,7 @@ import { getForgot, getLogin, getLogout, getReset, getSignup, postForgot, postLo import { DashUserModel } from './authentication/models/user_model'; import { Client } from './Client'; import { Database } from './database'; -import { MessageStore, Transferable, Types, Diff, YoutubeQueryTypes as YoutubeQueryType, YoutubeQueryInput } from "./Message"; +import { MessageStore, Transferable, Types, Diff, YoutubeQueryTypes as YoutubeQueryType, YoutubeQueryInput, RoomMessage } from "./Message"; import { RouteStore } from './RouteStore'; import v4 = require('uuid/v4'); const app = express(); @@ -777,6 +777,10 @@ server.on("connection", function (socket: Socket) { Utils.AddServerHandlerCallback(socket, MessageStore.GetRefField, GetRefField); Utils.AddServerHandlerCallback(socket, MessageStore.GetRefFields, GetRefFields); Utils.AddServerHandler(socket, MessageStore.NotifyRoommates, message => HandleRoommateNotification(socket, message)); + Utils.AddServerHandler(socket, MessageStore.HangUpCall, message => HandleHangUp(socket, message)); + Utils.AddRoomHandler(socket, "create or join", HandleCreateOrJoin); + + }); @@ -840,9 +844,45 @@ function HandleYoutubeQuery([query, callback]: [YoutubeQueryInput, (result?: any } } -function HandleRoommateNotification(socket: Socket, message: String) { - socket.broadcast.emit('message', message); +function HandleRoommateNotification(socket: Socket, message: RoomMessage) { + //socket.broadcast.emit('message', message); + server.sockets.in(message.room).emit('message', message.message); + +} + +function HandleCreateOrJoin(socket: io.Socket, room: string) { + console.log("Received request to create or join room " + room); + + + let clientsInRoom = server.sockets.adapter.rooms[room]; + let numClients = clientsInRoom ? Object.keys(clientsInRoom.sockets).length : 0; + console.log('Room ' + room + ' now has ' + numClients + ' client(s)'); + + + if (numClients === 0) { + socket.join(room); + console.log('Client ID ' + socket.id + ' created room ' + room); + socket.emit('created', room, socket.id); + + } else if (numClients === 1) { + console.log('Client ID ' + socket.id + ' joined room ' + room); + server.sockets.in(room).emit('join', room); + socket.join(room); + socket.emit('joined', room, socket.id); + server.sockets.in(room).emit('ready'); + + } else { + socket.emit('full', room); + } + + + + + +} +function HandleHangUp(socket: io.Socket, message: string) { + console.log("Receive bye from someone"); } const credentialsPath = path.join(__dirname, "./credentials/google_docs_credentials.json"); |
