feat: allow user to redirect after signin (#40069)
Co-authored-by: Mrugesh Mohapatra <1884376+raisedadead@users.noreply.github.com>
This commit is contained in:
committed by
GitHub
parent
0dba9c1036
commit
a7eba00690
@ -39,6 +39,12 @@ module.exports = function enableAuthentication(app) {
|
|||||||
const ifNoUserRedirectHome = ifNoUserRedirectTo(homeLocation);
|
const ifNoUserRedirectHome = ifNoUserRedirectTo(homeLocation);
|
||||||
const saveAuthCookies = saveResponseAuthCookies();
|
const saveAuthCookies = saveResponseAuthCookies();
|
||||||
const loginSuccessRedirect = loginRedirect();
|
const loginSuccessRedirect = loginRedirect();
|
||||||
|
const addRedirect = (req, res, next) => {
|
||||||
|
if (req && req.query && req.query.returnTo) {
|
||||||
|
req.query.returnTo = `${homeLocation}/${req.query.returnTo}`;
|
||||||
|
}
|
||||||
|
return next();
|
||||||
|
};
|
||||||
const api = app.loopback.Router();
|
const api = app.loopback.Router();
|
||||||
|
|
||||||
// Use a local mock strategy for signing in if we are in dev mode.
|
// Use a local mock strategy for signing in if we are in dev mode.
|
||||||
@ -47,27 +53,18 @@ module.exports = function enableAuthentication(app) {
|
|||||||
if (process.env.LOCAL_MOCK_AUTH === 'true') {
|
if (process.env.LOCAL_MOCK_AUTH === 'true') {
|
||||||
api.get(
|
api.get(
|
||||||
'/signin',
|
'/signin',
|
||||||
|
addRedirect,
|
||||||
passport.authenticate('devlogin'),
|
passport.authenticate('devlogin'),
|
||||||
saveAuthCookies,
|
saveAuthCookies,
|
||||||
loginSuccessRedirect
|
loginSuccessRedirect
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
api.get(
|
api.get('/signin', addRedirect, ifUserRedirect, (req, res, next) => {
|
||||||
'/signin',
|
const state = req.query.returnTo
|
||||||
(req, res, next) => {
|
? Buffer.from(req.query.returnTo).toString('base64')
|
||||||
if (req && req.query && req.query.returnTo) {
|
: null;
|
||||||
req.query.returnTo = `${homeLocation}/${req.query.returnTo}`;
|
return passport.authenticate('auth0-login', { state })(req, res, next);
|
||||||
}
|
});
|
||||||
return next();
|
|
||||||
},
|
|
||||||
ifUserRedirect,
|
|
||||||
(req, res, next) => {
|
|
||||||
const state = req.query.returnTo
|
|
||||||
? Buffer.from(req.query.returnTo).toString('base64')
|
|
||||||
: null;
|
|
||||||
return passport.authenticate('auth0-login', { state })(req, res, next);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
api.get(
|
api.get(
|
||||||
'/auth/auth0/callback',
|
'/auth/auth0/callback',
|
||||||
|
@ -81,9 +81,8 @@ export const saveResponseAuthCookies = () => {
|
|||||||
export const loginRedirect = () => {
|
export const loginRedirect = () => {
|
||||||
return (req, res) => {
|
return (req, res) => {
|
||||||
const successRedirect = req => {
|
const successRedirect = req => {
|
||||||
if (!!req && req.session && req.session.returnTo) {
|
if (req && req.query && req.query.returnTo) {
|
||||||
delete req.session.returnTo;
|
return req.query.returnTo;
|
||||||
return `${homeLocation}/learn`;
|
|
||||||
}
|
}
|
||||||
return `${homeLocation}/learn`;
|
return `${homeLocation}/learn`;
|
||||||
};
|
};
|
||||||
|
@ -29,7 +29,6 @@
|
|||||||
"auth:before": {
|
"auth:before": {
|
||||||
"express-flash": {},
|
"express-flash": {},
|
||||||
"./middlewares/express-extensions": {},
|
"./middlewares/express-extensions": {},
|
||||||
"./middlewares/add-return-to": {},
|
|
||||||
"./middlewares/cookie-parser": {},
|
"./middlewares/cookie-parser": {},
|
||||||
"./middlewares/request-authorization": {}
|
"./middlewares/request-authorization": {}
|
||||||
},
|
},
|
||||||
|
@ -1,37 +0,0 @@
|
|||||||
const pathsOfNoReturn = [
|
|
||||||
'link',
|
|
||||||
'auth',
|
|
||||||
'login',
|
|
||||||
'logout',
|
|
||||||
'signin',
|
|
||||||
'signup',
|
|
||||||
'fonts',
|
|
||||||
'favicon',
|
|
||||||
'js',
|
|
||||||
'css'
|
|
||||||
];
|
|
||||||
|
|
||||||
const pathsAllowedList = ['challenges', 'map', 'commit'];
|
|
||||||
|
|
||||||
const pathsOfNoReturnRegex = new RegExp(pathsOfNoReturn.join('|'), 'i');
|
|
||||||
const pathsAllowedRegex = new RegExp(pathsAllowedList.join('|'), 'i');
|
|
||||||
|
|
||||||
export default function addReturnToUrl() {
|
|
||||||
return function(req, res, next) {
|
|
||||||
// Remember original destination before login.
|
|
||||||
var path = req.path.split('/')[1];
|
|
||||||
|
|
||||||
if (
|
|
||||||
req.method !== 'GET' ||
|
|
||||||
pathsOfNoReturnRegex.test(path) ||
|
|
||||||
!pathsAllowedRegex.test(path) ||
|
|
||||||
/hot/i.test(req.path)
|
|
||||||
) {
|
|
||||||
return next();
|
|
||||||
}
|
|
||||||
req.session.returnTo = req.originalUrl.includes('/map')
|
|
||||||
? '/'
|
|
||||||
: req.originalUrl;
|
|
||||||
return next();
|
|
||||||
};
|
|
||||||
}
|
|
Reference in New Issue
Block a user