-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
112 lines (83 loc) · 2.85 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
const express = require('express');
const mysql = require('mysql');
const dotenv = require('dotenv').config();
const flash = require('connect-flash');
const session = require('express-session');
const passport = require('passport');
const bodyParser = require("body-parser");
const cors = require('cors');
const https = require('https')
const fs = require('fs')
const app = express();
// Create connection
const db = mysql.createConnection({
host : 'goaldb.cf3qwkt8ruuo.ap-northeast-1.rds.amazonaws.com',
user : 'admin',
password : process.env.password,
database : 'GoalDb'
});
// connection
db.connect((err) => {
if(err){
throw err;
}
console.log('Mysql Connected');
})
//passport config
require('./config/passport')(passport);
require('dotenv').config()
// Use Cors
// app.use(cors({
// origin:"https://localhost:5000",
// credentials: true
// }))
app.use((req, res, next) => {
res.setHeader('Access-Control-Allow-Origin', 'http://localhost:8080'); // * allows all, or you can limit by domain
res.setHeader('Access-Control-Allow-Methods', '*'); // Set which header methods you want to allow (GET,POST,PUT,DELETE,OPTIONS)
res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization'); // These 2 are recommended
res.setHeader('Access-Control-Expose-Headers', 'Set-Cookie'); // Required to allow the returned cookie to be set
res.setHeader('Access-Control-Allow-Credentials', 'true'); // Required to allow auth credentials
next();
});
app.set('trust proxy', 1)
// Express Session
app.use(session({
secret: 'secert',
resave: false,
saveUninitialized: true,
cookie: {
path: "/",
httpOnly: false, // Set this so it can be accessed via document.cookie in javascript
secure: true, // Required when using sameSite:'none'
sameSite: 'none', // Set this to allow access via different domians
maxAge: 3600000 // Set cookie to last 1 hour
}
}))
// Passport middleware
app.use(passport.initialize());
app.use(passport.session());
app.use(express.json());
//app.use(express.urlencoded({extended: false}));
app.use(bodyParser.urlencoded({extended: true}));
// Connect flash
app.use(flash());
// Global Vars
app.use((req, res, next) => {
res.locals.success_msg = req.flash('success_msg');
res.locals.error_msg = req.flash('error_msg');
res.locals.error = req.flash('error');
res.locals.userId = req.flash('userId');
next();
})
// Set Router
app.use('/api', require('./routes/index'));
app.use('/api/user', require('./routes/goals'));
app.use('/api/user', require('./routes/subgoals'));
const PORT = process.env.PORT || 3000;
// // Sets up the server as HTTPS using certificates
// const httpsOptions = {
// key: fs.readFileSync('key.pem'),
// cert: fs.readFileSync('cert.pem')
// }
// const server = https.createServer(httpsOptions, app).listen(PORT);
app.listen(PORT)