-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
53 lines (44 loc) · 1.58 KB
/
server.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
require('dotenv').config();
const express = require('express');
const exphbs = require('express-handlebars');
const session = require('express-session');
const path = require('path');
const routes = require('./controllers');
const helpers = require('./utils/helpers');
const sequelize = require('./config/connection');
const SequelizeStore = require('connect-session-sequelize')(session.Store);
const app = express();
const PORT = process.env.PORT || 3001;
const hbs = exphbs.create({ helpers });
// Session configuration
const sess = {
secret: process.env.EXP_SESS_SEC || 'defaultsecret', // Fallback to a default secret if EXP_SESS_SEC is not set
cookie: {
maxAge: 24 * 60 * 60 * 1000, // Session expires after 24 hours
httpOnly: true,
secure: false, // Set to true if using HTTPS
sameSite: 'strict',
},
resave: false,
saveUninitialized: true,
store: new SequelizeStore({
db: sequelize,
expiration: 24 * 60 * 60 * 1000 // Session expires after 24 hours
})
};
app.use(session(sess));
app.use(routes);
// Set up handlebars engine and views
app.engine('handlebars', hbs.engine);
app.set('view engine', 'handlebars');
// Middleware to parse JSON bodies
app.use(express.json());
app.use(express.urlencoded({ extended: true }));
// Serve static files from 'public' directory
app.use(express.static(path.join(__dirname, 'public')));
// Sync sequelize models and start server
sequelize.sync({ force: false }).then(() => {
app.listen(PORT, () => {
console.log(`Server is listening on http://localhost:${PORT}`);
});
});