* fix(models.user): Colocate all user methods Moved user methods/extensions into one file. Tracked down `next method called more than once` error and setting headers after their sent. Let regular error handler handle api errors as well. * feat(server.auth): Disable github account creation We are no longer allowing account creation through github * refactor(Auth): Move user identity link into models dir * feat(Disable link account login): This removes the ability to use a linked account t * feat(errorhandlers): Add opbeat, filter out handled error
		
			
				
	
	
		
			167 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			167 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| const successRedirect = '/';
 | |
| const failureRedirect = '/signin';
 | |
| const linkSuccessRedirect = '/settings';
 | |
| const linkFailureRedirect = '/settings';
 | |
| 
 | |
| export default {
 | |
|   local: {
 | |
|     provider: 'local',
 | |
|     module: 'passport-local',
 | |
|     usernameField: 'email',
 | |
|     passwordField: 'password',
 | |
|     authPath: '/auth/local',
 | |
|     successRedirect: successRedirect,
 | |
|     failureRedirect: '/email-signin',
 | |
|     session: true,
 | |
|     failureFlash: true
 | |
|   },
 | |
|   'facebook-login': {
 | |
|     provider: 'facebook',
 | |
|     module: 'passport-facebook',
 | |
|     clientID: process.env.FACEBOOK_ID,
 | |
|     clientSecret: process.env.FACEBOOK_SECRET,
 | |
|     authPath: '/auth/facebook',
 | |
|     callbackURL: '/auth/facebook/callback',
 | |
|     callbackPath: '/auth/facebook/callback',
 | |
|     successRedirect: successRedirect,
 | |
|     failureRedirect: failureRedirect,
 | |
|     scope: ['email'],
 | |
|     failureFlash: true
 | |
|   },
 | |
|   'facebook-link': {
 | |
|     provider: 'facebook',
 | |
|     module: 'passport-facebook',
 | |
|     clientID: process.env.FACEBOOK_ID,
 | |
|     clientSecret: process.env.FACEBOOK_SECRET,
 | |
|     authPath: '/link/facebook',
 | |
|     callbackURL: '/link/facebook/callback',
 | |
|     callbackPath: '/link/facebook/callback',
 | |
|     successRedirect: linkSuccessRedirect,
 | |
|     failureRedirect: linkFailureRedirect,
 | |
|     scope: ['email', 'user_likes'],
 | |
|     link: true,
 | |
|     failureFlash: true
 | |
|   },
 | |
|   'google-login': {
 | |
|     provider: 'google',
 | |
|     authScheme: 'oauth2',
 | |
|     module: 'passport-google-oauth2',
 | |
|     clientID: process.env.GOOGLE_ID,
 | |
|     clientSecret: process.env.GOOGLE_SECRET,
 | |
|     authPath: '/auth/google',
 | |
|     callbackURL: '/auth/google/callback',
 | |
|     callbackPath: '/auth/google/callback',
 | |
|     successRedirect: successRedirect,
 | |
|     failureRedirect: failureRedirect,
 | |
|     scope: ['email', 'profile'],
 | |
|     failureFlash: true
 | |
|   },
 | |
|   'google-link': {
 | |
|     provider: 'google',
 | |
|     authScheme: 'oauth2',
 | |
|     module: 'passport-google-oauth2',
 | |
|     clientID: process.env.GOOGLE_ID,
 | |
|     clientSecret: process.env.GOOGLE_SECRET,
 | |
|     authPath: '/link/google',
 | |
|     callbackURL: '/link/google/callback',
 | |
|     callbackPath: '/link/google/callback',
 | |
|     successRedirect: linkSuccessRedirect,
 | |
|     failureRedirect: linkFailureRedirect,
 | |
|     scope: ['email', 'profile'],
 | |
|     link: true,
 | |
|     failureFlash: true
 | |
|   },
 | |
|   'twitter-login': {
 | |
|     provider: 'twitter',
 | |
|     authScheme: 'oauth',
 | |
|     module: 'passport-twitter',
 | |
|     authPath: '/auth/twitter',
 | |
|     callbackURL: '/auth/twitter/callback',
 | |
|     callbackPath: '/auth/twitter/callback',
 | |
|     successRedirect: successRedirect,
 | |
|     failureRedirect: failureRedirect,
 | |
|     consumerKey: process.env.TWITTER_KEY,
 | |
|     consumerSecret: process.env.TWITTER_SECRET,
 | |
|     failureFlash: true
 | |
|   },
 | |
|   'twitter-link': {
 | |
|     provider: 'twitter',
 | |
|     authScheme: 'oauth',
 | |
|     module: 'passport-twitter',
 | |
|     authPath: '/link/twitter',
 | |
|     callbackURL: '/link/twitter/callback',
 | |
|     callbackPath: '/link/twitter/callback',
 | |
|     successRedirect: linkSuccessRedirect,
 | |
|     failureRedirect: linkFailureRedirect,
 | |
|     consumerKey: process.env.TWITTER_KEY,
 | |
|     consumerSecret: process.env.TWITTER_SECRET,
 | |
|     link: true,
 | |
|     failureFlash: true
 | |
|   },
 | |
|   'linkedin-login': {
 | |
|     provider: 'linkedin',
 | |
|     authScheme: 'oauth2',
 | |
|     module: 'passport-linkedin-oauth2',
 | |
|     authPath: '/auth/linkedin',
 | |
|     callbackURL: '/auth/linkedin/callback',
 | |
|     callbackPath: '/auth/linkedin/callback',
 | |
|     successRedirect: successRedirect,
 | |
|     failureRedirect: failureRedirect,
 | |
|     clientID: process.env.LINKEDIN_ID,
 | |
|     clientSecret: process.env.LINKEDIN_SECRET,
 | |
|     scope: ['r_basicprofile', 'r_emailaddress'],
 | |
|     authOptions: {
 | |
|       state: process.env.LINKEDIN_STATE
 | |
|     },
 | |
|     failureFlash: true
 | |
|   },
 | |
|   'linkedin-link': {
 | |
|     provider: 'linkedin',
 | |
|     authScheme: 'oauth2',
 | |
|     module: 'passport-linkedin-oauth2',
 | |
|     authPath: '/link/linkedin',
 | |
|     callbackURL: '/link/linkedin/callback',
 | |
|     callbackPath: '/link/linkedin/callback',
 | |
|     successRedirect: linkSuccessRedirect,
 | |
|     failureRedirect: linkFailureRedirect,
 | |
|     clientID: process.env.LINKEDIN_ID,
 | |
|     clientSecret: process.env.LINKEDIN_SECRET,
 | |
|     scope: ['r_basicprofile', 'r_emailaddress'],
 | |
|     authOptions: {
 | |
|       state: process.env.LINKEDIN_STATE
 | |
|     },
 | |
|     link: true,
 | |
|     failureFlash: true
 | |
|   },
 | |
|   'github-login': {
 | |
|     provider: 'github',
 | |
|     authScheme: 'oauth2',
 | |
|     module: 'passport-github',
 | |
|     authPath: '/auth/github',
 | |
|     callbackURL: '/auth/github/callback',
 | |
|     callbackPath: '/auth/github/callback',
 | |
|     successRedirect: successRedirect,
 | |
|     failureRedirect: failureRedirect,
 | |
|     clientID: process.env.GITHUB_ID,
 | |
|     clientSecret: process.env.GITHUB_SECRET,
 | |
|     failureFlash: true
 | |
|   },
 | |
|   'github-link': {
 | |
|     provider: 'github',
 | |
|     authScheme: 'oauth2',
 | |
|     module: 'passport-github',
 | |
|     authPath: '/link/github',
 | |
|     callbackURL: '/auth/github/callback/link',
 | |
|     callbackPath: '/auth/github/callback/link',
 | |
|     successRedirect: linkSuccessRedirect,
 | |
|     failureRedirect: linkFailureRedirect,
 | |
|     clientID: process.env.GITHUB_ID,
 | |
|     clientSecret: process.env.GITHUB_SECRET,
 | |
|     link: true,
 | |
|     failureFlash: true,
 | |
|     successFlash: [ 'We\'ve updated your profile based ',
 | |
|                     'on your your GitHub account.'
 | |
|                   ].join('')
 | |
|   }
 | |
| };
 |