diff options
author | Tor Andersson <tor@ccxvii.net> | 2022-03-08 18:56:06 +0100 |
---|---|---|
committer | Tor Andersson <tor@ccxvii.net> | 2022-03-08 18:56:22 +0100 |
commit | fac8af2866827e2b2b27d8efbab8e24b06739e56 (patch) | |
tree | f0c687532c79e8479c74e7adc08ce3e534d25e12 /server.js | |
parent | bd74b662fbac99a0b3987e454fdc129784820992 (diff) | |
download | server-fac8af2866827e2b2b27d8efbab8e24b06739e56.tar.gz |
Allow "query" calls as Observer and during replays.
Diffstat (limited to 'server.js')
-rw-r--r-- | server.js | 29 |
1 files changed, 18 insertions, 11 deletions
@@ -1759,7 +1759,7 @@ function on_restart(socket, scenario) { } } -function handle_message(socket, cmd, arg) { +function handle_player_message(socket, cmd, arg) { switch (cmd) { case 'action': on_action(socket, arg[0], arg[1]); break; case 'query': on_query(socket, arg); break; @@ -1773,6 +1773,12 @@ function handle_message(socket, cmd, arg) { } } +function handle_observer_message(socket, cmd, arg) { + switch (cmd) { + case 'query': on_query(socket, arg); break; + } +} + wss.on('connection', (socket, req, client) => { let u = url.parse(req.url, true); if (u.pathname !== '/play-socket') @@ -1829,16 +1835,17 @@ wss.on('connection', (socket, req, client) => { broadcast_presence(socket.game_id); }); - if (socket.role !== "Observer") { - socket.on('message', (data) => { - try { - let [ cmd, arg ] = JSON.parse(data); - handle_message(socket, cmd, arg); - } catch (err) { - send_message(socket, 'error', err); - } - }); - } + socket.on('message', (data) => { + try { + let [ cmd, arg ] = JSON.parse(data); + if (socket.role !== "Observer") + handle_player_message(socket, cmd, arg); + else + handle_observer_message(socket, cmd, arg); + } catch (err) { + send_message(socket, 'error', err); + } + }); broadcast_presence(socket.game_id); send_state(socket, get_game_state(socket.game_id)); |