-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
90 lines (68 loc) · 2.78 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
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
require('dotenv').config();
require('express-async-errors');
const express = require('express');
const app = express();
const path = require('path');
const { logger, logEvents } = require('./middleware/logger')
const errorHandler = require('./middleware/errorHandler');
const cookieParser = require('cookie-parser');
const cors = require('cors');
const corsOptions = require('./config/corsOptions');
const connectDB = require('./config/dbConn');
const mongoose = require('mongoose');
const PORT = process.env.PORT || 3500;
console.log(process.env.NODE_ENV);
connectDB();
app.use(logger);
app.use(cors(corsOptions));
app.use(express.json());
app.use(cookieParser());
app.use('/', express.static(path.join(__dirname, 'public')));
app.use('/', require('./routes/root'));
app.use('/auth', require('./routes/authRoutes'));
app.use('/users', require('./routes/userRoutes'));
app.use('/notes', require('./routes/noteRoutes'))
app.all('*', (req, res) => {
res.status(404);
if (req.accepts('html')) {
res.sendFile(path.join(__dirname, 'views', '404.html'));
} else if (req.accepts('json')) {
res.json({ error: "404 Not Found" });
} else {
res.type('txt').send('404 Not Found');
}
});
app.use(errorHandler);
mongoose.connection.once('open', () => {
console.log('Connected to MongoDB')
app.listen(PORT, () => console.log(`Server running on port ${PORT}`))
})
// err.name:
// Menyediakan nama error yang terjadi, seperti 'MongoNetworkError', 'MongooseServerSelectionError', dll.
// Contoh: 'MongoNetworkError'.
// err.message:
// Menyediakan deskripsi atau pesan kesalahan yang lebih rinci.
// Contoh: 'failed to connect to server [localhost:27017] on first connect [MongoNetworkError: connect ECONNREFUSED 127.0.0.1:27017]'.
// err.code:
// Kode numerik yang mewakili jenis kesalahan.
// Misalnya, 11000 untuk error duplikat, 18 untuk otentikasi gagal, dll.
// Jika error tidak memiliki code, nilainya bisa undefined.
// err.errno:
// Nomor kesalahan yang disertakan oleh sistem operasi atau driver MongoDB. Kadang-kadang sama dengan code.
// Contoh: -61, 11000.
// err.syscall:
// Nama sistem panggilan (syscall) yang menyebabkan kesalahan.
// Contoh: 'connect'.
// err.hostname:
// Hostname dari server yang menyebabkan kesalahan, jika ada.
// Contoh: 'localhost'.
// err.path:
// Path atau properti yang menyebabkan error, misalnya ketika terjadi kesalahan validasi.
// Contoh: 'email' ketika terjadi error validasi pada field email.
// err.stack:
// Stack trace dari error yang memberikan informasi di mana dan bagaimana error tersebut terjadi.
// Ini berguna untuk debugging dan pelacakan kesalahan yang lebih mendetail.
mongoose.connection.on('error', err => {
console.log(err)
logEvents(`${err.errno}: ${err.code}\t${err.syscall}\t${err.hostname}`, 'mongoErrLog.log')
})