-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.js
112 lines (94 loc) · 3.02 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
111
112
var express = require("express");
var path = require("path");
var bodyParser = require("body-parser");
var mongodb = require("mongodb");
var ObjectID = mongodb.ObjectID;
var PROJECTS_COLLECTION = "projects";
var app = express();
app.use(express.static(__dirname + "/public"));
app.use(bodyParser.json());
// Create a database variable outside of the database connection callback to reuse the connection pool in your app.
var db;
// Connect to the database before starting the application server.
mongodb.MongoClient.connect(process.env.MONGODB_URI, function (err, database) {
if (err) {
console.log(err);
process.exit(1);
}
// Save database object from the callback for reuse.
db = database;
console.log("Database connection ready");
// Initialize the app.
var server = app.listen(process.env.PORT || 8080, function () {
var port = server.address().port;
console.log("App now running on port", port);
});
});
// Project API ROUTES BELOW
// Generic error handler used by all endpoints.
function handleError(res, reason, message, code) {
console.log("ERROR: " + reason);
res.status(code || 500).json({"error": message});
}
/* "/project"
* GET: finds all project
* POST: creates a new contact
*/
app.get("/projects", function(req, res) {
db.collection(PROJECTS_COLLECTION).find({}).toArray(function(err, docs) {
if (err) {
handleError(res, err.message, "Failed to get projects.");
} else {
res.status(200).json(docs);
}
});
});
app.post("/projects", function(req, res) {
var newProject = req.body;
newProject.createDate = new Date();
console.log(req.body)
if (!(req.body.name || req.body.required)) {
handleError(res, "Invalid user input", "Must provide a project name and donation amount.", 400);
}
db.collection(PROJECTS_COLLECTION).insertOne(newProject, function(err, doc) {
if (err) {
handleError(res, err.message, "Failed to create new projects.");
} else {
res.status(201).json(doc.ops[0]);
}
});
});
/* "/contacts/:id"
* GET: find project by id
* PUT: update project by id
* DELETE: deletes project by id
*/
app.get("/projects/:id", function(req, res) {
db.collection(PROJECTS_COLLECTION).findOne({ _id: new ObjectID(req.params.id) }, function(err, doc) {
if (err) {
handleError(res, err.message, "Failed to get contact");
} else {
res.status(200).json(doc);
}
});
});
app.put("/projects/:id", function(req, res) {
var updateDoc = req.body;
delete updateDoc._id;
db.collection(PROJECTS_COLLECTION).updateOne({_id: new ObjectID(req.params.id)}, updateDoc, function(err, doc) {
if (err) {
handleError(res, err.message, "Failed to update contact");
} else {
res.status(204).end();
}
});
});
app.delete("/project/:id", function(req, res) {
db.collection(PROJECTS_COLLECTION).deleteOne({_id: new ObjectID(req.params.id)}, function(err, result) {
if (err) {
handleError(res, err.message, "Failed to delete contact");
} else {
res.status(204).end();
}
});
});