forked from paulosalvatore/ocean-backend-nuvem-11-03-2022
-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.js
98 lines (70 loc) · 2.49 KB
/
index.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
91
92
93
94
95
96
97
98
const express = require("express");
const { MongoClient, ObjectId } = require("mongodb");
const url = "mongodb+srv://marsoft:[email protected]";
const dbName = "MarSoft";
async function main() {
// Conexão com o bando de dados
console.log("Conectando ao banco de dados...");
const client = await MongoClient.connect(url);
const db = client.db(dbName);
const collection = db.collection("herois");
console.log("Conexão com o banco de dados realizada com sucesso.");
const app = express();
// Sinaliza para o express entender o JSON no corpo das requisições
app.use(express.json());
// Endpoint principal
app.get("/", function (req, res) {
res.send("Hello World");
});
const herois = ["Mulher Maravilha", "Capitã Marvel", "Homem de Ferro"];
// 0 1 2
// [GET] Read All (Ler individualmente)
app.get("/herois", async function (req, res) {
const documentos = await collection.find().toArray();
res.send(documentos);
});
// [GET] Read Single (by Id) (Ler individualmente pelo ID)
app.get("/herois/:id", async function (req, res) {
// Acesso o parâmetro da rota chamado ID
const id = req.params.id;
// Pega o item da lista que corresponde a esse ID
const item = await collection.findOne({ _id: new ObjectId(id) });
res.send(item);
});
// [POST] Create (Criar)
app.post("/herois", async function (req, res) {
// Recebemos o item no corpo da requisição
const item = req.body;
// Adicionamos o item no banco
await collection.insertOne(item);
// Enviamos uma resposta de sucesso
res.send(item);
});
// [PUT] Update (Atualizar)
app.put("/herois/:id", function (req, res) {
// Recebemos o ID que será atualizado
const id = req.params.id;
// Pegamos o novo item que foi enviado no corpo da requisição
const novoItem = req.body;
// Atualizamos o banco de dados com a nova informação
collection.updateOne(
{ _id: ObjectId(id) },
{
$set: novoItem,
}
);
// Enviamos uma mensagem de sucesso
res.send(novoItem);
});
// [DELETE] Delete (Remover)
app.delete("/herois/:id", async function (req, res) {
// Recebemos o ID que será excluído
const id = req.params.id;
// Excluimos o ID do banco
await collection.deleteOne({ _id: ObjectId(id) });
// Enviamos uma mensagem de sucesso
res.send("Item removido com sucesso!");
});
app.listen(process.env.PORT || 3000);
}
main();