app.js 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. 'use strict';
  2. // nodejs modules
  3. const path = require('path'),
  4. fs = require('fs'),
  5. os = require('os');
  6. process.env.NODE_CONFIG_DIR = `${__dirname}/config`;
  7. // npm modules
  8. const express = require('express'),
  9. session = require('express-session'),
  10. mongoose = require('mongoose'),
  11. MongoStore = require('connect-mongo')(session),
  12. bodyParser = require('body-parser'),
  13. config = require('config'),
  14. request = require('request'),
  15. passport = require('passport'),
  16. bcrypt = require('bcrypt'),
  17. LocalStrategy = require('passport-local').Strategy,
  18. GitHubStrategy = require('passport-github').Strategy,
  19. DiscordStrategy = require('passport-discord').Strategy,
  20. passportSocketIo = require("passport.socketio");
  21. // global module
  22. const global = require('./logic/global');
  23. // database
  24. const MongoDB = mongoose.connect('mongodb://172.16.0.1:27017/musare').connection;
  25. MongoDB.on('error', (err) => {
  26. console.log('Database error: ' + err.message);
  27. });
  28. MongoDB.once('open', () => {
  29. console.log('Connected to database');
  30. setupExpress();
  31. });
  32. // setup express and socket.io
  33. function setupExpress() {
  34. const app = express(MongoDB);
  35. const server = app.listen(80);
  36. global.io = require('socket.io')(server);
  37. // other custom modules
  38. const coreHandler = require('./logic/coreHandler'),
  39. socketHandler = require('./logic/socketHandler'),
  40. expressHandler = require('./logic/expressHandler');
  41. global.db = {
  42. user: require('./schemas/user')(mongoose),
  43. station: require('./schemas/station')(mongoose)
  44. };
  45. const mongoStore = new MongoStore({'mongooseConnection': MongoDB});
  46. app.use(session({
  47. secret: config.get('secret'),
  48. key: 'connect.sid',
  49. store: mongoStore,
  50. resave: true,
  51. saveUninitialized: true
  52. }));
  53. global.io.use(passportSocketIo.authorize({
  54. cookieParser: require('cookie-parser'),
  55. key: 'connect.sid',
  56. secret: config.get('secret'),
  57. store: mongoStore,
  58. success: (data, accept) => {
  59. accept();
  60. },
  61. fail: (data, message, error, accept) => {
  62. if (error) throw new Error(message);
  63. accept();
  64. }
  65. }));
  66. app.use(passport.initialize());
  67. app.use(passport.session());
  68. passport.serializeUser((user, done) => {
  69. done(null, user);
  70. });
  71. passport.deserializeUser((user, done) => {
  72. done(null, user);
  73. });
  74. passport.use(new LocalStrategy({usernameField: 'email'}, (email, password, done) => {
  75. process.nextTick(() => {
  76. global.db.user.findOne({"email.address": email}, (err, user) => {
  77. if (err) return done(err);
  78. if (!user) return done(null, false);
  79. bcrypt.compare(password, user.services.password.password, function(err, res) {
  80. if (res) {
  81. return done(null, user);
  82. } else if (err) {
  83. return done(err);
  84. } else {
  85. return done(null, false);
  86. }
  87. });
  88. });
  89. });
  90. }));
  91. app.use(bodyParser.json());
  92. app.use(bodyParser.urlencoded({
  93. extended: true
  94. }));
  95. app.get('*', (req, res) => {
  96. res.redirect('/');
  97. });
  98. socketHandler(coreHandler, global.io);
  99. expressHandler(coreHandler, app);
  100. }