});
/* LMNO middleware to lookup the game. */
-app.use('/empires/:game_id([a-zA-Z0-9]{4})', (request, response, next) => {
+app.use('/:engine([^/]+)/:game_id([a-zA-Z0-9]{4})', (request, response, next) => {
+ const engine = request.params.engine;
const game_id = request.params.game_id;
const canon_id = lmno_canonize(game_id);
/* Redirect user to page with the canonical ID in it. */
if (game_id !== canon_id) {
- const new_url = request.originalUrl.replace("/empires/" + game_id,
- "/empires/" + canon_id);
+ const new_url = request.originalUrl.replace(`/${engine}/${game_id}`,
+ `/${engine}/${canon_id}`);
response.redirect(301, new_url);
return;
}
app.get('/logout', (request, response) => {
request.session.user = undefined;
+ request.session.destroy();
response.send("You are now logged out.");
});
return;
});
-/* A stats page (only available to admin users) */
-app.get('/stats/', auth_admin, (request, response) => {
- let active = 0;
- let idle = 0;
+/* API to set uer profile information */
+app.put('/profile', (request, response) => {
+ const nickname = request.body.nickname;
+ if (nickname) {
+ request.session.nickname = nickname;
+ request.session.save();
+ }
+ response.send();
+});
+
+/* An admin page (only available to admin users, of course) */
+app.get('/admin/', auth_admin, (request, response) => {
+ let active = [];
+ let idle = [];
for (let id in lmno.ids) {
if (lmno.ids[id].game.clients.length)
- active++;
- else
- idle++;
+ active.push(lmno.ids[id]);
+ else
+ idle.push(lmno.ids[id]);
}
- response.send(`<html><body>Active games: ${active}.<br>
-Idle games: ${idle}</body></html>`);
+ response.render('admin.html', { test: "foobar", games: { active: active, idle: idle}});
});