-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathapp.js
54 lines (45 loc) · 1.21 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
const express = require("express")
const mongoose = require("mongoose")
const dotenv = require("dotenv")
const cookie_parser = require("cookie-parser")
const cors = require("cors")
const morgan = require("morgan")
const fs = require("fs")
const auth_route = require("./routes/auth")
const office_order_route = require("./routes/office_order")
const PORT = process.env.PORT || 3000
dotenv.config()
const app = express()
let accessLogStream = fs.createWriteStream('./access.log', {flags: 'a'})
const connect = () => {
mongoose.connect(process.env.MONGO_URL)
.then(() => {
console.log("Connected to database")
})
.catch((err) => {
console.log("[ERROR]")
console.log(err)
throw new Error
})
}
// middlewares
app.use(morgan({stream: accessLogStream}))
app.use(cors())
app.use(cookie_parser())
app.use(express.json())
// routes middleware
app.use("/auth", auth_route)
app.use("/orders", office_order_route)
// error middleware
app.use((req, res) => {
if (req.err) {
res.status(400).send({ error: req.err })
}
else {
res.status(404).send({ error: "404 page not found !"})
}
})
app.listen(PORT, () => {
connect()
console.log("Server Started!");
})