-
Notifications
You must be signed in to change notification settings - Fork 1
/
server.js
95 lines (81 loc) · 2.79 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
/*
Le package `dotenv` permet de definir des variables d'environnement
dans le fichier `.env`. Nous utilisons le fichier `.slugignore` pour ignorer
le fichier `.env` dans l'environnement Heroku
*/
require("dotenv").config();
/*
Le package `mongoose` est un ODM (Object-Document Mapping) permettant de
la manipulation des documents de la base de données comme si s'agissait d'objets
*/
const mongoose = require("mongoose");
mongoose.connect(
process.env.MONGODB_URI,
{
useNewUrlParser: true
},
function(err) {
if (err) console.error("Could not connect to mongodb.");
}
);
const express = require("express");
const app = express();
/*
Le package `helmet` est une collection de protections contre certaines
vulnérabilités HTTP
*/
const helmet = require("helmet");
app.use(helmet());
/*
Les réponses (> 1024 bytes) du serveur seront compressées au format GZIP pour
diminuer la quantité d'informations transmises
*/
const compression = require("compression");
app.use(compression());
// Parse le `body` des requêtes HTTP reçues
const formidableMiddleware = require("express-formidable");
app.use(formidableMiddleware());
// Initialisation des models
const User = require("./models/User");
app.get("/", function(req, res) {
res.send("Welcome to the leboncoin API.");
});
/*
`Cross-Origin Resource Sharing` est un mechanisme permettant d'autoriser les
requêtes provenant d'un nom de domaine différent. Ici, nous autorisons l'API
à repondre aux requêtes AJAX venant d'autres serveurs.
*/
const cors = require("cors");
app.use("/api", cors());
// Les routes sont séparées dans plusieurs fichiers
const coreRoutes = require("./routes/core.js");
const renewRoutes = require("./routes/renew.js");
const userRoutes = require("./routes/user.js");
const offerRoutes = require("./routes/offer.js");
// Les routes relatives aux utilisateurs auront pour prefix d'URL `/user`
app.use("/api", coreRoutes);
app.use("/api/renew", renewRoutes);
app.use("/api/user", userRoutes);
app.use("/api/offer", offerRoutes);
/*
Toutes les méthodes HTTP (GET, POST, etc.) des pages non trouvées afficheront
une erreur 404
*/
app.all("*", function(req, res) {
res.status(404).json({ error: "Not Found" });
});
/*
Le dernier middleware de la chaîne gérera les d'erreurs. Ce `error handler`
doit définir obligatoirement 4 paramètres `err, req, res, next`.
Définition d'un middleware : https://expressjs.com/en/guide/writing-middleware.html
*/
app.use(function(err, req, res, next) {
if (res.statusCode === 200) res.status(400);
console.error(err);
// if (process.env.NODE_ENV === "production") err = "An error occurred";
res.json({ error: err });
});
app.listen(process.env.PORT, function() {
console.log(`leboncoin API running on port ${process.env.PORT}`);
console.log(`Current environment is ${process.env.NODE_ENV}`);
});