-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
155 lines (134 loc) · 5.55 KB
/
app.js
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var sassMiddleware = require('node-sass-middleware');
var session = require('express-session');
var methodOverride = require('method-override');
var flash = require('connect-flash');
var mongoose = require('mongoose');
var passport = require('passport');
var passportSocketIo = require('passport.socketio');
var index = require('./routes/index');
var users = require('./routes/users');
var posts = require('./routes/posts');
var passportConfig = require('./lib/passport-config');
module.exports = (app, io) => {
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'pug');
if (app.get('env') === 'development') {
app.locals.pretty = true;
}
// Pug의 local에 moment라이브러리와 querystring 라이브러리를 사용할 수 있도록.
app.locals.moment = require('moment');
app.locals.querystring = require('querystring');
//=======================================================
// mongodb connect
//=======================================================
mongoose.Promise = global.Promise; // ES6 Native Promise를 mongoose에서 사용한다.
// const connStr = 'mongodb://localhost/mjdb4';
// 아래는 mLab을 사용하는 경우의 예: 본인의 접속 String으로 바꾸세요.
const connStr = (process.env.NODE_ENV == 'production')?
'mongodb+srv://Jihyeon:kgh1124@cluster0-zgqfs.mongodb.net/test?retryWrites=true&w=majority'
:
'mongodb://localhost'
mongoose.connect(connStr, {useMongoClient: true });
mongoose.connection.on('error', console.error);
// Favicon은 웹사이트의 대표 아이콘입니다. Favicon을 만들어서 /public에 둡시다.
// https://www.favicon-generator.org/ 여기서 만들어볼 수 있어요.
app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
// _method를 통해서 method를 변경할 수 있도록 함. PUT이나 DELETE를 사용할 수 있도록.
app.use(methodOverride('_method', {methods: ['POST', 'GET']}));
// sass, scss를 사용할 수 있도록
app.use(sassMiddleware({
src: path.join(__dirname, 'public'),
dest: path.join(__dirname, 'public'),
indentedSyntax: false, // true = .sass and false = .scss
debug: true,
sourceMap: true
}));
const sessionStore = new session.MemoryStore();
const sessionId = 'mjoverflow.sid';
const sessionSecret = 'TODO: change this secret string for your own'
// session을 사용할 수 있도록.
app.use(session({
name: sessionId,
resave: true,
saveUninitialized: true,
store: sessionStore,
secret: sessionSecret
}));
app.use(flash()); // flash message를 사용할 수 있도록
// public 디렉토리에 있는 내용은 static하게 service하도록.
app.use(express.static(path.join(__dirname, 'public')));
//=======================================================
// Passport 초기화
//=======================================================
app.use(passport.initialize());
app.use(passport.session());
passportConfig(passport);
// pug의 local에 현재 사용자 정보와 flash 메시지를 전달하자.
app.use(function(req, res, next) {
res.locals.currentUser = req.user; // passport는 req.user로 user정보 전달
res.locals.flashMessages = req.flash();
next();
});
// Socket에서도 Passport로 로그인한 정보를 볼 수 있도록 함.
io.use(passportSocketIo.authorize({
cookieParser: cookieParser, // the same middleware you registrer in express
key: sessionId, // the name of the cookie where express/connect stores its session_id
secret: sessionSecret, // the session_secret to parse the cookie
store: sessionStore, // we NEED to use a sessionstore. no memorystore please
passport: passport,
success: (data, accept) => {
console.log('successful connection to socket.io');
accept(null, true);
},
fail: (data, message, error, accept) => {
// 실패 혹은 로그인 안된 경우
console.log('failed connection to socket.io:', message);
accept(null, false);
}
}));
// connection 요청이 온 경우
io.on('connection', socket => {
console.log('socket connection!');
if (socket.request.user.logged_in) {
// 로그인이 된 경우에만 join 요청을 받는다.
socket.emit('welcome');
socket.on('join', data => {
// 본인의 ID에 해당하는 채널에 가입시킨다.
socket.join(socket.request.user._id.toString());
});
}
});
// Route
app.use('/', index);
app.use('/users', users);
app.use('/posts', posts(io)); // socket.io를 인자로 주기 위해 function으로 변경
require('./routes/auth')(app, passport);
app.use('/api', require('./routes/api'));
// catch 404 and forward to error handler
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
});
// error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500);
res.render('error');
});
return app;
}