Using clusters instead of domains.

Appended all controller variables with Controller to make it more explicit.
This commit is contained in:
Sahat Yalkabov
2014-01-06 19:22:28 -05:00
parent f660cd5129
commit 9598f3119c

79
app.js
View File

@ -6,30 +6,33 @@ var less = require('less-middleware');
var path = require('path'); var path = require('path');
var mongoose = require('mongoose'); var mongoose = require('mongoose');
var passport = require('passport'); var passport = require('passport');
var cluster = require('cluster');
// Load controllers // Load controllers
var home = require('./controllers/home'); var homeController = require('./controllers/home');
var user = require('./controllers/user'); var userController = require('./controllers/user');
var api = require('./controllers/api'); var apiController = require('./controllers/api');
var contact = require('./controllers/contact'); var contactController = require('./controllers/contact');
// App Configuration (API Keys, Database URI) // App Configuration (API Keys, Database URI)
var secrets = require('./config/secrets'); var secrets = require('./config/secrets');
var passportConf = require('./config/passport'); var passportConf = require('./config/passport');
// Connect to MongoDB on a separate domain if (cluster.isMaster) {
var dbDomain = domain.create(); var numCPUs = require('os').cpus().length;
dbDomain.run(function() {
mongoose.connect(secrets.db); for (var i = 0; i < numCPUs; i++) {
cluster.fork();
}
cluster.on('disconnect', function(worker, code, signal) {
console.error('worker ' + worker.process.pid + ' died');
cluster.fork();
}); });
// Graceful error handling for MongoDB } else {
dbDomain.on('error', function(err) {
console.error(err.message);
setTimeout(function() {
mongoose.connect(secrets.db); mongoose.connect(secrets.db);
}, 1000);
});
// Initialize express application // Initialize express application
var app = express(); var app = express();
@ -66,31 +69,31 @@ app.use(function(err, req, res, next){
}); });
// Login/Signup Routes // Login/Signup Routes
app.get('/', home.index); app.get('/', homeController.index);
app.get('/login', user.getLogin); app.get('/login', userController.getLogin);
app.post('/login', user.postLogin); app.post('/login', userController.postLogin);
app.get('/logout', user.logout); app.get('/logout', userController.logout);
app.get('/signup', user.getSignup); app.get('/signup', userController.getSignup);
app.post('/signup', user.postSignup); app.post('/signup', userController.postSignup);
// Primary Routes // Primary Routes
app.get('/contact', contact.getContact); app.get('/contact', contactController.getContact);
app.post('/contact', contact.postContact); app.post('/contact', contactController.postContact);
app.get('/account', passportConf.isAuthenticated, user.getAccount); app.get('/account', passportConf.isAuthenticated, userController.getAccount);
app.post('/account/profile', passportConf.isAuthenticated, user.postAccountProfileTab); app.post('/account/profile', passportConf.isAuthenticated, userController.postAccountProfileTab);
app.post('/account/settings', passportConf.isAuthenticated, user.postAccountSettingsTab); app.post('/account/settings', passportConf.isAuthenticated, userController.postAccountSettingsTab);
app.post('/account/delete', passportConf.isAuthenticated, user.postDeleteAccount); app.post('/account/delete', passportConf.isAuthenticated, userController.postDeleteAccount);
app.get('/account/unlink/:provider', passportConf.isAuthenticated, user.getOauthUnlink); app.get('/account/unlink/:provider', passportConf.isAuthenticated, userController.getOauthUnlink);
app.get('/api', api.getApi); app.get('/api', apiController.getApi);
app.get('/api/foursquare', passportConf.isAuthenticated, passportConf.isAuthorized, api.getFoursquare); app.get('/api/foursquare', passportConf.isAuthenticated, passportConf.isAuthorized, apiController.getFoursquare);
app.get('/api/tumblr', passportConf.isAuthenticated, passportConf.isAuthorized, api.getTumblr); app.get('/api/tumblr', passportConf.isAuthenticated, passportConf.isAuthorized, apiController.getTumblr);
app.get('/api/facebook', passportConf.isAuthenticated, api.getFacebook); app.get('/api/facebook', passportConf.isAuthenticated, apiController.getFacebook);
app.get('/api/scraping', api.getScraping); app.get('/api/scraping', apiController.getScraping);
app.get('/api/github', passportConf.isAuthenticated, passportConf.isAuthorized, api.getGithub); app.get('/api/github', passportConf.isAuthenticated, passportConf.isAuthorized, apiController.getGithub);
app.get('/api/lastfm', api.getLastfm); app.get('/api/lastfm', apiController.getLastfm);
app.get('/api/nyt', api.getNewYorkTimes); app.get('/api/nyt', apiController.getNewYorkTimes);
app.get('/api/twitter', passportConf.isAuthenticated, api.getTwitter); app.get('/api/twitter', passportConf.isAuthenticated, apiController.getTwitter);
app.get('/api/aviary', api.getAviary); app.get('/api/aviary', apiController.getAviary);
// OAuth Routes // OAuth Routes
app.get('/auth/facebook', passport.authenticate('facebook', { scope: 'email' })); app.get('/auth/facebook', passport.authenticate('facebook', { scope: 'email' }));
@ -109,3 +112,5 @@ app.get('/auth/tumblr/callback', passport.authorize('tumblr', { failureRedirect:
app.listen(app.get('port'), function() { app.listen(app.get('port'), function() {
console.log('Express server listening on port ' + app.get('port')); console.log('Express server listening on port ' + app.get('port'));
}); });
}