-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.js
More file actions
120 lines (101 loc) · 3.38 KB
/
index.js
File metadata and controls
120 lines (101 loc) · 3.38 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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
const express = require("express");
const app = express();
const sql = require("mssql");
const { environment } = require("./environment");
async function main() {
const pool = new sql.ConnectionPool(environment.databaseConfig);
await pool.connect();
const cors = require("cors");
app.use(
cors({
origin: "http://localhost:4200",
})
);
const bodyParser = require("body-parser");
app.use(bodyParser.json());
app.get("/cars", async (request, response) => {
const id = request.query.id;
try {
if (id) {
const queryResult = await pool
.request()
.input("id", sql.Int(), id)
.query("SELECT * FROM Cars WHERE Id = @id");
const car = queryResult.recordset[0];
response.send(car);
} else {
const queryResult = await pool.request().query("SELECT * FROM Cars");
const cars = queryResult.recordset;
response.send(cars);
}
} catch (err) {
console.error(err);
response.status(500).send("An error occured!");
}
});
app.post("/cars", async (request, response) => {
const car = request.body;
try {
const result = await pool
.request()
.input("model", sql.NVarChar(256), car.model)
.input("manufacturer", sql.NVarChar(128), car.manufacturer)
.input("price", sql.Money(), car.price)
.input("year", sql.Int(), car.year)
.query(
"INSERT INTO Cars (Model, Manufacturer, Price, Year) OUTPUT INSERTED.* VALUES (@model, @manufacturer, @price, @year)"
);
console.log(`Affected ${result.rowsAffected} rows after inserting new car`);
const createdCar = result.recordset.at(0);
response.status(201).send(createdCar);
} catch (err) {
console.error(err);
response.status(500).send("An error occured!");
}
});
app.put("/cars", async (request, response) => {
const car = request.body;
try {
const result = await pool
.request()
.input("id", sql.Int(), car.id)
.input("model", sql.NVarChar(256), car.model)
.input("manufacturer", sql.NVarChar(128), car.manufacturer)
.input("price", sql.Money(), car.price)
.input("year", sql.Int(), car.year)
.query(
"UPDATE Cars SET Model = @model, Manufacturer = @manufacturer, Price = @price, Year = @Year OUTPUT INSERTED.* WHERE Id = @id"
);
console.log(`Affected ${result.rowsAffected} rows after updating car`);
const updatedCar = result.recordset.at(0);
response.status(201).send(updatedCar);
} catch (err) {
console.log(err);
response.status(500).send("An error occured!");
}
});
app.delete("/cars", async (request, response) => {
const id = request.body.id;
try {
const rowsAffected = (
await pool.request().input("id", sql.Int(), id).query("DELETE FROM Cars WHERE Id = @id")
).rowsAffected;
console.log(`Affected ${rowsAffected} rows after deleting car`);
response.sendStatus(204);
} catch (err) {
console.log(err);
response.status(500).send("An error occured!");
}
});
const port = 3000;
const host = "localhost";
app.listen(port, host, () => {
console.log(`Server started at ${host}:${port}`);
});
const nodeCleanup = require("node-cleanup");
nodeCleanup(() => {
console.log("Closing database connections");
pool.close();
});
}
main();