summaryrefslogtreecommitdiff
path: root/routes/login.js
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--routes/login.js44
1 files changed, 44 insertions, 0 deletions
diff --git a/routes/login.js b/routes/login.js
new file mode 100644
index 0000000..9b04324
--- /dev/null
+++ b/routes/login.js
@@ -0,0 +1,44 @@
+import express from "express";
+import { check, validationResult, matchedData } from "express-validator";
+
+import makeLoginController from "../controllers/login.js"
+import bodyParser from "../middlewares/formParser.js";
+import session from "../middlewares/sessions.js";
+
+const router = express.Router();
+router.use(session);
+
+router.get("/", (req, res) => {
+ if (req.session.userId) {
+ return res.redirect(302, "/play");
+ }
+ return res.render("login", makeLoginController());
+});
+
+const checkUsername = check("username")
+ .trim()
+ .matches(/^[a-z][-a-z0-9_]+$/i)
+ .withMessage("Un identifiant d'au moins deux charactères est requis.");
+const checkPassword = check("password")
+ .isStrongPassword()
+ .withMessage("Veuillez utiliser un mot de passe d'au moins 8 caractères contenant au moins une minuscule, majuscule, chiffre et charactère spécial.");
+
+router.post("/", [bodyParser, checkUsername, checkPassword], (req, res) => {
+ if (req.session.userId) {
+ return res.redirect(302, "/play");
+ }
+ let controller = makeLoginController();
+ controller.data = req.body;
+ controller.errors = validationResult(req).mapped();
+ if (Object.keys(controller.errors).length === 0) {
+ // TODO check password
+ req.session.userId = 1;
+ // TODO add an error variable for the username/password mismatch
+ }
+ if (Object.keys(controller.errors).length === 0) {
+ return res.redirect(302, "/play");
+ }
+ return res.render("login", controller);
+});
+
+export default router;