app.ts 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. if (process.env.DEBUG_FULL !== undefined)
  2. process.env.DEBUG = process.env.DEBUG || "*";
  3. import * as express from 'express';
  4. import { AddressInfo } from "net";
  5. import * as path from 'path';
  6. import * as bodyParser from 'body-parser';
  7. import route_index from './routes/index';
  8. import route_entity from './routes/entity';
  9. import { route_login, route_logout } from './routes/login';
  10. import LDAPFactory from './src/ldapInterface';
  11. import { Session } from './src/Security';
  12. import Security from './src/Security';
  13. const debug = require('debug')('LDAPManager:http');
  14. const app = express();
  15. declare global {
  16. namespace Express {
  17. interface Request {
  18. ldapManager: LDAPFactory
  19. session: Session | null
  20. isUserLogged: boolean
  21. }
  22. }
  23. }
  24. // view engine setup
  25. app.set('views', path.join(__dirname, 'views'));
  26. app.set('view engine', 'pug');
  27. app.use(express.static(path.join(__dirname, 'public')));
  28. app.use(bodyParser.json());
  29. app.use(bodyParser.urlencoded({ extended: true }));
  30. app.use((req, res, next) => {
  31. req.ldapManager = new LDAPFactory();
  32. req.session = Security.GetSession(req);
  33. req.isUserLogged = Security.IsUserLogged(req) || process.env.DEBUG_FULL !== undefined;
  34. res.socket && res.socket.once('close', () => {
  35. req.ldapManager.Release();
  36. });
  37. next();
  38. });
  39. //app.use('/', route_index);
  40. app.use('/', route_index);
  41. app.use('/entity', route_entity);
  42. app.use('/login', route_login);
  43. app.use('/logout', route_logout);
  44. // catch 404 and forward to error handler
  45. app.use((req, res, next) => {
  46. const err: any = new Error('Not Found');
  47. err['status'] = 404;
  48. next(err);
  49. });
  50. // error handlers
  51. // development error handler
  52. // will print stacktrace
  53. if (app.get('env') === 'development') {
  54. app.use((err: any, req: Express.Request, res: any, next: any) => { // eslint-disable-line @typescript-eslint/no-unused-vars
  55. res.status(err[ 'status' ] || 500);
  56. res.render('error', {
  57. message: err.message,
  58. error: err
  59. });
  60. });
  61. }
  62. // production error handler
  63. // no stacktraces leaked to user
  64. app.use((err: any, req: any, res: any, next: any) => { // eslint-disable-line @typescript-eslint/no-unused-vars
  65. res.status(err.status || 500);
  66. res.render('error', {
  67. message: err.message,
  68. error: {}
  69. });
  70. });
  71. app.set('port', process.env.PORT || 8080);
  72. const server = app.listen(app.get('port'), function () {
  73. debug(`Express server listening on port ${(server.address() as AddressInfo).port}`);
  74. });