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 saveAuthCookies = saveResponseAuthCookies();
|
||||
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();
|
||||
|
||||
// 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') {
|
||||
api.get(
|
||||
'/signin',
|
||||
addRedirect,
|
||||
passport.authenticate('devlogin'),
|
||||
saveAuthCookies,
|
||||
loginSuccessRedirect
|
||||
);
|
||||
} else {
|
||||
api.get(
|
||||
'/signin',
|
||||
(req, res, next) => {
|
||||
if (req && req.query && req.query.returnTo) {
|
||||
req.query.returnTo = `${homeLocation}/${req.query.returnTo}`;
|
||||
}
|
||||
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('/signin', addRedirect, 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(
|
||||
'/auth/auth0/callback',
|
||||
|
Reference in New Issue
Block a user