-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.js
More file actions
83 lines (68 loc) · 2.39 KB
/
index.js
File metadata and controls
83 lines (68 loc) · 2.39 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
73
74
75
76
77
78
79
80
81
82
83
const express = require('express');
const mongoose = require('mongoose');
const path = require('path');
const methodOverride = require('method-override');
const passport = require('passport');
const app = express();
const PORT = 3000;
// Import routers
const notesRoutes = require('./routers/notes');
const authRoutes = require('./routers/auth');
const usersRoutes = require('./routers/users');
const session = require('express-session');
// Middleware
app.set('view engine', 'ejs');
app.set('views', path.join(__dirname, 'views'));
app.use(express.static(path.join(__dirname, 'public')));
app.use(express.urlencoded({ extended: true }));
app.use(express.json());
app.use(methodOverride('_method'));
const loggedInMiddleware = (req, res, next) => {
if (req.user) {
next();
}
else {
// res.status(401).json({ message: 'Unauthorized access. Please login to continue.' });
res.redirect('/auth/login');
}
};
app.get('/', (req, res) => {
res.redirect('/home');
});
// Session Middleware Setup
app.use(session({
secret: '([M@jQaFokwJ?Xz8',
resave: false,
saveUninitialized: false,
cookie: {
secure: false, // Set to true if using HTTPS
maxAge: 1000 * 60 * 60 * 24 // 1 hour
}
}));
app.use(passport.session());
// Connect to DB
mongoose.connect('mongodb://localhost:27017/notesApp')
.then(() => console.log('Connected to MongoDB'))
.catch(err => console.error('Error connecting to MongoDB', err));
// Root route -> Home page
app.get('/home', (req, res) => {
res.render('home', {
user: req.user || null, // logged-in user if exists
page: 'home'
});
});
// Route requests to the auth router for handling authentication endpoints (register, login, logout)
app.use('/auth', authRoutes); // Auth routes (login/register)
// Route requests to the notes router for handling note-related endpoints
app.use('/notes', loggedInMiddleware, notesRoutes); // Notes routes
// Route requests to the users router for handling user settings and account management
app.use('/users', loggedInMiddleware, usersRoutes); // Users routes
app.use((err, req, res, next) => {
console.error(err);
const status = err.status || err.statusCode || 500;
res.status(status).send({ message: err.message || 'Internal Server Error' });
});
// Start server
app.listen(PORT, () => {
console.log(`Server running on http://localhost:${PORT}`);
});