-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
99 lines (92 loc) · 2.68 KB
/
Copy pathserver.js
File metadata and controls
99 lines (92 loc) · 2.68 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
const express = require("express");
const app = express();
const bodyParser = require("body-parser");
const MongoClient = require("mongodb").MongoClient;
var db, collection;
const dbName = "palindrome";
const url =
`mongodb+srv://abdullahidev:Github12@cluster0.rasf3io.mongodb.net/${dbName}?retryWrites=true&w=majority`;
app.listen(3500, () => {
MongoClient.connect(
url,
{ useNewUrlParser: true, useUnifiedTopology: true },
(error, client) => {
if (error) {
throw error;
}
db = client.db();
console.log("Connected to `" + dbName + "`!");
}
);
});
app.set("view engine", "ejs");
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());
app.use(express.static("public"));
app.get("/", (req, res) => {
db.collection("results")
.find()
.toArray((err, allDocuments) => {
if (err) return console.log(err);
res.render("index.ejs", { palindromes : allDocuments });
});
});
app.post("/palindromesave", (req, res) => {
db.collection("results").insertOne(
{ userWordinput: req.body.word, userResults: req.body.dbResult },
(err, result) => {
if (err) return console.log(err);
console.log("saved to database");
res.redirect("/");
}
);
});
app.delete("/delete", (req, res) => {
db.collection("results").findOneAndDelete(
{ userWordinput: req.body.deleteWord, userResults: req.body.deleteResult },
(err, result) => {
if (err) return res.send(500, err);
res.send("Message deleted!");
}
);
});
// previous logic on palindrome applied to express!
// reference link https://stackoverflow.com/questions/6912584/how-to-get-get-query-string-variables-in-express-js-on-node-js
app.get ('/palindromecheck',(req,res)=> {
let result = 'false'
let word = req.query.word
if (word){
// check if params word is a palindrome
// convert to lowercase
word = word.toLowerCase();
var reverse = word.split('').reverse().join('').toLowerCase();
if (word == reverse){
result = 'true';
}
}
const objToJson = {
result: result
}
// reference link https://stackoverflow.com/questions/19696240/proper-way-to-return-json-using-node-or-express
res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(objToJson));
})
// ====================== Refer Later ==============================
app.put("/messages", (req, res) => {
db.collection("results").findOneAndUpdate(
{ name: req.body.name, msg: req.body.msg },
{
$set: {
thumbUp: req.body.thumbUp + 1,
},
},
{
sort: { _id: -1 },
upsert: true,
},
(err, result) => {
if (err) return res.send(err);
res.send(result);
}
);
});