app.js 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  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 = `${process.cwd()}/backend/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://localhost: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. song: require('./schemas/song')(mongoose),
  45. queueSong: require('./schemas/queueSong')(mongoose)
  46. };
  47. const mongoStore = new MongoStore({'mongooseConnection': MongoDB});
  48. app.use(session({
  49. secret: config.get('secret'),
  50. key: 'connect.sid',
  51. store: mongoStore,
  52. resave: true,
  53. saveUninitialized: true
  54. }));
  55. global.io.use(passportSocketIo.authorize({
  56. cookieParser: require('cookie-parser'),
  57. key: 'connect.sid',
  58. secret: config.get('secret'),
  59. store: mongoStore,
  60. success: function (data, accept) {
  61. console.log('successful connection to socket.io');
  62. accept();
  63. },
  64. fail: function (data, message, error, accept) {
  65. console.log(message);
  66. if (error && message !== "Passport was not initialized")
  67. throw new Error(message);
  68. accept();
  69. }
  70. }));
  71. app.use(passport.initialize());
  72. app.use(passport.session());
  73. passport.serializeUser((user, done) => {
  74. done(null, user);
  75. });
  76. passport.deserializeUser((user, done) => {
  77. done(null, user);
  78. });
  79. passport.use(new LocalStrategy({usernameField: 'email'}, (email, password, done) => {
  80. console.log(email, password);
  81. process.nextTick(() => {
  82. console.log(email, password);
  83. global.db.user.findOne({"email.address": email}, (err, user) => {
  84. if (err) return done(err);
  85. if (!user) return done(null, false);
  86. bcrypt.compare(password, user.services.password.password, function(err, res) {
  87. if (res) {
  88. return done(null, user);
  89. } else if (err) {
  90. return done(err);
  91. } else {
  92. return done(null, false);
  93. }
  94. });
  95. });
  96. });
  97. }));
  98. passport.use(new GitHubStrategy({
  99. clientID: config.get("apis.github.client"),
  100. clientSecret: config.get("apis.github.secret"),
  101. callbackURL: `${config.get("domain")}/users/github/callback`
  102. },
  103. function(accessToken, refreshToken, profile, done) {
  104. console.log('new github auth', accessToken, refreshToken, profile);
  105. /*User.findOrCreate({ githubId: profile.id }, function (err, user) {
  106. return cb(err, user);
  107. });*/
  108. global.db.user.findOne({"services.github.id": profile._json.id}, (err, id) => {
  109. if (err) return done(err);
  110. if (!id) {
  111. global.db.user.findOne({"username": profile.username}, (err, username) => {
  112. if (err) return done(err);
  113. if (!username) {
  114. let newUser = new global.db.user({
  115. username: profile.username,
  116. services: {
  117. discord: {
  118. id: profile.id
  119. }
  120. }
  121. });
  122. newUser.save(err => {
  123. if (err) throw err;
  124. return done(null, newUser);
  125. });
  126. } else {
  127. return done(null, user);
  128. }
  129. });
  130. }
  131. });
  132. }
  133. ));
  134. passport.use(new DiscordStrategy({
  135. clientID: config.get("apis.discord.client"),
  136. clientSecret: config.get("apis.discord.secret"),
  137. callbackURL: `${config.get("domain")}/users/discord/callback`
  138. },
  139. function(accessToken, refreshToken, profile, done) {
  140. console.log('new discord auth', accessToken, refreshToken, profile);
  141. global.db.user.findOne({"services.discord.id": profile.id}, (err, id) => {
  142. if (err) return done(err);
  143. if (!id) {
  144. global.db.user.findOne({"username": profile.username}, (err, username) => {
  145. if (err) return done(err);
  146. if (!username) {
  147. let newUser = new global.db.user({
  148. username: profile.username,
  149. services: {
  150. discord: {
  151. id: profile.id
  152. }
  153. }
  154. });
  155. newUser.save(err => {
  156. if (err) throw err;
  157. return done(null, newUser);
  158. });
  159. } else {
  160. return done(null, user);
  161. }
  162. });
  163. }
  164. });
  165. }
  166. ));
  167. app.use(bodyParser.json());
  168. app.use(bodyParser.urlencoded({
  169. extended: true
  170. }));
  171. app.use(express.static(__dirname + '/../frontend/build/'));
  172. app.get('*', (req, res) => {
  173. res.redirect('/');
  174. });
  175. socketHandler(coreHandler, global.io);
  176. expressHandler(coreHandler, app);
  177. }