});
/* 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;
});
+/* 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 = [];