var passport = require('passport'), crypto = require('crypto'), secret = require('./secrets.js'), User = require('./models/user.js'), GoogleStrategy = require('passport-google-oauth2').Strategy, GoogleTokenStrategy = require('passport-google-id-token'); passport.use(new GoogleStrategy({ clientID: secret.googleClientId, clientSecret: secret.googleClientSecret, callbackURL: secret.url+'/auth/google/callback', passReqToCallback: true }, function(req, accessToken, refreshToken, profile, done) { // Check for user User.findOne({googleID: profile.id}, function(err, user){ // Error if (err) { console.log('Error finding user with google ID: '+profile.id+'\n'+err); } // User found if (!err && user !== null) /* Log user in */ { if (!user.name) { user.name=profile.displayName; } user.lastLogin = Date.now(); user.save(function (err, raw) { if (err) { throwErr(req,err); } }); done(null, user); } // User not found else /* create user */ { var user, successMessage, failMessage, cbc=2; user.googleID = profile.id; user.email = profile.emails[0]; user.lastLogin = Date.now(); // Get slug (function checkSlug(s,cb) { //console.log('checking ',s); User.findOne({slug:s}, function(err, existingUser){ if (err) { console.log('Slug check error for ',slug(request.name).toLowerCase(),+':',err); } if (existingUser){ s = ''; while (s.length<6) { s+='abcdefghijkmnpqrtuvwxy346789'.charAt(Math.floor(Math.random()*28)); } checkSlug(s,cb); } else { cb(s); } }); })(slug(profile.name).toLowerCase(), function(newSlug){ user.slug = newSlug; if (cbc>1) /* waiting on other calls */ { cbc--; } else { done(null, user, { success:successMessage, failure:failMessage }); } }); // Get sk32 crypto.randomBytes(32, function(err,buf) { if (err) {console.log('Unable to get random bytes:',err);} if (!buf) {console.log('Unable to get random buffer');} else { user.sk32 = buf.toString('hex'); user.save(function(err) { if (err) { console.log('Error saving new (invited) user '+err); var failMessage = 'Something went wrong finding your session. Would you like to report this error?'; } else { successMessage = 'Your account has been created. Next maybe you should download the android app. ' } if (cbc>1) /* waiting on other calls */ { cbc--; } else { done(null, user, { success:successMessage, failure:failMessage }); } }); } }); } }); })); passport.use(new GoogleTokenStrategy({ clientID: secret.googleClientId }, function(parsedToken, googleId, done) { User.findOne({googleID:googleId}, function(err, user) { if (err) { console.log('Error finding user for gToken login with google profile ID: '+googleId+'\n'+err); } if (!err && user !== null) { // Log in user.lastLogin = Date.now(); user.save(function (err) { if (err) { console.log('Error saving user\'s lastLogin for gToken login with google profile ID: '+googleId+'\n'+err); } }); return done(err, user); } else { // No such user done(null, false); } }); }));