auth.js
2.18 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
var express = require('express');
var router = express.Router();
var UserModel = require('../models/UserModel');
var passport = require('passport');
var FacebookStrategy = require('passport-facebook').Strategy;
const GoogleStrategy = require('passport-google-oauth20').Strategy;
passport.serializeUser(function (user, done) {
done(null, user);
});
passport.deserializeUser(function (user, done) {
done(null, user);
});
passport.use(
new GoogleStrategy(
{
clientID:
'912554148550-gq86jjjgc022b1eit50mboh5lq48covi.apps.googleusercontent.com',
clientSecret: '_EzuXeN7eNCTbcGQUV4kY1pN',
callbackURL: 'http://localhost:3000/auth/google/callback',
profileFields: ['id', 'displayName', 'photos', 'email'], //받고 싶은 필드 나열
},
function (accessToken, refreshToken, profile, done) {
UserModel.findOne(
{ username: 'goo_' + profile.id },
function (err, user) {
if (!user) {
//없으면 회원가입 후 로그인 성공페이지 이동
var regData = {
//DB에 등록 및 세션에 등록될 데이터
username: 'goo_' + profile.id,
password: 'google_login',
displayname: profile.displayName,
};
var User = new UserModel(regData);
User.save(function (err) {
//DB저장
done(null, regData); //세션 등록
});
} else {
//있으면 DB에서 가져와서 세션등록
done(null, user);
}
}
);
}
)
);
// http://localhost:3000/auth/facebook 접근시 facebook으로 넘길 url 작성해줌
router.get('/google', passport.authenticate('google', { scope: ['profile'] }));
//인증후 페이스북에서 이 주소로 리턴해줌. 상단에 적은 callbackURL과 일치
router.get(
'/google/callback',
passport.authenticate('google', {
failureRedirect: '/auth',
successRedirect: '/',
})
);
//로그인 성공시 이동할 주소
router.get('/google/success', function (req, res) {
res.send(req.user);
});
router.get('/google/fail', function (req, res) {
res.send('google login fail');
});
module.exports = router;