Non puoi selezionare più di 25 argomenti Gli argomenti devono iniziare con una lettera o un numero, possono includere trattini ('-') e possono essere lunghi fino a 35 caratteri.
 
 
 

107 righe
2.1 KiB

  1. #!/usr/bin/env node
  2. require('dotenv').config({
  3. path: `./env-files/${process.env.NODE_ENV || 'development'}.env`,
  4. });
  5. /**
  6. * Module dependencies.
  7. */
  8. const debug = require('debug')('express:www');
  9. const http = require('http');
  10. const app = require('../app');
  11. const logger = require('../logger');
  12. const { HTTP_HOST, PORT } = process.env;
  13. /**
  14. * Normalize a port into a number, string, or false.
  15. */
  16. function normalizePort(val) {
  17. const port = parseInt(val, 10);
  18. if (Number.isNaN(port)) {
  19. // named pipe
  20. return val;
  21. }
  22. if (port >= 0) {
  23. // port number
  24. return port;
  25. }
  26. return false;
  27. }
  28. /**
  29. * Get port from environment and store in Express.
  30. */
  31. const port = normalizePort(PORT || '14015');
  32. app.set('port', port);
  33. /**
  34. * Event listener for HTTP server "error" event.
  35. */
  36. function onError(error) {
  37. if (error.syscall !== 'listen') {
  38. throw error;
  39. }
  40. const bind = typeof port === 'string' ? `Pipe ${port}` : `Port ${port}`;
  41. // handle specific listen errors with friendly messages
  42. switch (error.code) {
  43. case 'EACCES':
  44. logger.error(`${bind} requires elevated privileges`);
  45. process.exit(1);
  46. break;
  47. case 'EADDRINUSE':
  48. logger.error(`${bind} is already in use`);
  49. process.exit(1);
  50. break;
  51. default:
  52. throw error;
  53. }
  54. }
  55. /**
  56. * Create HTTP server.
  57. */
  58. const server = http.createServer(app);
  59. /**
  60. * Event listener for HTTP server "listening" event.
  61. */
  62. function onListening() {
  63. const addr = server.address();
  64. const bind = typeof addr === 'string' ? `pipe ${addr}` : `port ${addr.port}`;
  65. debug(`Listening on ${bind}`);
  66. console.log(`Listening on ${bind}`);
  67. }
  68. process.on('uncaughtException', uncaughtException => {
  69. logger.error(
  70. 'Uncaught Exception at: %s - message: %s',
  71. uncaughtException.stack,
  72. uncaughtException.message
  73. );
  74. });
  75. process.on('unhandledRejection', reason => {
  76. logger.error('Unhandled Rejection at: %s - message: %s', reason.stack, reason.message);
  77. });
  78. /**
  79. * Listen on provided port, on all network interfaces.
  80. */
  81. server.listen(port, HTTP_HOST);
  82. server.on('error', onError);
  83. server.on('listening', onListening);