// Initialisation de l'application
const express = require('express');
const mongoose = require('mongoose');
const cors = require('cors');
const helmet = require('helmet');
const rateLimit = require('express-rate-limit');
// Configuration de l'application
const app = express();
const PORT = process.env.PORT || 3000;
// Middlewares
app.use(cors());
app.use(helmet());
app.use(express.json());
app.use(express.urlencoded({ extended: true }));
// Limiteur de requêtes
const limiter = rateLimit({
windowMs: 15 * 60 * 1000, // 15 minutes
max: 100 // limite chaque IP à 100 requêtes par fenêtre
});
app.use(limiter);
// Connexion à la base de données
mongoose.connect(process.env.DB_URI, {
useNewUrlParser: true,
useUnifiedTopology: true,
useCreateIndex: true
})
.then(() => console.log('Connecté à MongoDB'))
.catch(err => console.error('Erreur de connexion:', err));
// Routes
const apiRoutes = require('./routes/api');
const authRoutes = require('./routes/auth');
const adminRoutes = require('./routes/admin');
app.use('/api', apiRoutes);
app.use('/auth', authRoutes);
app.use('/admin', adminRoutes);
// Gestion des erreurs
app.use((err, req, res, next) => {
console.error(err.stack);
res.status(500).json({ error: 'Erreur interne du serveur' });
});
// Démarrage du serveur
app.listen(PORT, () => {
console.log(`Serveur démarré sur le port ${PORT}`);
});