X-Git-Url: https://git.auder.net/?a=blobdiff_plain;f=routes%2Fall.js;h=b2318135823d4d5a5b0956e76ab926003aa53410;hb=9a3c9f790aa28fd4708faefe41b4624173922c8e;hp=b1e0fda3096732862bdd5ecc511698f31b8388e3;hpb=7931e479adf93c87771ded1892a0873af72ae46d;p=vchess.git diff --git a/routes/all.js b/routes/all.js index b1e0fda3..b2318135 100644 --- a/routes/all.js +++ b/routes/all.js @@ -5,6 +5,33 @@ const sqlite3 = require('sqlite3');//.verbose(); const db = new sqlite3.Database('db/vchess.sqlite'); const sanitizeHtml = require('sanitize-html'); +const supportedLang = ["fr","en"]; +function selectLanguage(req, res) +{ + // If preferred language already set: + if (!!req.cookies["lang"]) + return req.cookies["lang"]; + + // Else: search and set it + const langString = req.headers["accept-language"]; + let langArray = langString + .replace(/;q=[0-9.]+/g, "") //priority + .replace(/-[A-Z]+/g, "") //region (skipped for now...) + .split(",") //may have some duplicates, but removal is too costly + let bestLang = "en"; //default: English + for (let lang of langArray) + { + if (supportedLang.includes(lang)) + { + bestLang = lang; + break; + } + } + // Cookie expires in 183 days (expressed in milliseconds) + res.cookie('lang', bestLang, { maxAge: 183*24*3600*1000 }); + return bestLang; +} + // Home router.get('/', function(req, res, next) { db.serialize(function() { @@ -13,7 +40,9 @@ router.get('/', function(req, res, next) { return next(err); res.render('index', { title: 'club', - variantArray: variants, //JSON.stringify(variants) + variantArray: variants, + lang: selectLanguage(req, res), + languages: supportedLang, }); }); }); @@ -48,7 +77,8 @@ router.get("/:vname([a-zA-Z0-9]+)", (req,res,next) => { router.get("/rules/:variant([a-zA-Z0-9]+)", (req,res) => { if (!req.xhr) return res.json({errmsg: "Unauthorized access"}); - res.render("rules/" + req.params["variant"]); + const lang = selectLanguage(req, res); + res.render("rules/" + req.params["variant"] + "/" + lang); }); // Fetch 10 previous or next problems (AJAX) @@ -69,12 +99,13 @@ router.post("/problems/:variant([a-zA-Z0-9]+)", (req,res) => { const timestamp = Date.now(); // Sanitize them const fen = req.body["fen"]; - if (!fen.match(/^[a-zA-Z0-9 /]*$/)) + if (!fen.match(/^[a-zA-Z0-9, /-]*$/)) return res.json({errmsg: "Bad characters in FEN string"}); const instructions = sanitizeHtml(req.body["instructions"]); const solution = sanitizeHtml(req.body["solution"]); db.serialize(function() { - let stmt = db.prepare("INSERT INTO Problems VALUES (?,?,?,?,?)"); + let stmt = db.prepare("INSERT INTO Problems " + + "(added,variant,fen,instructions,solution) VALUES (?,?,?,?,?)"); stmt.run(timestamp, vname, fen, instructions, solution); stmt.finalize(); });