|
| 1 | +const passport = require("passport"); |
| 2 | +const googleStrategy = require("passport-google-oauth").OAuth2Strategy; |
| 3 | +const crypto = require("crypto"); |
| 4 | +// const { promisify } = require("util"); |
| 5 | +const User = require("../models/user"); |
| 6 | + |
| 7 | +passport.use( |
| 8 | + new googleStrategy( |
| 9 | + { |
| 10 | + clientID: |
| 11 | + "122142816625-mnuj9cb21fdd9u1voer990b4macuoe8t.apps.googleusercontent.com", |
| 12 | + clientSecret: "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", |
| 13 | + callbackURL: "http://localhost:3000/users/auth/google/callback", |
| 14 | + }, |
| 15 | + async function (accessToken, refreshToken, profile, done) { |
| 16 | + try { |
| 17 | + const user = await User.findOne({ |
| 18 | + email: profile.emails[0].value, |
| 19 | + }); |
| 20 | + |
| 21 | + // console.log(accessToken, refreshToken); |
| 22 | + // console.log(profile); |
| 23 | + |
| 24 | + if (user) { |
| 25 | + // If Found return from request |
| 26 | + return done(null, user); |
| 27 | + } else { |
| 28 | + // if not found, create the user and set it as req.user |
| 29 | + const newUser = User.create({ |
| 30 | + name: profile.displayName, |
| 31 | + email: profile.emails[0].value, |
| 32 | + password: crypto.randomBytes(20).toString("hex"), |
| 33 | + }); |
| 34 | + |
| 35 | + return done(null, newUser); |
| 36 | + } |
| 37 | + } catch (err) { |
| 38 | + console.log("error in google strategy-passport", err); |
| 39 | + return done(err); |
| 40 | + } |
| 41 | + } |
| 42 | + ) |
| 43 | +); |
| 44 | + |
| 45 | +module.exports = passport; |
0 commit comments