-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.js
More file actions
121 lines (101 loc) · 2.86 KB
/
Copy pathindex.js
File metadata and controls
121 lines (101 loc) · 2.86 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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
const express = require("express");
const app = express();
const morgan = require("morgan");
const cors = require("cors");
require("dotenv").config();
const Person = require("./models/person");
app.use(express.static("build"));
app.use(cors());
app.use(express.json());
const errorHandler = (error, request, response, next) => {
console.error(error.message);
if (error.name === "CastError" && error.message.includes("ObjectId")) {
return response.status(400).send({ error: "malformatted id" });
} else if (error.name === "ValidationError") {
if (error.errors.name) {
return response.status(400).json({ error: error.errors.name.message });
} else if (error.errors.number) {
return response.status(400).json({ error: error.errors.number.message });
}
}
next(error);
};
morgan.token("body", (request) => {
return Object.keys(request.body).length !== 0
? JSON.stringify(request.body)
: " ";
});
app.use(
morgan(":method :url :status :res[content-length] - :response-time ms :body")
);
app.get("/info", (request, response) => {
Person.find({}).then((persons) => {
var dateTime = new Date();
response.send(
`<p>Phonebook has info for ${persons.length} people</p>
<p>${dateTime}</p>`
);
});
});
app.get("/api/persons", (request, response) => {
Person.find({}).then((persons) => {
response.json(persons);
});
});
app.post("/api/persons", (request, response, next) => {
const body = request.body;
const person = new Person({
name: body.name,
number: body.number,
});
person
.save()
.then((savedPerson) => savedPerson.toJSON())
.then((savedAndFormattedPerson) => {
response.json(savedAndFormattedPerson);
})
.catch((error) => next(error));
});
app.get("/api/persons/:id", (request, response, next) => {
Person.findById(request.params.id)
.then((person) => {
if (person) {
response.json(person);
} else {
response.status(404).end();
}
})
.catch((error) => next(error));
});
app.delete("/api/persons/:id", (request, response, next) => {
Person.findByIdAndRemove(request.params.id)
.then(() => {
response.status(204).end();
})
.catch((error) => next(error));
});
app.put("/api/persons/:id", (request, response, next) => {
const body = request.body;
const person = {
name: body.name,
number: body.number,
};
Person.findByIdAndUpdate(request.params.id, person, {
runValidators: true,
context: "query",
new: true,
})
.then((updatedPerson) => {
response.json(updatedPerson);
})
.catch((error) => next(error));
});
const unknownEndpoint = (request, response) => {
response.status(404).send({ error: "unknown endpoint" });
};
app.use(unknownEndpoint);
app.use(errorHandler);
const PORT = process.env.PORT;
app.listen(PORT, () => {
console.log(`Server running on port ${PORT}`);
});