if (!!clients[sid])
return socket.send(JSON.stringify({code:"duplicate"}));
clients[sid] = {sock: socket, page: query["page"]};
- const notifyRoom = (page,code,obj) => {
+ const notifyRoom = (page,code,obj={},excluded=[]) => {
Object.keys(clients).forEach(k => {
+ if (k in excluded)
+ return;
if (k != sid && clients[k].page == page)
{
clients[k].sock.send(JSON.stringify(Object.assign(
- {code:code}, obj)));
+ {code:code, from:sid}, obj)));
}
});
};
- notifyRoom(query["page"],"connect",{sid:sid});
+ notifyRoom(query["page"], "connect"); //Hall or Game
+ if (query["page"].indexOf("/game/") >= 0)
+ notifyRoom("/", "connect"); //notify main hall
socket.on("message", objtxt => {
let obj = JSON.parse(objtxt);
if (!!obj.target && !clients[obj.target])
case "pollclients":
const curPage = clients[sid].page;
socket.send(JSON.stringify({code:"pollclients",
- sockIds: Object.keys(clients).filter(k =>
- k != sid && clients[k].page == curPage)}));
+ sockIds: Object.keys(clients).filter(k => k != sid &&
+ (clients[k].page == curPage ||
+ // Consider that people playing are in Hall too:
+ (curPage == "/" && clients[k].page.indexOf("/game/") >= 0))
+ )}));
break;
case "pagechange":
- notifyRoom(clients[sid].page, "disconnect", {sid:sid});
+ notifyRoom(clients[sid].page, "disconnect");
+ if (clients[sid].page.indexOf("/game/") >= 0)
+ notifyRoom("/", "disconnect");
clients[sid].page = obj.page;
- notifyRoom(obj.page, "connect", {sid:sid});
+ notifyRoom(obj.page, "connect");
+ if (obj.page.indexOf("/game/") >= 0)
+ notifyRoom("/", "connect");
break;
case "askidentity":
clients[obj.target].sock.send(JSON.stringify(
clients[obj.target].sock.send(JSON.stringify(
{code:"askchallenge",from:sid}));
break;
- case "askgame":
- clients[obj.target].sock.send(JSON.stringify(
- {code:"askgame",from:sid}));
+ case "askgames":
+ // Check all clients playing, and send them a "askgame" message
+ Object.keys(clients).forEach(k => {
+ if (k != sid && clients[k].page.indexOf("/game/") >= 0)
+ {
+ clients[k].sock.send(JSON.stringify(
+ {code:"askgame", from: sid}));
+ }
+ });
break;
case "identity":
clients[obj.target].sock.send(JSON.stringify(
{code:"challenge", chall:obj.chall, from:sid}));
break;
case "game":
- clients[obj.target].sock.send(JSON.stringify(
- {code:"game", game:obj.game, from:sid}));
+ if (!!obj.target)
+ {
+ clients[obj.target].sock.send(JSON.stringify(
+ {code:"game", game:obj.game, from:sid}));
+ }
+ else
+ {
+ // Notify all room except opponent and me:
+ notifyRoom("/", "game", {game:obj.game}, [obj.oppsid]);
+ }
break;
case "newchat":
- notifyRoom(query["page"], "newchat",
- {msg:obj.msg, name:obj.name, sid:sid})
+ notifyRoom(query["page"], "newchat", {msg:obj.msg, name:obj.name});
break;
// TODO: WebRTC instead in this case (most demanding?)
case "newmove":
clients[obj.target].sock.send(JSON.stringify(
- {code:"newmove",move:obj.move}));
+ {code:"newmove", move:obj.move}));
break;
case "lastate":
clients[obj.target].sock.send(JSON.stringify(
const page = clients[sid].page;
delete clients[sid];
notifyRoom(page, "disconnect");
+ if (page.indexOf("/game/") >= 0)
+ notifyRoom("/", "disconnect"); //notify main hall
});
});
}