tracman-server/config/auth.js

107 lines
3.5 KiB
JavaScript
Raw Normal View History

2016-03-31 17:06:21 -06:00
var passport = require('passport'),
2016-08-09 23:51:49 -06:00
slug = require('slug'),
2016-06-12 18:18:34 -06:00
crypto = require('crypto'),
2016-03-31 17:06:21 -06:00
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) {
2016-07-01 19:14:36 -06:00
// 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 */ {
2017-03-06 02:52:59 -07:00
user = new User();
2016-07-01 19:14:36 -06:00
user.googleID = profile.id;
2016-08-09 23:51:49 -06:00
user.name = profile.displayName;
user.email = profile.emails[0].value;
user.slug = slug(profile.displayName).toLowerCase();
user.created = Date.now();
user.lastLogin = Date.now();
// user.settings = { units:'standard', defaultMap:'road', defaultZoom:11, showSpeed:false, showTemp:false, showAlt:false, showStreetview:false },
// user.last = { lat:0, lon:0, dir:0, alt:0, spd:0 },
// user.isPro = false;
// user.isAdmin = false;
var cbc = 2;
2017-03-06 02:52:59 -07:00
var successMessage, failMessage;
2016-08-09 23:51:49 -06:00
// Generate slug
2016-07-01 19:14:36 -06:00
(function checkSlug(s,cb) {
//console.log('checking ',s);
User.findOne({slug:s}, function(err, existingUser){
2016-09-08 05:26:12 -06:00
if (err) { console.log('No user found for ',slug,':',err); }
2016-07-01 19:14:36 -06:00
if (existingUser){
s = '';
while (s.length<6) {
s+='abcdefghijkmnpqrtuvwxy346789'.charAt(Math.floor(Math.random()*28));
}
checkSlug(s,cb);
} else { cb(s); }
2016-03-31 17:06:21 -06:00
});
2016-08-09 23:51:49 -06:00
})(user.slug, function(newSlug){
2016-07-01 19:14:36 -06:00
user.slug = newSlug;
if (cbc>1) /* waiting on other calls */ { cbc--; }
else { done(null, user, { success:successMessage, failure:failMessage }); }
});
2016-08-09 23:51:49 -06:00
// Generate sk32
2016-07-01 19:14:36 -06:00
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) {
2016-04-27 15:23:04 -06:00
if (err) {
2016-08-09 23:51:49 -06:00
console.log('Error saving new user '+err);
var failMessage = 'Something went wrong creating your account. Would you like to <a href="/bug">report this error</a>?';
2016-07-01 19:14:36 -06:00
} else { successMessage = 'Your account has been created. Next maybe you should download the <a href="/android">android app</a>. ' }
if (cbc>1) /* waiting on other calls */ { cbc--; }
else { done(null, user, { success:successMessage, failure:failMessage }); }
2016-03-31 17:06:21 -06:00
});
2016-06-30 14:40:21 -06:00
}
2016-07-01 19:14:36 -06:00
});
2016-08-09 23:51:49 -06:00
2016-07-01 19:14:36 -06:00
}
});
2016-06-30 14:40:21 -06:00
2016-03-31 17:06:21 -06:00
}));
2016-03-31 15:01:27 -06:00
2016-03-31 17:06:21 -06:00
passport.use(new GoogleTokenStrategy({
2016-05-31 21:54:21 -06:00
clientID: secret.googleClientId
2016-03-31 17:06:21 -06:00
}, function(parsedToken, googleId, done) {
User.findOne({googleID:googleId}, function(err, user) {
2016-04-27 15:14:32 -06:00
if (err) {
console.log('Error finding user for gToken login with google profile ID: '+googleId+'\n'+err); }
2016-03-31 17:06:21 -06:00
if (!err && user !== null) { // Log in
user.lastLogin = Date.now();
user.save(function (err) {
2016-04-27 15:14:32 -06:00
if (err) {
console.log('Error saving user\'s lastLogin for gToken login with google profile ID: '+googleId+'\n'+err); }
2016-03-31 17:06:21 -06:00
});
return done(err, user);
} else { // No such user
done(null, false);
}
});
}));