Aufgabe 3: Rest-API funktioniert

This commit is contained in:
Selina 2019-01-05 14:43:01 +01:00
parent 712688969e
commit 489f2c3baf
2 changed files with 71 additions and 77 deletions

View file

@ -1,11 +1,9 @@
// DO NOT CHANGE! // DO NOT CHANGE!
//init app with express, util, body-parser, csv2json //init app with express, util, body-parser, csv2json
var express = require('express'); const express = require('express');
var app = express(); const app = express()
var sys = require('util'); const path = require('path');
var path = require('path'); const bodyParser = require('body-parser');
var bodyParser = require('body-parser');
var Converter = require("csvtojson").Converter;
//register body-parser to handle json from res / req //register body-parser to handle json from res / req
app.use(bodyParser.json()); app.use(bodyParser.json());
@ -20,63 +18,55 @@ app.use(express.static(path.join(__dirname, "public")));
****************************** csv2json ********************************* ****************************** csv2json *********************************
**************************************************************************/ **************************************************************************/
const csv = require('csvtojson') const csv = require('csvtojson');
var json; let csvdata;
csv() csv()
.fromFile("world_data.csv") .fromFile("world_data.csv")
.then((jsonObj) => { .then((jsonObj) => {
json = jsonObj; csvdata = jsonObj;
}) });
/************************************************************************** /**************************************************************************
********************** handle HTTP METHODS *********************** ********************** handle HTTP METHODS ***********************
**************************************************************************/ **************************************************************************/
// ------------------------------ GET ------------------------------ // ------------------------------ GET ------------------------------
app.get("/items", function (req, res) { app.get("/items", function (req, res) {
console.log(json); res.send(csvdata);
res.send(json);
}); });
app.get("/items/:id", function (req, res) { app.get("/items/:id", function (req, res) {
var requested_id = parseInt(req.params.id); const requested_id = parseInt(req.params.id);
var answer = ["Err", "No such id " + requested_id + " in database"]; let answer = "Err, No such id " + requested_id + " in database";
for (var i = 0; i < json.length; i++) { for (let i = 0; i < csvdata.length; i++) {
if (json[i].id == requested_id) { if (parseInt(csvdata[i].id) === requested_id) {
answer = [json[i]]; answer = csvdata[i];
} }
} }
res.send(answer); res.send(answer);
}); });
app.get("/items/:id1/:id2", function (req, res) { app.get("/items/:id1/:id2", function (req, res) {
var first_requested_id = parseInt(req.params.id1); const first_requested_id = parseInt(req.params.id1);
var second_requested_id = parseInt(req.params.id2); const second_requested_id = parseInt(req.params.id2);
var answer = ["Err", "Range not possible"]; let answer = "Err, Range not possible";
// check that first id is bigger than 0 if (id_exists(first_requested_id) && id_exists(second_requested_id)
// and the second one is the bigger one && first_requested_id < second_requested_id) {
if (first_requested_id >= 0 && second_requested_id > first_requested_id) { answer = [];
var enable_push = false; for (let i = 0; i < csvdata.length; i++) {
if (parseInt(csvdata[i].id) >= first_requested_id) {
for (var i; i < json.length; i++) { if (parseInt(csvdata[i].id) <= second_requested_id) {
// enable push when the first id is found answer.push(csvdata[i]);
if (parseInt(json[i].id) == first_requested_id) { }
enable_push = true;
}
// push key when enabled
if (enable_push) {
answer.push(json[i]);
}
// break when second id is found
if (parseInt(json[i].id) == second_requested_id) {
break;
} }
} }
} }
@ -84,66 +74,59 @@ app.get("/items/:id1/:id2", function (req, res) {
res.send(answer); res.send(answer);
}); });
app.get("/properties", function (req, res) { app.get("/properties", function (req, res) {
var answer = []; res.send(Object.keys(csvdata[0]));
for (var key in json[0]) {
answer.push(key);
}
res.send(answer);
}); });
app.get("/properties/:num", function (req, res) { app.get("/properties/:num", function (req, res) {
let num = parseInt(req.params.num); let num = parseInt(req.params.num);
var answer = ["Err", "No such property available"]; let answer = "Err, No such property available";
var i = 0; keys = Object.keys(csvdata[0]);
if (num >= 0 && num < keys.length) {
for (var key in json[0]) { answer = keys[num];
if (i == num) {
answer = [key];
break;
}
i++;
} }
res.send(answer); res.send(answer);
}) });
// ----------------------------- POST ------------------------------ // ----------------------------- POST ------------------------------
app.post("/items", function (req, res) { app.post("/items", function (req, res) {
var new_entry = req.body; const new_entry = req.body;
// set id // set id
var last_id = parseInt(json[json.length - 1].id); const last_id = parseInt(csvdata[csvdata.length - 1].id);
new_entry["id"] = (last_id + 1).toString(); new_entry["id"] = (last_id + 1).toString();
// add entry to json // add entry to csvdata
json.push(new_entry); csvdata.push(new_entry);
res.send("Added country " + new_entry.name + " to list!"); res.send("Added country " + new_entry.name + " to list!");
}); });
// ---------------------------- DELETE ----------------------------- // ---------------------------- DELETE -----------------------------
app.delete("/items", function (req, res) { app.delete("/items", function (req, res) {
var name = json[json.length - 1].name; const name = csvdata[csvdata.length - 1].name;
json.splice(-1, 1); csvdata.splice(-1, 1);
res.send("Deleted last country " + name + "!"); res.send("Deleted last country " + name + "!");
}); });
app.delete("/items/id", function (req, res) { app.delete("/items/:id", function (req, res) {
var requested_id = parseInt(req.params.id); const requested_id = parseInt(req.params.id);
var answer = ["Err", "No such id " + requested_id + "in database"]; let answer = "Err, No such id " + requested_id + "in database";
for (var i = 0; i < json.length; i++) {
if (json[i].id == requested_id) {
json.splice(i, 1);
answer = ["Item " + requested_id + " deleted successfully."];
for (let i = 0; i < csvdata.length; i++) {
if (parseInt(csvdata[i].id) === requested_id) {
csvdata.splice(i, 1);
answer = "Item " + requested_id + " deleted successfully.";
break; break;
} }
} }
@ -153,8 +136,18 @@ app.delete("/items/id", function (req, res) {
// DO NOT CHANGE! // DO NOT CHANGE!
// bind server to port // bind server to port
var server = app.listen(3000, function () { const server = app.listen(3000, function () {
var host = server.address().address; console.log('Example app listening at http://localhost:3000');
var port = server.address().port; });
console.log('Example app listening at http://%s:%s', host, port);
});
const id_exists = (id) => {
for (let i = 0; i < csvdata.length; i++) {
if (parseInt(csvdata[i].id) === first_requested_id) {
return true;
}
}
return false;
};

View file

@ -4,7 +4,8 @@
"description": "", "description": "",
"main": "app.js", "main": "app.js",
"scripts": { "scripts": {
"test": "echo \"Error: no test specified\" && exit 1" "test": "echo \"Error: no test specified\" && exit 1",
"start": "node app.js"
}, },
"author": "TEAM_00", "author": "TEAM_00",
"license": "ISC", "license": "ISC",