app.js 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. // express and http
  2. var express = require('express');
  3. var app = express();
  4. var http = require('http').Server(app);
  5. // view engine setup
  6. var path = require('path');
  7. app.set('views', path.join(__dirname, 'views'));
  8. app.set('view engine', 'hbs');
  9. // logging
  10. var logger = require('morgan');
  11. app.use(logger('dev'));
  12. // Sockets
  13. var io = require('socket.io').listen(http);
  14. io.on('connection', function(socket){
  15. console.log('a user connected');
  16. });
  17. var routes = require('./routes/index');
  18. // Unused (for now) cookies and favicons
  19. //var favicon = require('serve-favicon');
  20. //var cookieParser = require('cookie-parser');
  21. // uncomment after placing your favicon in /public
  22. //app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
  23. //app.use(cookieParser());
  24. app.use(express.static(path.join(__dirname, 'public')));
  25. app.use('/', routes);
  26. // catch 404 and forward to error handler
  27. app.use(function(req, res, next) {
  28. var err = new Error('Not Found');
  29. err.status = 404;
  30. next(err);
  31. });
  32. // error handlers
  33. // development error handler
  34. // will print stacktrace
  35. if (app.get('env') === 'development') {
  36. app.use(function(err, req, res, next) {
  37. res.status(err.status || 500);
  38. res.render('error', {
  39. message: err.message,
  40. error: err
  41. });
  42. });
  43. }
  44. // production error handler
  45. // no stacktraces leaked to user
  46. app.use(function(err, req, res, next) {
  47. res.status(err.status || 500);
  48. res.render('error', {
  49. message: err.message,
  50. error: {}
  51. });
  52. });
  53. module.exports = app;