1
0
Fork 0

Merge branch 'back' into 'master'

Back

See merge request LETU/LETU!6
This commit is contained in:
Ethanell 2020-10-12 23:52:29 +02:00
commit 9dd913f768
9 changed files with 71 additions and 10 deletions

6
app.js
View file

@ -1,10 +1,10 @@
let createError = require("http-errors");
let express = require("express"); let express = require("express");
let path = require("path"); let path = require("path");
let cookieParser = require("cookie-parser"); let cookieParser = require("cookie-parser");
let logger = require("morgan"); let logger = require("morgan");
let sassMiddleware = require("node-sass-middleware"); let sassMiddleware = require("node-sass-middleware");
const session = require("express-session"); const session = require("express-session");
const error = require("./routes/utils/error");
let config = process.env.NODE_ENV === "test" ? {} : require("./config/config.json"); let config = process.env.NODE_ENV === "test" ? {} : require("./config/config.json");
let indexRouter = require("./routes/index"); let indexRouter = require("./routes/index");
@ -42,8 +42,8 @@ app.use("/", indexRouter);
app.use("/login", loginRouter); app.use("/login", loginRouter);
// catch 404 and forward to error handler // catch 404 and forward to error handler
app.use((req, res, next) => { app.use((req, res) => {
next(createError(404)); return error(req, res, "Page not found", 404);
}); });
// error handler // error handler

View file

@ -43,13 +43,11 @@ module.exports = (sequelize, DataTypes) => {
}, },
firstName: { firstName: {
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: false, allowNull: false
unique: "userFullName"
}, },
lastName: { lastName: {
type: DataTypes.STRING, type: DataTypes.STRING,
allowNull: false, allowNull: false
unique: "userFullName"
}, },
passwordHash: { passwordHash: {
type: DataTypes.STRING, type: DataTypes.STRING,

View file

@ -0,0 +1,21 @@
//let socket = io.connect();
document.getElementById("register").addEventListener("submit", e=>{
e.preventDefault();
let expressionReguliere = /^(([^<>()[]\.,;:s@]+(.[^<>()[]\.,;:s@]+)*)|(.+))@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}])|(([a-zA-Z-0-9]+.)+[a-zA-Z]{2,}))$/;
let mail = document.getElementById("mailreg-input").value;
if(expressionReguliere.test(mail)) {
socket.emit("register", {
"email": mail,
"firstName": document.getElementById("firstname-input").value,
"lastName": document.getElementById("lastname-input").value,
"password": document.getElementById("passwordreg-input").value
});
}
});
socket.on("register", data=>{
if(data){
window.location.href = "/";
}
});

View file

@ -1,8 +1,8 @@
let express = require("express"); let express = require("express");
let router = express.Router(); let router = express.Router();
const sessionCheck = require("./utils/sessionCheck");
/* GET home page. */ router.get("/", sessionCheck(1), (req, res) => {
router.get("/", (req, res) => {
res.render("index", { title: "L'ETU" }); res.render("index", { title: "L'ETU" });
}); });

4
routes/utils/error.js Normal file
View file

@ -0,0 +1,4 @@
module.exports = (req, res, message, status, subMessage) => {
res.status(status || 500);
res.render("error", {message: message, error: {status: subMessage || undefined}});
};

View file

@ -0,0 +1,15 @@
let error = require("./error");
function sessionCheck(permission) {
return (req, res, next) => {
if (!req.session.user) {
req.session.lastUrl = req.originalUrl;
req.session.save(() => res.redirect("/login"));
} else if (req.session.user.permissions < permission)
return error(req, res, "Permission denied !", 403);
else
next();
}
}
module.exports = sessionCheck;

View file

@ -1,5 +1,6 @@
module.exports = socket => { module.exports = socket => {
console.log("New connection !"); console.log("New connection !");
socket.on("login", require("./login")(socket)); socket.on("login", require("./login")(socket));
socket.on("register", require("./register")(socket));
socket.emit("connected"); socket.emit("connected");
} }

21
sockets/register.js Normal file
View file

@ -0,0 +1,21 @@
const modules = require("../models");
module.exports = socket => {
return async (data) => {
if (await modules.User.findByPk(data.email) || !data.email.endsWith("univ-lyon1.fr")) {
socket.emit("register", null);
return;
}
let user = await modules.User.create({
email: data.email,
firstName: data.firstName,
lastName: data.lastName,
passwordHash: data.password
});
socket.request.session.user = user;
socket.request.session.save();
socket.emit("register", user);
}
}

View file

@ -19,7 +19,7 @@ block content
div(class='col s12 m8 offset-m2 signinup z-depth-5' id="signup") div(class='col s12 m8 offset-m2 signinup z-depth-5' id="signup")
h2 Welcome h2 Welcome
form form#register
div(class="input-field col s6") div(class="input-field col s6")
i(class="material-icons prefix") portrait i(class="material-icons prefix") portrait
input(type="text" id="firstname-input" class="autocomplete") input(type="text" id="firstname-input" class="autocomplete")
@ -52,3 +52,4 @@ block content
input(type='submit' value='Send email') input(type='submit' value='Send email')
script(src="/javascripts/login.js") script(src="/javascripts/login.js")
script(src="/javascripts/register.js")