50 lines
1.0 KiB
JavaScript
50 lines
1.0 KiB
JavaScript
export function ifNoUserRedirectTo(url, message, type = 'errors') {
|
|
return function(req, res, next) {
|
|
const { path } = req;
|
|
if (req.user) {
|
|
return next();
|
|
}
|
|
|
|
req.flash(type, {
|
|
msg: message || `You must be signed in to access ${path}`
|
|
});
|
|
|
|
return res.redirect(url);
|
|
};
|
|
}
|
|
|
|
export function ifNoUserSend(sendThis) {
|
|
return function(req, res, next) {
|
|
if (req.user) {
|
|
return next();
|
|
}
|
|
return res.status(200).send(sendThis);
|
|
};
|
|
}
|
|
|
|
export function ifNoUser401(req, res, next) {
|
|
if (req.user) {
|
|
return next();
|
|
}
|
|
return res.status(401).end();
|
|
}
|
|
|
|
export function flashIfNotVerified(req, res, next) {
|
|
return next();
|
|
/*
|
|
// disabled until authorized required bug is fixed
|
|
const user = req.user;
|
|
if (!user) {
|
|
return next();
|
|
}
|
|
const email = req.user.email;
|
|
const emailVerified = req.user.emailVerified;
|
|
if (!email || !emailVerified) {
|
|
req.flash('info', {
|
|
msg: 'Please verify your email address ' +
|
|
'<a href="/update-email">here</a>.'
|
|
});
|
|
}
|
|
*/
|
|
}
|