index.js 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. const express = require('express');
  2. const bodyparser = require('body-parser');
  3. const passport = require('passport');
  4. const mongoose = require('mongoose');
  5. const cors = require('cors');
  6. // const config = require('./config/db.config');
  7. const userRoutes = require('./routes/user');
  8. const employeeRoutes = require('./routes/employee');
  9. const authRoutes = require('./routes/auth');
  10. const oauthRoutes = require('./routes/oauth');
  11. const ticketRoutes = require('./routes/ticket');
  12. const emailsRoutes = require('./routes/emailing');
  13. //const authGoogle = require('./routes/google');
  14. const authFacebook = require('./routes/facebook');
  15. const tirageRoutes = require('./routes/tirage');
  16. const contactRoutes = require('./routes/contact');
  17. const restaurantRoutes = require('./routes/restaurant');
  18. const Logger = require('./logging')
  19. //metrics
  20. const makeApiMiddleware = require("api-express-exporter");
  21. //const apiMetrics = require('prometheus-api-metrics');
  22. const promBundle = require("express-prom-bundle");
  23. const metricsMiddleware = promBundle({includeMethod: true, includePath: true});
  24. const app = express();
  25. Logger.error('hello world', 'Nan c est juste pour tester les logs')
  26. app.use(metricsMiddleware);
  27. //app.use(apiMetrics());
  28. //metrics
  29. app.use(makeApiMiddleware());
  30. app.use(cors());
  31. app.get("/api", (req, res) => {
  32. res.status(200).send("Api Works.");
  33. });
  34. // var corsOptions = {
  35. // origin: 'https://localhost:4200',
  36. // optionsSuccessStatus: 200
  37. // }
  38. //Définition des CORS Middleware
  39. app.use(function(req, res, next) {
  40. //res.header("Access-Control-Allow-Origin", "*");
  41. res.setHeader("Access-Control-Allow-Origin", "*");
  42. res.setHeader(
  43. "Access-Control-Allow-Headers",
  44. "X-Requested-With,content-type, Accept,Authorization,Origin"
  45. );
  46. res.setHeader(
  47. "Access-Control-Allow-Methods",
  48. "GET, POST, OPTIONS, PUT, PATCH, DELETE"
  49. );
  50. res.setHeader("Access-Control-Allow-Credentials", true);
  51. next();
  52. });
  53. // parse requests body params
  54. app.use(bodyparser.json());
  55. app.use(bodyparser.urlencoded({extended: true}));
  56. app.use(passport.initialize());
  57. //simple route
  58. app.use('/api/users', userRoutes );
  59. app.use('/api/employees', employeeRoutes );
  60. app.use('/api/tickets', ticketRoutes );
  61. app.use('/api/auth', authRoutes );
  62. app.use('/api/auth', oauthRoutes );
  63. //app.use('/api/auth', authGoogle );
  64. app.use('/api/emails', emailsRoutes );
  65. //app.use('/api/auth/google', authGoogle );
  66. //app.use('/api/auth/facebook', authFacebook );
  67. app.use('/api/tirage', tirageRoutes );
  68. app.use('/api/contact', contactRoutes );
  69. app.use('/api/restaurants', restaurantRoutes );
  70. //connexion database
  71. require('./lib/db');
  72. //listen for requests
  73. const PORT = process.env.PORT || 4000;
  74. app.listen(PORT, () => {
  75. console.log(`Api listen on port ${PORT}.`);
  76. });