-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
153 lines (132 loc) · 3.62 KB
/
app.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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
var expressSanitizer= require("express-sanitizer"),
methodOverride = require("method-override"),
bodyParser = require("body-parser"),
mongoose = require("mongoose"),
express = require("express"),
app = express();
// APP config
// var dburl = process.env.DATABASEURL || "mongodb://localhost/blog_app";
var dburl= "mongodb://nitish:[email protected]:61969/blog_app";
mongoose.connect(dburl);
app.use(bodyParser.urlencoded({extended:true}));
app.use(expressSanitizer());
app.use(methodOverride("_method"));
app.use(express.static("public"));
app.set("view engine","ejs");
app.use(function(req, res, next){
res.locals.isLoggedIn = isLoggedIn;
next();
});
// Mongoose config
var blogSchema = new mongoose.Schema({
title: String,
image: String,
body: String,
created: {type: Date, default: Date.now}
});
var Blog = mongoose.model("Blog", blogSchema);
var isLoggedIn = false;
// blog.create({
// title: "Sunrise",
// image: "https://source.unsplash.com/Aj6mvFNBXAA",
// body: "A beatiful sunrise spot between the cliffs with a beatiful couple."
// });
//ROOT ROUTE
app.get("/", (req, res)=>{
res.redirect("/blogs");
});
//INDEX ROUTE
app.get("/blogs", (req, res)=>{
Blog.find({}, (err, blogs)=>{
if(err){
console.log(err);
}
else {
res.render("index", {blogs: blogs});
}
});
});
// NEW ROUTE
app.get("/blogs/new", (req, res)=>{
res.render("new");
});
// CREATE ROUTE
app.post("/blogs", (req, res)=>{
req.body.blog.body = req.sanitize(req.body.blog.body);
Blog.create(req.body.blog, (err, blog)=>{
if(err)
res.render("new");
else
res.redirect("/blogs");
});
});
// SHOW ROUTE
app.get("/blogs/:id", (req, res)=>{
Blog.findById(req.params.id, (err, blog)=>{
if(err)
res.redirect("/blogs");
else{
res.render("show", {blog: blog});
}
});
});
// EDIT ROUTE
app.get("/blogs/:id/edit", LoggedIn, (req, res)=>{
Blog.findById(req.params.id, (err, blog)=>{
if(err)
res.redirect("/show/"+req.params.id);
else{
res.render("edit", {blog: blog});
}
});
});
// UPDATE ROUTE
app.put("/blogs/:id", LoggedIn, (req, res)=>{
req.body.blog.body = req.sanitize(req.body.blog.body);
Blog.findByIdAndUpdate(req.params.id, req.body.blog, (err, blog)=>{
if(err)
res.redirect("/blogs/"+req.params.id+"/edit");
else{
res.redirect("/blogs/"+req.params.id);
}
});;
});
// DELETE ROUTE
app.delete("/blogs/:id", LoggedIn, (req, res)=>{
Blog.findByIdAndRemove(req.params.id, (err)=>{
if(err)
res.redirect("/blogs/"+req.params.id);
else
res.redirect("/blogs");
})
});
// ADMIN ROUTE
app.get("/admin", (req, res)=>{
res.render("login");
});
app.post("/login", (req, res)=>{
// console.log("==============================");
// console.log(req.body);
if(req.body.email === "nitish" && req.body.pass === "password"){
isLoggedIn = true;
res.redirect("/blogs");
}
else
res.redirect("back");
});
app.post("/logout", (req, res)=>{
isLoggedIn = false;
res.redirect("/blogs");
});
//For non-existing ROUTES
app.get("*", (req, res)=>res.send("Page Not Found."));
app.post("*", (req, res)=>res.send("Page Not Found"));
function LoggedIn(req, res, next){
if(isLoggedIn)
return next();
return res.redirect("back");
}
// Listen to a PORT
app.listen(process.env.PORT, process.env.IP, ()=>{
console.log("Server Started!");
});