mirror of
https://github.com/bodyrep/DemoApp.git
synced 2026-01-25 14:43:00 +00:00
migrating repo to Bodyrep org
This commit is contained in:
11
routes/middleware/is_admin.js
Normal file
11
routes/middleware/is_admin.js
Normal file
@@ -0,0 +1,11 @@
|
||||
function isAdmin(req, res, next) {
|
||||
if (req.session.user.is_admin === false) {
|
||||
console.log("not an admin - sending to profile");
|
||||
res.redirect('/users/' + req.session.user.username);
|
||||
} else {
|
||||
console.log("Admin detected");
|
||||
next();
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = isAdmin;
|
||||
16
routes/middleware/load_user.js
Normal file
16
routes/middleware/load_user.js
Normal file
@@ -0,0 +1,16 @@
|
||||
var User = require('../../data/models/user');
|
||||
|
||||
function loadUser(req, res, next) {
|
||||
User.findOne({username: req.params.name}, function(err, user) {
|
||||
if (err) {
|
||||
return next(err);
|
||||
}
|
||||
if (! user) {
|
||||
return res.send('Not found', 404);
|
||||
}
|
||||
req.user = user;
|
||||
next();
|
||||
});
|
||||
}
|
||||
|
||||
module.exports = loadUser;
|
||||
21
routes/middleware/load_workout.js
Normal file
21
routes/middleware/load_workout.js
Normal file
@@ -0,0 +1,21 @@
|
||||
var workout = require('../../data/models/workout');
|
||||
|
||||
function loadworkout(req, res, next) {
|
||||
console.log('fetch id' + req.params.title );
|
||||
workout.findOne({title: req.params.title})
|
||||
.populate('elements')
|
||||
|
||||
.exec(function(err, workout) {
|
||||
if (err) {
|
||||
return next(err);
|
||||
}
|
||||
if (! workout) {
|
||||
return res.send('Not found', 404);
|
||||
}
|
||||
console.log('workout' + JSON.stringify(workout));
|
||||
req.workout = workout;
|
||||
next();
|
||||
});
|
||||
}
|
||||
|
||||
module.exports = loadworkout;
|
||||
11
routes/middleware/logged_in.js
Normal file
11
routes/middleware/logged_in.js
Normal file
@@ -0,0 +1,11 @@
|
||||
function loggedIn(req, res, next) {
|
||||
if (! req.session.user) {
|
||||
console.log("not logged in - redirecting to login");
|
||||
res.redirect('/session/new');
|
||||
} else {
|
||||
console.log("user logged in");
|
||||
next();
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = loggedIn;
|
||||
9
routes/middleware/not_logged_in.js
Normal file
9
routes/middleware/not_logged_in.js
Normal file
@@ -0,0 +1,9 @@
|
||||
function notLoggedIn(req, res, next) {
|
||||
if (req.session.user) {
|
||||
res.redirect('/users/' + req.session.user.username);
|
||||
} else {
|
||||
next();
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = notLoggedIn;
|
||||
9
routes/middleware/restrict_user_to_self.js
Normal file
9
routes/middleware/restrict_user_to_self.js
Normal file
@@ -0,0 +1,9 @@
|
||||
function restrictUserToSelf(req, res, next) {
|
||||
if (! req.session.user || req.session.user.username !== req.user.username) {
|
||||
res.send('Unauthorized', 401);
|
||||
} else {
|
||||
next();
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = restrictUserToSelf;
|
||||
Reference in New Issue
Block a user