feat: update user identity login

This commit is contained in:
Mrugesh Mohapatra
2018-05-19 21:21:49 +05:30
parent 764d040553
commit 4d48175e64
5 changed files with 124 additions and 96 deletions

View File

@@ -30,9 +30,8 @@ module.exports = function enableAuthentication(app) {
const { AuthToken, User } = app.models;
router.get('/email-signin', (req, res) => res.redirect(301, '/login'));
router.get('/signin', (req, res) => res.redirect(301, '/login'));
router.get('/signin', (req, res) => res.redirect(301, '/signup'));
router.get('/signout', (req, res) => res.redirect(301, '/logout'));
router.get('/signup', (req, res) => res.redirect(301, '/deprecated-signup'));
function getLegacySignUp(req, res) {
if (isSignUpDisabled) {
@@ -44,7 +43,7 @@ module.exports = function enableAuthentication(app) {
title: 'Sign in to freeCodeCamp using your Email Address'
});
}
router.get('/deprecated-signup', ifUserRedirect, getLegacySignUp);
router.get('/signup', ifUserRedirect, getLegacySignUp);
router.get('/login',
ifUserRedirect,
(req, res) => res.redirect(301, '/auth/auth0'));

View File

@@ -2,6 +2,7 @@ import passport from 'passport';
import { PassportConfigurator } from
'@freecodecamp/loopback-component-passport';
import passportProviders from './passport-providers';
import url from 'url';
const passportOptions = {
emailOptional: true,
@@ -90,26 +91,27 @@ export default function setupPassport(app) {
configurator.init();
Object.keys(passportProviders).map(function(strategy) {
var config = passportProviders[strategy];
let config = passportProviders[strategy];
config.session = config.session !== false;
// https://stackoverflow.com/q/37430452
let successRedirect = (req) => {
if (!!req && req.session && req.session.returnTo) {
var returnTo = req.session.returnTo;
let returnTo = req.session.returnTo;
delete req.session.returnTo;
return returnTo;
}
return config.successRedirect || '';
};
config.customCallback = !config.redirectWithToken
? null
: function(req, res, next) {
var url = require('url');
: (req, res, next) => {
passport.authenticate(
strategy,
{session: false},
function(err, user, info) {
{ session: false },
(err, user) => {
if (err) {
return next(err);
}
@@ -117,16 +119,24 @@ export default function setupPassport(app) {
if (!user) {
return res.redirect(config.failureRedirect);
}
var redirect = url.parse(successRedirect(req), true);
let redirect = url.parse(successRedirect(req), true);
delete redirect.search;
redirect.query = {
/* eslint-disable camelcase */
access_token: info.accessToken.id,
/* eslint-enable camelcase */
userId: user.id.toString()
};
req.flash(
'success',
'Success! You have signed in to your account. Happy Coding!'
);
// redirect.query = {
// /* eslint-disable camelcase */
// access_token: info.accessToken.id,
// /* eslint-enable camelcase */
// userId: user.id.toString()
// };
user.loginByRequest(req, res);
redirect = url.format(redirect);
return res.redirect(redirect);
}

View File

@@ -1,4 +1,4 @@
const successRedirect = '/settings';
const successRedirect = '/';
const failureRedirect = '/';
const linkSuccessRedirect = '/settings';
const linkFailureRedirect = '/settings';
@@ -176,7 +176,7 @@ export default {
callbackURL: '/auth/auth0/callback',
authPath: '/auth/auth0',
callbackPath: '/auth/auth0/callback',
redirectWithToken: false,
redirectWithToken: true,
successRedirect: successRedirect,
failureRedirect: failureRedirect,
scope: ['openid email'],

View File

@@ -6,10 +6,15 @@ block content
.text-center
h2 Sign up (or sign in with your existing account)
br
br
br
a.btn.btn-lg.btn-primary(href='/auth/auth0')
| Get a link on your email
| Continue with your email
.row
.text-center
br
br
br
br
a(href="/deprecated-signin")
| Continute with old sign in methods
| Continute with an old sign in method, that you used previously.