commit
9dd913f768
9 changed files with 71 additions and 10 deletions
6
app.js
6
app.js
|
@ -1,10 +1,10 @@
|
|||
let createError = require("http-errors");
|
||||
let express = require("express");
|
||||
let path = require("path");
|
||||
let cookieParser = require("cookie-parser");
|
||||
let logger = require("morgan");
|
||||
let sassMiddleware = require("node-sass-middleware");
|
||||
const session = require("express-session");
|
||||
const error = require("./routes/utils/error");
|
||||
let config = process.env.NODE_ENV === "test" ? {} : require("./config/config.json");
|
||||
|
||||
let indexRouter = require("./routes/index");
|
||||
|
@ -42,8 +42,8 @@ app.use("/", indexRouter);
|
|||
app.use("/login", loginRouter);
|
||||
|
||||
// catch 404 and forward to error handler
|
||||
app.use((req, res, next) => {
|
||||
next(createError(404));
|
||||
app.use((req, res) => {
|
||||
return error(req, res, "Page not found", 404);
|
||||
});
|
||||
|
||||
// error handler
|
||||
|
|
|
@ -43,13 +43,11 @@ module.exports = (sequelize, DataTypes) => {
|
|||
},
|
||||
firstName: {
|
||||
type: DataTypes.STRING,
|
||||
allowNull: false,
|
||||
unique: "userFullName"
|
||||
allowNull: false
|
||||
},
|
||||
lastName: {
|
||||
type: DataTypes.STRING,
|
||||
allowNull: false,
|
||||
unique: "userFullName"
|
||||
allowNull: false
|
||||
},
|
||||
passwordHash: {
|
||||
type: DataTypes.STRING,
|
||||
|
|
21
public/javascripts/register.js
Normal file
21
public/javascripts/register.js
Normal 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 = "/";
|
||||
}
|
||||
});
|
|
@ -1,8 +1,8 @@
|
|||
let express = require("express");
|
||||
let router = express.Router();
|
||||
const sessionCheck = require("./utils/sessionCheck");
|
||||
|
||||
/* GET home page. */
|
||||
router.get("/", (req, res) => {
|
||||
router.get("/", sessionCheck(1), (req, res) => {
|
||||
res.render("index", { title: "L'ETU" });
|
||||
});
|
||||
|
||||
|
|
4
routes/utils/error.js
Normal file
4
routes/utils/error.js
Normal 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}});
|
||||
};
|
15
routes/utils/sessionCheck.js
Normal file
15
routes/utils/sessionCheck.js
Normal 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;
|
|
@ -1,5 +1,6 @@
|
|||
module.exports = socket => {
|
||||
console.log("New connection !");
|
||||
socket.on("login", require("./login")(socket));
|
||||
socket.on("register", require("./register")(socket));
|
||||
socket.emit("connected");
|
||||
}
|
||||
|
|
21
sockets/register.js
Normal file
21
sockets/register.js
Normal 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);
|
||||
}
|
||||
}
|
|
@ -19,7 +19,7 @@ block content
|
|||
|
||||
div(class='col s12 m8 offset-m2 signinup z-depth-5' id="signup")
|
||||
h2 Welcome
|
||||
form
|
||||
form#register
|
||||
div(class="input-field col s6")
|
||||
i(class="material-icons prefix") portrait
|
||||
input(type="text" id="firstname-input" class="autocomplete")
|
||||
|
@ -52,3 +52,4 @@ block content
|
|||
input(type='submit' value='Send email')
|
||||
|
||||
script(src="/javascripts/login.js")
|
||||
script(src="/javascripts/register.js")
|
||||
|
|
Reference in a new issue