index.js 3.2 KB

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