Replaced clusters in favor of mongoose connection error handler. Plus, Css updates.

This commit is contained in:
Sahat Yalkabov
2014-01-11 22:53:31 -05:00
parent b09c8f16ac
commit e8b1616e13
3 changed files with 86 additions and 92 deletions

175
app.js
View File

@ -1,6 +1,7 @@
/** /**
* Module dependencies. * Module dependencies.
*/ */
var express = require('express'); var express = require('express');
var fs = require('fs'); var fs = require('fs');
var flash = require('connect-flash'); var flash = require('connect-flash');
@ -9,11 +10,11 @@ var path = require('path');
var mongoose = require('mongoose'); var mongoose = require('mongoose');
var MongoStore = require('connect-mongo')(express); var MongoStore = require('connect-mongo')(express);
var passport = require('passport'); var passport = require('passport');
var cluster = require('cluster');
/** /**
* Controllers. * Controllers.
*/ */
var homeController = require('./controllers/home'); var homeController = require('./controllers/home');
var userController = require('./controllers/user'); var userController = require('./controllers/user');
var apiController = require('./controllers/api'); var apiController = require('./controllers/api');
@ -22,102 +23,94 @@ var contactController = require('./controllers/contact');
/** /**
* API keys and Passport configuration. * API keys and Passport configuration.
*/ */
var secrets = require('./config/secrets'); var secrets = require('./config/secrets');
var passportConf = require('./config/passport'); var passportConf = require('./config/passport');
if (cluster.isMaster) { /**
var numCPUs = require('os').cpus().length; * Connect to MongoDB.
*/
var opts = { server: { auto_reconnect: true } };
mongoose.connect(secrets.db, opts);
mongoose.connection.on('error', function() {
console.log('MongoDB Connection Error');
});
for (var i = 0; i < numCPUs; i++) { var app = express();
cluster.fork();
}
cluster.on('disconnect', function(worker, code, signal) { /**
console.error('worker ' + worker.process.pid + ' died'); * Express configuration.
cluster.fork(); */
});
} else {
/** app.set('port', process.env.PORT || 3000);
* Connect to MongoDB. app.set('views', path.join(__dirname, 'views'));
*/ app.set('view engine', 'jade');
var opts = { server: { auto_reconnect: true } }; app.use(express.favicon());
mongoose.connect(secrets.db, opts); app.use(express.logger('dev'));
app.use(express.cookieParser());
app.use(express.json());
app.use(express.urlencoded());
app.use(express.methodOverride());
app.use(express.session({
secret: '0000',
store: new MongoStore({ db: secrets.db })
}));
app.use(passport.initialize());
app.use(passport.session());
app.use(function(req, res, next) {
res.locals.user = req.user;
next();
});
app.use(flash());
app.use(less({ src: __dirname + '/public', compress: true }));
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
app.use(function(req, res) {
res.status(404);
res.render('404');
});
app.use(express.errorHandler());
var app = express(); /**
* Routes.
*/
/** app.get('/', homeController.index);
* Express configuration. app.get('/login', userController.getLogin);
*/ app.post('/login', userController.postLogin);
app.set('port', process.env.PORT || 3000); app.get('/logout', userController.logout);
app.set('views', path.join(__dirname, 'views')); app.get('/signup', userController.getSignup);
app.set('view engine', 'jade'); app.post('/signup', userController.postSignup);
app.use(express.favicon()); app.get('/contact', contactController.getContact);
app.use(express.logger('dev')); app.post('/contact', contactController.postContact);
app.use(express.cookieParser()); app.get('/account', passportConf.isAuthenticated, userController.getAccount);
app.use(express.json()); app.post('/account/profile', passportConf.isAuthenticated, userController.postUpdateProfile);
app.use(express.urlencoded()); app.post('/account/password', passportConf.isAuthenticated, userController.postUpdatePassword);
app.use(express.methodOverride()); app.post('/account/delete', passportConf.isAuthenticated, userController.postDeleteAccount);
app.use(express.session({ app.get('/account/unlink/:provider', passportConf.isAuthenticated, userController.getOauthUnlink);
secret: '0000', app.get('/api', apiController.getApi);
store: new MongoStore({ db: secrets.db }) app.get('/api/foursquare', passportConf.isAuthenticated, passportConf.isAuthorized, apiController.getFoursquare);
})); app.get('/api/tumblr', passportConf.isAuthenticated, passportConf.isAuthorized, apiController.getTumblr);
app.use(passport.initialize()); app.get('/api/facebook', passportConf.isAuthenticated, apiController.getFacebook);
app.use(passport.session()); app.get('/api/scraping', apiController.getScraping);
app.use(function(req, res, next) { app.get('/api/github', passportConf.isAuthenticated, passportConf.isAuthorized, apiController.getGithub);
res.locals.user = req.user; app.get('/api/lastfm', apiController.getLastfm);
next(); app.get('/api/nyt', apiController.getNewYorkTimes);
}); app.get('/api/twitter', passportConf.isAuthenticated, apiController.getTwitter);
app.use(flash()); app.get('/api/aviary', apiController.getAviary);
app.use(less({ src: __dirname + '/public', compress: true })); app.get('/auth/facebook', passport.authenticate('facebook', { scope: 'email' }));
app.use(app.router); app.get('/auth/facebook/callback', passport.authenticate('facebook', { successRedirect: '/', failureRedirect: '/login' }));
app.use(express.static(path.join(__dirname, 'public'))); app.get('/auth/github', passport.authenticate('github'));
app.use(function(req, res) { app.get('/auth/github/callback', passport.authenticate('github', { successRedirect: '/', failureRedirect: '/login' }));
res.status(404); app.get('/auth/google', passport.authenticate('google', { scope: 'profile email' }));
res.render('404'); app.get('/auth/google/callback', passport.authenticate('google', { successRedirect: '/', failureRedirect: '/login' }));
}); app.get('/auth/twitter', passport.authenticate('twitter'));
app.use(express.errorHandler()); app.get('/auth/twitter/callback', passport.authenticate('twitter', { successRedirect: '/', failureRedirect: '/login' }));
app.get('/auth/foursquare', passport.authorize('foursquare'));
app.get('/auth/foursquare/callback', passport.authorize('foursquare', { failureRedirect: '/api' }), function(req, res) { res.redirect('/api/foursquare'); });
app.get('/auth/tumblr', passport.authorize('tumblr'));
app.get('/auth/tumblr/callback', passport.authorize('tumblr', { failureRedirect: '/api' }), function(req, res) { res.redirect('/api/tumblr'); });
/** app.listen(app.get('port'), function() {
* Routes. console.log('Express server listening on port ' + app.get('port'));
*/ });
app.get('/', homeController.index);
app.get('/login', userController.getLogin);
app.post('/login', userController.postLogin);
app.get('/logout', userController.logout);
app.get('/signup', userController.getSignup);
app.post('/signup', userController.postSignup);
app.get('/contact', contactController.getContact);
app.post('/contact', contactController.postContact);
app.get('/account', passportConf.isAuthenticated, userController.getAccount);
app.post('/account/profile', passportConf.isAuthenticated, userController.postUpdateProfile);
app.post('/account/password', passportConf.isAuthenticated, userController.postUpdatePassword);
app.post('/account/delete', passportConf.isAuthenticated, userController.postDeleteAccount);
app.get('/account/unlink/:provider', passportConf.isAuthenticated, userController.getOauthUnlink);
app.get('/api', apiController.getApi);
app.get('/api/foursquare', passportConf.isAuthenticated, passportConf.isAuthorized, apiController.getFoursquare);
app.get('/api/tumblr', passportConf.isAuthenticated, passportConf.isAuthorized, apiController.getTumblr);
app.get('/api/facebook', passportConf.isAuthenticated, apiController.getFacebook);
app.get('/api/scraping', apiController.getScraping);
app.get('/api/github', passportConf.isAuthenticated, passportConf.isAuthorized, apiController.getGithub);
app.get('/api/lastfm', apiController.getLastfm);
app.get('/api/nyt', apiController.getNewYorkTimes);
app.get('/api/twitter', passportConf.isAuthenticated, apiController.getTwitter);
app.get('/api/aviary', apiController.getAviary);
app.get('/auth/facebook', passport.authenticate('facebook', { scope: 'email' }));
app.get('/auth/facebook/callback', passport.authenticate('facebook', { successRedirect: '/', failureRedirect: '/login' }));
app.get('/auth/github', passport.authenticate('github'));
app.get('/auth/github/callback', passport.authenticate('github', { successRedirect: '/', failureRedirect: '/login' }));
app.get('/auth/google', passport.authenticate('google', { scope: 'profile email' }));
app.get('/auth/google/callback', passport.authenticate('google', { successRedirect: '/', failureRedirect: '/login' }));
app.get('/auth/twitter', passport.authenticate('twitter'));
app.get('/auth/twitter/callback', passport.authenticate('twitter', { successRedirect: '/', failureRedirect: '/login' }));
app.get('/auth/foursquare', passport.authorize('foursquare'));
app.get('/auth/foursquare/callback', passport.authorize('foursquare', { failureRedirect: '/api' }), function(req, res) { res.redirect('/api/foursquare'); });
app.get('/auth/tumblr', passport.authorize('tumblr'));
app.get('/auth/tumblr/callback', passport.authorize('tumblr', { failureRedirect: '/api' }), function(req, res) { res.redirect('/api/tumblr'); });
app.listen(app.get('port'), function() {
console.log('Express server listening on port ' + app.get('port'));
});
}

View File

@ -1,4 +1,5 @@
@import "bootstrap/bootstrap"; @import "bootstrap/bootstrap";
@import "themes/flatly";
@navbar-height: 40px; @navbar-height: 40px;

View File

@ -514,7 +514,7 @@ you can use the generic selector below, but it's slower:
@navbar-default-link-disabled-bg: transparent; @navbar-default-link-disabled-bg: transparent;
// Navbar brand label // Navbar brand label
@navbar-default-brand-color: @navbar-default-link-color; @navbar-default-brand-color: @navbar-default-link-hover-color;
@navbar-default-brand-hover-color: @navbar-default-link-hover-color; @navbar-default-brand-hover-color: @navbar-default-link-hover-color;
@navbar-default-brand-hover-bg: transparent; @navbar-default-brand-hover-bg: transparent;