-
Notifications
You must be signed in to change notification settings - Fork 0
/
app.js
156 lines (133 loc) · 4.17 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
156
// Import basic modules
const express = require('express');
const path = require('path');
const favicon = require('serve-favicon');
const logger = require('morgan');
const cookieParser = require('cookie-parser');
const bodyParser = require('body-parser');
const mongoose = require('mongoose');
const session = require('express-session');
const MongoStore = require('connect-mongo')(session);
const passport = require('passport');
const flash = require('connect-flash');
//import multer
const multer = require('multer');
const upload = multer({
dest:'./public/uploads/',
limits: {
fileSize: 10000000,
files:1
}
});
// Controllers
const index = require('./server/controllers/index');
const auth = require('./server/controllers/auth');
const comments = require('./server/controllers/comments');
const videos = require('./server/controllers/videos');
const images = require('./server/controllers/images');
const app = express();
// view engine setup
app.set('views', path.join(__dirname, 'server/views/pages'));
app.set('view engine', 'ejs');
// Database configuration
const config = require('./server/config/config.js');
// connect to our database
mongoose.connect(config.url);
// Check if MongoDB is running
mongoose.connection.on('error', () => {
console.error('MongoDB Connection Error. Make sure MongoDB is running.');
});
// Passport configuration
require('./server/config/passport')(passport);
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(require('node-sass-middleware')({
src: path.join(__dirname, 'public'),
dest: path.join(__dirname, 'public'),
indentedSyntax: true,
sourceMap: true
}));
// Setup public directory
app.use(express.static(path.join(__dirname, 'public')));
// required for passport
// secret for session
app.use(session({
secret: 'super_puper_secret',
saveUninitialized: true,
resave: true,
store: new MongoStore({
url: config.url,
collection : 'sessions'
})
}));
// Init passport authentication
app.use(passport.initialize());
app.use(passport.session());
app.use(flash());
// Application Routes
// Index Route
app.get('/', index.show);
// Routes for Auth
app.get('/login', auth.signin);
app.post('/login', passport.authenticate('local-login', {
//Success go to Profile Page / Fail go to login page
successRedirect : '/profile',
failureRedirect : '/login',
failureFlash : true
}));
app.get('/signup', auth.signup);
app.post('/signup', passport.authenticate('local-signup', {
//Success go to Profile Page / Fail go to Signup page
successRedirect : '/profile',
failureRedirect : '/signup',
failureFlash : true
}));
app.get('/profile', auth.isLoggedIn, auth.profile);
// Logout Page
app.get('/logout', function(req, res) {
req.logout();
res.redirect('/');
});
// Routes for comments
app.get('/comments', comments.hasAuthorization, comments.list);
app.post('/comments', comments.hasAuthorization, comments.create);
// Routes for videos
app.get('/videos', videos.hasAuthorization, videos.show);
app.post('/videos', videos.hasAuthorization, upload.single('video'), videos.uploadVideo);
// Routes for images
app.post('/images', images.hasAuthorization, upload.single('image'),
images.uploadImage);
app.get('/images-gallery', images.hasAuthorization, images.show);
// catch 404 and forward to error handler
app.use((req, res, next) => {
const err = new Error('Not Found');
err.status = 404;
next(err);
});
// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
app.use((err, req, res, next) => {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: err
});
});
}
// production error handler
// no stacktraces leaked to user
app.use((err, req, res, next) => {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: {}
});
});
module.exports = app;
app.set('port', process.env.PORT || 3000);
const server = app.listen(app.get('port'), () => {
console.log('Express server listening on port ' + server.address().port);
});