-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
110 lines (100 loc) · 2.66 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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
const express = require("express");
const app = express();
const bodyParser = require("body-parser");
const MongoClient = require("mongodb").MongoClient;
const PORT = 4000;
require("dotenv").config();
let db,
dbConnectionStr =process.env.DB_STRING,
dbName = process.env.DB_NAME;
MongoClient.connect(dbConnectionStr, { useUnifiedTopology: true }).then(
(client) => {
console.log(`Connected to ${dbName} Database`);
db = client.db(dbName);
}
);
app.set("view engine", "ejs");
app.use(express.static("public"));
app.use(express.urlencoded({ extended: true }));
app.use(express.json());
app.listen(process.env.PORT || PORT, () => {
console.log(`Server running on port ${PORT}`);
});
app.get("/", (request, response) => {
db.collection("contacts")
.find()
.sort({thumbUp:-1}) //sort in descending order
.toArray()
.then((data) => {
response.render("index.ejs", { info: data });
})
.catch((error) => console.error(error));
});
app.post("/addStudent", (request, response) => {
db.collection("contacts")
.insertOne(request.body)
.then((result) => {
console.log("Rapper Added");
response.redirect("/");
})
.catch((error) => console.error(error));
});
app.put("/addStudent", (request, response) => {
if (request.body.thumbUp !== undefined) {
db.collection("contacts")
.findOneAndUpdate(
{
Name: request.body.Name,
StudentId: request.body.StudentId,
},
{
$set: {
thumbUp: request.body.thumbUp + 1,
},
},
{
sort: { _id: -1 },
upsert: true,
}
)
.then((result) => {
console.log("Added One Like");
response.json("Like Added");
})
.catch((error) => console.error(error));
} else if (request.body.thumbDown !== undefined) {
db.collection("contacts")
.findOneAndUpdate(
{
Name: request.body.Name,
StudentId: request.body.StudentId,
},
{
$set: {
thumbDown: request.body.thumbDown + 1,
},
},
{
sort: { _id: -1 },
upsert: true,
}
)
.then((result) => {
console.log("Added One Dislike");
response.json("Dislike Added");
})
.catch((error) => console.error(error));
}
});
app.delete("/addStudent", (request, response) => {
db.collection("contacts")
.deleteOne({
Name: request.body.Name,
StudentId: request.body.StudentId,
})
.then((result) => {
console.log("Student Deleted");
response.json("Studnet Deleted");
})
.catch((error) => console.error(error));
});