*
* / Serves <identifier>-game.html template
*
+ * /player Allows client to set name or team
+ *
* /events Serves a stream of events. Game can override
* the handle_events method, call super() first,
* and then have code to add custom events.
response.render(`${game.meta.identifier}-game.html`);
});
+ router.put('/player', (request, response) => {
+ const game = request.game;
+
+ game.handle_player(request, response);
+ });
+
router.get('/events', (request, response) => {
const game = request.game;
router.post('/move', (request, response) => {
const game = request.game;
const move = request.body.move;
+ const player = game.players[request.session.id];
+
+ /* Reject move if there is no player for this session. */
+ if (! player) {
+ response.json({legal: false, message: "No valid player from session"});
+ return;
+ }
- const result = game.add_move(move);
+ const result = game.add_move(player, move);
/* Feed move response back to the client. */
response.json(result);