feat: allow user to redirect after signin (#40069)

Co-authored-by: Mrugesh Mohapatra <1884376+raisedadead@users.noreply.github.com>
This commit is contained in:
Oliver Eyton-Williams
2020-11-02 11:10:43 +01:00
committed by GitHub
parent 0dba9c1036
commit a7eba00690
4 changed files with 15 additions and 57 deletions

View File

@ -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',