server.ts 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. import * as express from 'express';
  2. import { AddressInfo } from "net";
  3. import * as path from 'path';
  4. import * as bodyParser from 'body-parser';
  5. import route_index from './routes/index';
  6. const debug = require('debug')('my express app');
  7. const app = express();
  8. // view engine setup
  9. app.set('views', [path.join(__dirname, 'views'), path.join(__dirname, 'views/template')]);
  10. app.set('view engine', 'pug');
  11. app.use(express.static(path.join(__dirname, 'public')));
  12. app.use(bodyParser.json());
  13. app.use(bodyParser.urlencoded({ extended: true }));
  14. app.use('/', route_index);
  15. // catch 404 and forward to error handler
  16. app.use((req, res, next) => {
  17. const err: any = new Error('Not Found');
  18. err['status'] = 404;
  19. next(err);
  20. });
  21. // error handlers
  22. // development error handler
  23. // will print stacktrace
  24. if (app.get('env') === 'development') {
  25. app.use((err: any, req: Express.Request, res: any, next: any) => { // eslint-disable-line @typescript-eslint/no-unused-vars
  26. res.status(err['status'] || 500);
  27. res.render('error', {
  28. message: err.message,
  29. error: err
  30. });
  31. });
  32. }
  33. // production error handler
  34. // no stacktraces leaked to user
  35. app.use((err: any, req: any, res: any, next: any) => { // eslint-disable-line @typescript-eslint/no-unused-vars
  36. res.status(err.status || 500);
  37. res.render('error', {
  38. message: err.message,
  39. error: {}
  40. });
  41. });
  42. app.set('port', process.env.port || 1337);
  43. const server = app.listen(app.get('port'), function () {
  44. debug(`Express server listening on port ${(server.address() as AddressInfo).port}`);
  45. });