-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
49 lines (40 loc) · 1.24 KB
/
server.js
File metadata and controls
49 lines (40 loc) · 1.24 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
"use strict";
const path = require("path");
const express = require("express");
const cookieParser = require("cookie-parser");
const morgan = require("morgan");
const { NOT_FOUND, INTERNAL_SERVER_ERROR } = require("http-status-codes");
require("express-async-errors");
const Logger = require("./shared/Logger");
const Router = require("./routes");
const app = express();
app.use(express.json());
app.use(express.urlencoded({ extended: true }));
app.set("views", path.join(__dirname, "views"));
app.set("view engine", "hbs");
app.use(morgan("common"));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, "public")));
// parse cookies
app.use((req, res, next) => {
const cookies = req.cookies || {};
req.cookies.settings = cookies.settings ? JSON.parse(cookies.settings) : {};
next();
});
app.use("/", Router);
app.use("*", () => {
throw new Error("Wrong URL");
});
// error handler
app.use((err, req, res, next) => {
let code = INTERNAL_SERVER_ERROR;
if (err.message === "Wrong URL") {
code = NOT_FOUND;
}
res.status(code);
res.render("error", { error: err });
});
const port = Number(process.env.PORT || 3000);
app.listen(port, () => {
Logger.info(`Express server started on port: ${port}`);
});