-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapp.js
More file actions
executable file
·105 lines (92 loc) · 2.58 KB
/
app.js
File metadata and controls
executable file
·105 lines (92 loc) · 2.58 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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
const dotenv = require("dotenv");
const path = require("path");
if (process.env.NODE_ENV == "production") {
dotenv.config({ path: "/.env.production" });
} else {
dotenv.config({ path: "/.env.develop" });
}
const express = require("express");
const app = express();
const morgan = require("morgan");
const db = require("./models");
const cors = require("cors");
const host =
process.env.NODE_ENV !== "production"
? "http://localhost:3000"
: "서버ip주소";
// const host = "http://localhost:9000";
const logger = require("./logger/logger");
const requestIP = require("request-ip");
const session = require("express-session");
// const cookieParser = require("cookie-parser");
var FileStore = require("session-file-store")(session);
// 일단 닷엔브가 작동이 안되네
const fileStoreOption = {};
// console.log(["not exist???"], process.env.cookieSessionSecretKey);
const cookieKey = "blue_penuts";
// app.use(cookieParser(cookieKey, {}));
app.use(
session({
store: new FileStore(fileStoreOption),
secret: cookieKey,
resave: true,
saveUninitialized: true,
cookie: {
secure: process.env.NODE_ENV === "production" || false, // if it's true, cookie will be sent over only https
sameSite: true,
httpOnly: true,
maxAge: 10000 * 60 * 60,
},
})
);
// const host = "http://192.168.55.151:3000"
const { sequelize } = db;
app.all("*", (req, res, next) => {
var clientIp = requestIP.getClientIp(req);
logger.info(`${req.method} ${clientIp} ${req.url}`);
next();
});
// CORS header setting
app.use(
cors({
credentials: true,
origin: host,
})
);
app.set("ROOT_PATH", path.join(__dirname, "/"));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(morgan("dev"));
sequelize
.sync({ force: false, alter: false })
.then(() => {
console.log("db is connected");
})
.catch((err) => {
console.log("err: ", err);
logger.error(err);
});
app.get("/", (req, res) => {
res.send("ok");
});
app.use("/v1", require("./routes/indexRouter"));
// logger
app.use((req, res, next) => {
const error = new Error(`${req.method} ${req.url} no Router there`);
error.status = 404;
error.level = "error";
logger.error(error.message);
next();
});
// 에러메시지 클라로 전송
app.use((err, req, res) => {
req.locals.message = err.message;
req.locals.error = process.env.NODE_ENV !== "production" ? err : {};
logger.error(err);
res
.status(err.status || 500)
.json({ msg: err.message, statusCode: err.status });
});
app.listen(5000, () => {
console.log("port is running on ", "5000 port");
});