2015-03-18 04:57:05 +00:00
|
|
|
if (process.env.NODE_ENV !== 'development') {
|
|
|
|
require('newrelic');
|
|
|
|
}
|
2014-12-23 00:16:10 +00:00
|
|
|
require('dotenv').load();
|
2015-03-23 05:18:01 +00:00
|
|
|
// handle uncaught exceptions. Forever will restart process on shutdown
|
|
|
|
process.on('uncaughtException', function (err) {
|
|
|
|
console.error(
|
|
|
|
(new Date()).toUTCString() + ' uncaughtException:',
|
|
|
|
err.message
|
|
|
|
);
|
|
|
|
console.error(err.stack);
|
|
|
|
/* eslint-disable no-process-exit */
|
|
|
|
process.exit(1);
|
|
|
|
/* eslint-enable no-process-exit */
|
|
|
|
});
|
2014-01-12 03:53:31 +00:00
|
|
|
|
2014-12-23 16:48:28 +00:00
|
|
|
var express = require('express'),
|
2015-03-25 22:25:19 +00:00
|
|
|
//accepts = require('accepts'),
|
2014-12-23 16:48:28 +00:00
|
|
|
cookieParser = require('cookie-parser'),
|
|
|
|
compress = require('compression'),
|
|
|
|
session = require('express-session'),
|
|
|
|
logger = require('morgan'),
|
|
|
|
errorHandler = require('errorhandler'),
|
|
|
|
methodOverride = require('method-override'),
|
|
|
|
bodyParser = require('body-parser'),
|
|
|
|
helmet = require('helmet'),
|
|
|
|
MongoStore = require('connect-mongo')(session),
|
|
|
|
flash = require('express-flash'),
|
|
|
|
path = require('path'),
|
|
|
|
mongoose = require('mongoose'),
|
|
|
|
passport = require('passport'),
|
|
|
|
expressValidator = require('express-validator'),
|
|
|
|
connectAssets = require('connect-assets'),
|
2014-01-12 03:53:31 +00:00
|
|
|
|
2014-12-23 16:48:28 +00:00
|
|
|
/**
|
2015-01-16 23:58:27 +00:00
|
|
|
* Controllers (route handlers).
|
|
|
|
*/
|
2014-12-23 16:48:28 +00:00
|
|
|
homeController = require('./controllers/home'),
|
|
|
|
resourcesController = require('./controllers/resources'),
|
|
|
|
userController = require('./controllers/user'),
|
|
|
|
contactController = require('./controllers/contact'),
|
2015-03-25 02:08:26 +00:00
|
|
|
nonprofitController = require('./controllers/nonprofits'),
|
2015-01-11 05:45:22 +00:00
|
|
|
bonfireController = require('./controllers/bonfire'),
|
2015-02-02 07:35:27 +00:00
|
|
|
coursewareController = require('./controllers/courseware'),
|
2015-03-30 20:48:54 +00:00
|
|
|
wikiController = require('./controllers/wiki'),
|
2015-04-04 03:05:53 +00:00
|
|
|
challengeMapController = require('./controllers/challengeMap'),
|
2013-11-14 07:29:55 +00:00
|
|
|
|
2015-04-04 03:05:53 +00:00
|
|
|
|
|
|
|
/**
|
2015-03-03 10:23:56 +00:00
|
|
|
* Stories
|
2015-01-16 23:58:27 +00:00
|
|
|
*/
|
2015-03-28 14:42:07 +00:00
|
|
|
storyController = require('./controllers/story'),
|
2014-01-12 03:53:31 +00:00
|
|
|
|
2014-12-23 16:48:28 +00:00
|
|
|
/**
|
2015-01-16 23:58:27 +00:00
|
|
|
* API keys and Passport configuration.
|
|
|
|
*/
|
2014-12-23 16:48:28 +00:00
|
|
|
secrets = require('./config/secrets'),
|
|
|
|
passportConf = require('./config/passport');
|
2013-11-27 04:15:13 +00:00
|
|
|
|
2014-02-02 10:38:38 +00:00
|
|
|
/**
|
|
|
|
* Create Express server.
|
|
|
|
*/
|
|
|
|
var app = express();
|
|
|
|
|
2014-01-12 03:53:31 +00:00
|
|
|
/**
|
2014-06-06 18:58:30 +00:00
|
|
|
* Connect to MongoDB.
|
2014-01-12 03:53:31 +00:00
|
|
|
*/
|
2014-02-26 03:39:28 +00:00
|
|
|
mongoose.connect(secrets.db);
|
2015-01-16 23:58:27 +00:00
|
|
|
mongoose.connection.on('error', function () {
|
|
|
|
console.error(
|
|
|
|
'MongoDB Connection Error. Please make sure that MongoDB is running.'
|
|
|
|
);
|
2014-01-12 03:53:31 +00:00
|
|
|
});
|
2013-11-13 17:32:22 +00:00
|
|
|
|
2014-05-06 04:44:30 +00:00
|
|
|
/**
|
|
|
|
* Express configuration.
|
|
|
|
*/
|
2014-04-18 18:29:30 +00:00
|
|
|
|
2015-02-17 23:35:16 +00:00
|
|
|
|
2014-01-12 03:53:31 +00:00
|
|
|
app.set('port', process.env.PORT || 3000);
|
|
|
|
app.set('views', path.join(__dirname, 'views'));
|
|
|
|
app.set('view engine', 'jade');
|
2014-06-06 18:58:30 +00:00
|
|
|
app.use(compress());
|
2014-12-27 08:22:50 +00:00
|
|
|
var oneYear = 31557600000;
|
2015-01-16 23:58:27 +00:00
|
|
|
app.use(express.static(__dirname + '/public', {maxAge: oneYear}));
|
2014-02-21 22:29:06 +00:00
|
|
|
app.use(connectAssets({
|
2014-12-23 16:48:28 +00:00
|
|
|
paths: [
|
2015-01-16 23:58:27 +00:00
|
|
|
path.join(__dirname, 'public/css'),
|
|
|
|
path.join(__dirname, 'public/js')
|
2014-12-23 16:48:28 +00:00
|
|
|
],
|
2014-10-18 02:23:53 +00:00
|
|
|
helperContext: app.locals
|
2014-02-03 13:34:12 +00:00
|
|
|
}));
|
2014-04-12 16:43:07 +00:00
|
|
|
app.use(logger('dev'));
|
|
|
|
app.use(bodyParser.json());
|
2015-01-16 23:58:27 +00:00
|
|
|
app.use(bodyParser.urlencoded({extended: true}));
|
2014-12-24 02:20:53 +00:00
|
|
|
app.use(expressValidator({
|
|
|
|
customValidators: {
|
2015-01-16 23:58:27 +00:00
|
|
|
matchRegex: function (param, regex) {
|
2014-12-24 02:20:53 +00:00
|
|
|
return regex.test(param);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}));
|
2014-04-12 16:43:07 +00:00
|
|
|
app.use(methodOverride());
|
|
|
|
app.use(cookieParser());
|
|
|
|
app.use(session({
|
2014-10-18 02:23:53 +00:00
|
|
|
resave: true,
|
|
|
|
saveUninitialized: true,
|
|
|
|
secret: secrets.sessionSecret,
|
|
|
|
store: new MongoStore({
|
|
|
|
url: secrets.db,
|
2015-03-25 04:46:42 +00:00
|
|
|
'autoReconnect': true
|
2014-10-18 02:23:53 +00:00
|
|
|
})
|
2014-01-29 05:49:09 +00:00
|
|
|
}));
|
2014-01-12 03:53:31 +00:00
|
|
|
app.use(passport.initialize());
|
|
|
|
app.use(passport.session());
|
2014-06-01 15:52:28 +00:00
|
|
|
app.use(flash());
|
2014-12-11 04:44:33 +00:00
|
|
|
app.disable('x-powered-by');
|
2014-12-23 16:48:28 +00:00
|
|
|
|
2014-12-11 04:44:33 +00:00
|
|
|
app.use(helmet.xssFilter());
|
2015-01-09 23:10:34 +00:00
|
|
|
app.use(helmet.noSniff());
|
2014-12-11 04:44:33 +00:00
|
|
|
app.use(helmet.xframe());
|
2015-02-17 23:35:16 +00:00
|
|
|
app.use(function(req, res, next) {
|
|
|
|
res.header("Access-Control-Allow-Origin", "*");
|
|
|
|
res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
|
|
|
|
next();
|
|
|
|
});
|
2014-12-23 16:48:28 +00:00
|
|
|
|
2014-12-22 20:36:45 +00:00
|
|
|
var trusted = [
|
2014-12-23 21:30:20 +00:00
|
|
|
"'self'",
|
2014-12-22 20:36:45 +00:00
|
|
|
'*.freecodecamp.com',
|
2014-12-23 16:48:28 +00:00
|
|
|
'*.gstatic.com',
|
2015-01-06 01:29:37 +00:00
|
|
|
'*.google-analytics.com',
|
|
|
|
'*.googleapis.com',
|
|
|
|
'*.google.com',
|
|
|
|
'*.gstatic.com',
|
|
|
|
'*.doubleclick.net',
|
|
|
|
'*.twitter.com',
|
2015-01-14 21:26:36 +00:00
|
|
|
'*.twitch.tv',
|
2014-12-22 20:36:45 +00:00
|
|
|
'*.twimg.com',
|
|
|
|
"'unsafe-eval'",
|
2014-12-22 23:07:32 +00:00
|
|
|
"'unsafe-inline'",
|
2015-01-06 01:29:37 +00:00
|
|
|
'*.rafflecopter.com',
|
2015-01-06 15:28:57 +00:00
|
|
|
'*.bootstrapcdn.com',
|
2015-01-06 01:29:37 +00:00
|
|
|
'*.cloudflare.com',
|
2015-03-17 23:18:41 +00:00
|
|
|
'https://*.cloudflare.com',
|
2015-01-06 15:28:57 +00:00
|
|
|
'localhost:3001',
|
2015-01-09 15:53:29 +00:00
|
|
|
'ws://localhost:3001/',
|
|
|
|
'http://localhost:3001',
|
|
|
|
'localhost:3000',
|
|
|
|
'ws://localhost:3000/',
|
2015-01-09 16:47:49 +00:00
|
|
|
'http://localhost:3000',
|
2015-01-09 23:47:52 +00:00
|
|
|
'*.ionicframework.com',
|
2015-01-11 08:07:41 +00:00
|
|
|
'https://syndication.twitter.com',
|
2015-01-23 00:52:43 +00:00
|
|
|
'*.youtube.com',
|
2015-02-21 22:22:46 +00:00
|
|
|
'*.jsdelivr.net',
|
2015-03-17 23:18:41 +00:00
|
|
|
'https://*.jsdelivr.net',
|
2015-02-21 22:22:46 +00:00
|
|
|
'*.togetherjs.com',
|
|
|
|
'https://*.togetherjs.com',
|
|
|
|
'wss://hub.togetherjs.com',
|
|
|
|
'*.ytimg.com',
|
2015-02-22 23:01:55 +00:00
|
|
|
'wss://fcctogether.herokuapp.com',
|
|
|
|
'*.bitly.com'
|
2014-12-22 20:36:45 +00:00
|
|
|
];
|
2014-12-22 21:38:48 +00:00
|
|
|
|
2014-12-11 04:44:33 +00:00
|
|
|
app.use(helmet.contentSecurityPolicy({
|
2014-12-22 20:36:45 +00:00
|
|
|
defaultSrc: trusted,
|
2015-02-20 01:18:44 +00:00
|
|
|
scriptSrc: [
|
|
|
|
'*.optimizely.com',
|
|
|
|
'*.aspnetcdn.com',
|
|
|
|
'*.d3js.org',
|
|
|
|
].concat(trusted),
|
2014-12-23 21:50:14 +00:00
|
|
|
'connect-src': [
|
2015-01-16 23:58:27 +00:00
|
|
|
'ws://*.rafflecopter.com',
|
|
|
|
'wss://*.rafflecopter.com',
|
|
|
|
'https://*.rafflecopter.com',
|
|
|
|
'ws://www.freecodecamp.com',
|
|
|
|
'http://www.freecodecamp.com'
|
2015-01-09 15:53:29 +00:00
|
|
|
].concat(trusted),
|
2014-12-22 20:36:45 +00:00
|
|
|
styleSrc: trusted,
|
2014-12-23 21:50:14 +00:00
|
|
|
imgSrc: [
|
2015-01-16 23:58:27 +00:00
|
|
|
'*.evernote.com',
|
|
|
|
'*.amazonaws.com',
|
|
|
|
'data:',
|
|
|
|
'*.licdn.com',
|
|
|
|
'*.gravatar.com',
|
|
|
|
'*.akamaihd.net',
|
|
|
|
'graph.facebook.com',
|
|
|
|
'*.githubusercontent.com',
|
|
|
|
'*.googleusercontent.com',
|
|
|
|
'*' /* allow all input since we have user submitted images for public profile*/
|
2014-12-23 21:50:14 +00:00
|
|
|
].concat(trusted),
|
|
|
|
fontSrc: ['*.googleapis.com'].concat(trusted),
|
|
|
|
mediaSrc: [
|
2015-01-16 23:58:27 +00:00
|
|
|
'*.amazonaws.com',
|
|
|
|
'*.twitter.com'
|
2015-01-09 15:53:29 +00:00
|
|
|
].concat(trusted),
|
2014-12-23 21:50:14 +00:00
|
|
|
frameSrc: [
|
2015-01-16 23:58:27 +00:00
|
|
|
'*.gitter.im',
|
2015-03-10 22:42:15 +00:00
|
|
|
'*.gitter.im https:',
|
2015-01-16 23:58:27 +00:00
|
|
|
'*.vimeo.com',
|
|
|
|
'*.twitter.com',
|
|
|
|
'*.rafflecopter.com',
|
2015-02-16 07:59:03 +00:00
|
|
|
'*.ghbtns.com'
|
2015-01-09 15:53:29 +00:00
|
|
|
].concat(trusted),
|
2014-12-11 04:44:33 +00:00
|
|
|
reportOnly: false, // set to true if you only want to report errors
|
|
|
|
setAllHeaders: false, // set to true if you want to set all headers
|
|
|
|
safari5: false // set to true if you want to force buggy CSP in Safari 5
|
|
|
|
}));
|
2014-11-19 23:30:36 +00:00
|
|
|
|
2015-01-16 23:58:27 +00:00
|
|
|
app.use(function (req, res, next) {
|
2014-10-18 02:23:53 +00:00
|
|
|
// Make user object available in templates.
|
|
|
|
res.locals.user = req.user;
|
|
|
|
next();
|
2014-01-12 03:53:31 +00:00
|
|
|
});
|
2014-11-19 23:30:36 +00:00
|
|
|
|
2015-01-16 23:58:27 +00:00
|
|
|
app.use(function (req, res, next) {
|
2014-10-18 02:23:53 +00:00
|
|
|
// Remember original destination before login.
|
|
|
|
var path = req.path.split('/')[1];
|
2015-03-28 05:16:48 +00:00
|
|
|
if (/auth|login|logout|signin|signup|fonts|favicon/i.test(path)) {
|
|
|
|
return next();
|
|
|
|
} else if (/\/stories\/comments\/\w+/i.test(req.path)) {
|
2014-10-18 02:23:53 +00:00
|
|
|
return next();
|
|
|
|
}
|
|
|
|
req.session.returnTo = req.path;
|
|
|
|
next();
|
2014-03-08 19:58:27 +00:00
|
|
|
});
|
2014-11-19 23:30:36 +00:00
|
|
|
|
2014-12-23 16:48:28 +00:00
|
|
|
app.use(
|
2015-01-16 23:58:27 +00:00
|
|
|
express.static(path.join(__dirname, 'public'), {maxAge: 31557600000})
|
2014-12-23 16:48:28 +00:00
|
|
|
);
|
2014-01-08 06:37:40 +00:00
|
|
|
|
2015-03-07 10:00:21 +00:00
|
|
|
app.use(express.static(__dirname + '/public', { maxAge: 86400000 }));
|
|
|
|
|
2014-01-12 03:53:31 +00:00
|
|
|
/**
|
2014-06-06 19:23:28 +00:00
|
|
|
* Main routes.
|
2014-01-12 03:53:31 +00:00
|
|
|
*/
|
2014-11-19 23:30:36 +00:00
|
|
|
|
2015-01-14 21:28:20 +00:00
|
|
|
app.get('/', homeController.index);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
|
|
|
app.get('/privacy', function(req, res) {
|
|
|
|
res.redirect(301, "/wiki/free-code-camp's-privacy-policy");
|
|
|
|
});
|
|
|
|
|
|
|
|
app.get('/nonprofit-project-instructions', function(req, res) {
|
|
|
|
res.redirect(301, "/wiki/free-code-camp's-privacy-policy");
|
|
|
|
});
|
|
|
|
|
2014-11-29 23:16:47 +00:00
|
|
|
app.get('/jquery-exercises', resourcesController.jqueryExercises);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-02-20 00:33:08 +00:00
|
|
|
app.get('/chat', resourcesController.chat);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-04-07 07:11:31 +00:00
|
|
|
app.get('/twitch', resourcesController.twitch);
|
|
|
|
|
2015-04-06 01:37:58 +00:00
|
|
|
app.get('/map', challengeMapController.challengeMap);
|
2015-04-04 03:05:53 +00:00
|
|
|
|
2015-03-30 22:15:07 +00:00
|
|
|
app.get('/live-pair-programming', function(req, res) {
|
|
|
|
res.redirect(301, '/wiki/live-stream-pair-programming-on-twitch.tv');
|
|
|
|
});
|
|
|
|
|
|
|
|
app.get('/install-screenhero', function(req, res) {
|
|
|
|
res.redirect(301, '/wiki/install-screenhero');
|
|
|
|
});
|
|
|
|
|
|
|
|
app.get('/guide-to-our-nonprofit-projects', function(req, res) {
|
|
|
|
res.redirect(301, '/wiki/a-guide-to-our-nonprofit-projects');
|
|
|
|
});
|
|
|
|
|
|
|
|
app.get('/chromebook', function(req, res) {
|
|
|
|
res.redirect(301, '/wiki/chromebook');
|
|
|
|
});
|
|
|
|
|
|
|
|
app.get('/deploy-a-website', function(req, res) {
|
|
|
|
res.redirect(301, '/wiki/deploy-a-website');
|
|
|
|
});
|
|
|
|
|
|
|
|
app.get('/gmail-shortcuts', function(req, res) {
|
|
|
|
res.redirect(301, '/wiki/gmail-shortcuts');
|
|
|
|
});
|
|
|
|
|
|
|
|
app.get('/nodeschool-challenges', function(req, res) {
|
|
|
|
res.redirect(301, '/wiki/nodeschool-challenges');
|
|
|
|
});
|
|
|
|
|
2015-01-26 19:38:19 +00:00
|
|
|
app.get('/stats', function(req, res) {
|
|
|
|
res.redirect(301, '/learn-to-code');
|
|
|
|
});
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-26 19:38:19 +00:00
|
|
|
app.get('/about', function(req, res) {
|
|
|
|
res.redirect(301, '/learn-to-code');
|
|
|
|
});
|
2015-03-30 22:15:07 +00:00
|
|
|
|
|
|
|
app.get('/learn-to-code', resourcesController.about);
|
|
|
|
|
|
|
|
app.get('/news', function(req, res) {
|
|
|
|
res.redirect(301, '/stories/hot');
|
|
|
|
});
|
|
|
|
|
2015-01-26 19:38:19 +00:00
|
|
|
app.get('/signin', userController.getSignin);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-26 19:38:19 +00:00
|
|
|
app.get('/login', function(req, res) {
|
|
|
|
res.redirect(301, '/signin');
|
|
|
|
});
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-26 19:38:19 +00:00
|
|
|
app.post('/signin', userController.postSignin);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-26 19:38:19 +00:00
|
|
|
app.get('/signout', userController.signout);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-26 19:38:19 +00:00
|
|
|
app.get('/logout', function(req, res) {
|
|
|
|
res.redirect(301, '/signout');
|
|
|
|
});
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2014-06-06 19:23:28 +00:00
|
|
|
app.get('/forgot', userController.getForgot);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2014-06-06 19:23:28 +00:00
|
|
|
app.post('/forgot', userController.postForgot);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2014-06-06 19:23:28 +00:00
|
|
|
app.get('/reset/:token', userController.getReset);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2014-06-06 19:23:28 +00:00
|
|
|
app.post('/reset/:token', userController.postReset);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2014-12-08 00:25:43 +00:00
|
|
|
app.get('/email-signup', userController.getEmailSignup);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2014-12-08 00:25:43 +00:00
|
|
|
app.get('/email-signin', userController.getEmailSignin);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2014-12-08 00:25:43 +00:00
|
|
|
app.post('/email-signup', userController.postEmailSignup);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-26 19:38:19 +00:00
|
|
|
app.post('/email-signin', userController.postSignin);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Nonprofit Project routes.
|
|
|
|
*/
|
|
|
|
|
2015-04-01 00:38:33 +00:00
|
|
|
//app.get('/nonprofits', contactController.getNonprofitsForm);
|
|
|
|
//
|
|
|
|
//app.post('/nonprofits', contactController.postNonprofitsForm);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-25 02:08:26 +00:00
|
|
|
app.get('/nonprofits/home', nonprofitController.nonprofitsHome);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-25 04:46:42 +00:00
|
|
|
app.get('/nonprofits/are-you-with-a-registered-nonprofit', nonprofitController.areYouWithARegisteredNonprofit);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-25 05:12:16 +00:00
|
|
|
app.get('/nonprofits/are-there-people-that-are-already-benefiting-from-your-services', nonprofitController.areTherePeopleThatAreAlreadyBenefitingFromYourServices);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-25 04:46:42 +00:00
|
|
|
app.get('/nonprofits/in-exchange-we-ask', nonprofitController.inExchangeWeAsk);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-25 04:46:42 +00:00
|
|
|
app.get('/nonprofits/ok-with-javascript', nonprofitController.okWithJavaScript);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-27 06:33:52 +00:00
|
|
|
app.get('/nonprofits/how-can-free-code-camp-help-you', nonprofitController.howCanFreeCodeCampHelpYou);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-25 04:46:42 +00:00
|
|
|
app.get('/nonprofits/what-does-your-nonprofit-do', nonprofitController.whatDoesYourNonprofitDo);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-25 04:46:42 +00:00
|
|
|
app.get('/nonprofits/link-us-to-your-website', nonprofitController.linkUsToYourWebsite);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-25 22:25:19 +00:00
|
|
|
app.get('/nonprofits/tell-us-your-name', nonprofitController.tellUsYourName);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-25 22:25:19 +00:00
|
|
|
app.get('/nonprofits/tell-us-your-email', nonprofitController.tellUsYourEmail);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-25 04:46:42 +00:00
|
|
|
app.get('/nonprofits/your-nonprofit-project-application-has-been-submitted', nonprofitController.yourNonprofitProjectApplicationHasBeenSubmitted);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-27 06:33:52 +00:00
|
|
|
app.get('/nonprofits/other-solutions', nonprofitController.otherSolutions);
|
2015-01-23 23:13:36 +00:00
|
|
|
|
2015-04-01 00:38:33 +00:00
|
|
|
app.get('/nonprofits/getNonprofitList', nonprofitController.showAllNonprofits);
|
|
|
|
|
2015-04-02 05:31:08 +00:00
|
|
|
app.get('/nonprofits/interested-in-nonprofit/:nonprofitName', nonprofitController.interestedInNonprofit);
|
|
|
|
|
2015-03-31 01:02:50 +00:00
|
|
|
app.get(
|
|
|
|
'/nonprofits/:nonprofitName',
|
|
|
|
nonprofitController.returnIndividualNonprofit
|
|
|
|
);
|
|
|
|
|
2015-01-14 21:28:20 +00:00
|
|
|
app.get(
|
|
|
|
'/done-with-first-100-hours',
|
2015-01-23 23:13:36 +00:00
|
|
|
passportConf.isAuthenticated,
|
2015-01-14 21:28:20 +00:00
|
|
|
contactController.getDoneWithFirst100Hours
|
|
|
|
);
|
|
|
|
app.post(
|
|
|
|
'/done-with-first-100-hours',
|
2015-01-23 23:13:36 +00:00
|
|
|
passportConf.isAuthenticated,
|
2015-01-14 21:28:20 +00:00
|
|
|
contactController.postDoneWithFirst100Hours
|
|
|
|
);
|
2014-11-19 23:50:57 +00:00
|
|
|
app.post(
|
2015-01-16 23:58:27 +00:00
|
|
|
'/update-progress',
|
|
|
|
passportConf.isAuthenticated,
|
|
|
|
userController.updateProgress
|
2014-12-23 16:48:28 +00:00
|
|
|
);
|
2015-02-16 07:59:03 +00:00
|
|
|
|
2015-03-03 10:23:56 +00:00
|
|
|
/**
|
2015-03-30 22:15:07 +00:00
|
|
|
* Camper News routes.
|
2015-03-03 10:23:56 +00:00
|
|
|
*/
|
2015-03-05 23:11:18 +00:00
|
|
|
app.get(
|
|
|
|
'/stories/hotStories',
|
|
|
|
storyController.hotJSON
|
|
|
|
);
|
|
|
|
|
|
|
|
app.get(
|
|
|
|
'/stories/recentStories',
|
|
|
|
storyController.recentJSON
|
|
|
|
);
|
|
|
|
|
2015-03-03 10:23:56 +00:00
|
|
|
app.get(
|
|
|
|
'/stories/',
|
2015-03-05 23:11:18 +00:00
|
|
|
function(req, res) {
|
|
|
|
res.redirect(302, '/stories/hot');
|
|
|
|
}
|
2015-03-03 10:23:56 +00:00
|
|
|
);
|
2015-03-05 23:11:18 +00:00
|
|
|
|
2015-03-03 10:23:56 +00:00
|
|
|
app.get(
|
2015-03-05 23:11:18 +00:00
|
|
|
'/stories/comments/:id',
|
|
|
|
storyController.comments
|
2015-03-03 10:23:56 +00:00
|
|
|
);
|
2015-03-03 22:15:00 +00:00
|
|
|
|
2015-03-05 21:08:40 +00:00
|
|
|
app.post(
|
2015-03-06 16:57:09 +00:00
|
|
|
'/stories/comment/',
|
2015-03-05 21:08:40 +00:00
|
|
|
storyController.commentSubmit
|
|
|
|
);
|
|
|
|
|
2015-03-06 16:57:09 +00:00
|
|
|
app.post(
|
|
|
|
'/stories/comment/:id/comment',
|
|
|
|
storyController.commentOnCommentSubmit
|
|
|
|
);
|
|
|
|
|
2015-03-03 22:15:00 +00:00
|
|
|
app.get(
|
2015-03-05 23:11:18 +00:00
|
|
|
'/stories/submit',
|
|
|
|
storyController.submitNew
|
2015-03-03 22:15:00 +00:00
|
|
|
);
|
|
|
|
|
2015-03-07 08:42:22 +00:00
|
|
|
app.get(
|
2015-03-09 09:41:07 +00:00
|
|
|
'/stories/submit/new-story',
|
2015-03-07 08:42:22 +00:00
|
|
|
storyController.preSubmit
|
2015-03-05 10:21:26 +00:00
|
|
|
);
|
|
|
|
|
2015-03-07 08:42:22 +00:00
|
|
|
app.post(
|
|
|
|
'/stories/preliminary',
|
|
|
|
storyController.newStory
|
|
|
|
);
|
2015-03-05 23:11:18 +00:00
|
|
|
|
2015-03-07 09:26:49 +00:00
|
|
|
app.post(
|
|
|
|
'/stories/',
|
|
|
|
storyController.storySubmission
|
|
|
|
);
|
|
|
|
|
2015-03-05 23:11:18 +00:00
|
|
|
app.get(
|
|
|
|
'/stories/hot',
|
|
|
|
storyController.hot
|
|
|
|
);
|
|
|
|
|
|
|
|
app.get(
|
|
|
|
'/stories/recent',
|
|
|
|
storyController.recent
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
app.get(
|
|
|
|
'/stories/search',
|
|
|
|
storyController.search
|
|
|
|
);
|
|
|
|
|
2015-03-06 00:20:30 +00:00
|
|
|
app.post(
|
|
|
|
'/stories/search',
|
|
|
|
storyController.getStories
|
|
|
|
);
|
|
|
|
|
2015-03-03 10:50:16 +00:00
|
|
|
app.get(
|
|
|
|
'/stories/:storyName',
|
|
|
|
storyController.returnIndividualStory
|
|
|
|
);
|
2015-03-05 23:11:18 +00:00
|
|
|
|
2015-03-03 13:03:33 +00:00
|
|
|
app.post(
|
2015-03-03 22:15:00 +00:00
|
|
|
'/stories/upvote/',
|
2015-03-03 13:03:33 +00:00
|
|
|
storyController.upvote
|
|
|
|
);
|
2015-03-03 10:23:56 +00:00
|
|
|
|
2014-11-19 23:30:36 +00:00
|
|
|
app.all('/account', passportConf.isAuthenticated);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-06 05:52:30 +00:00
|
|
|
app.get('/account/api', userController.getAccountAngular);
|
2015-01-28 01:12:51 +00:00
|
|
|
|
2015-02-17 07:35:02 +00:00
|
|
|
/**
|
|
|
|
* API routes
|
|
|
|
*/
|
|
|
|
|
|
|
|
app.get('/api/github', resourcesController.githubCalls);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-28 06:30:06 +00:00
|
|
|
app.get('/api/blogger', resourcesController.bloggerCalls);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-28 06:30:06 +00:00
|
|
|
app.get('/api/trello', resourcesController.trelloCalls);
|
2015-02-17 07:35:02 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
/**
|
|
|
|
* Bonfire related routes
|
|
|
|
*/
|
2015-02-22 08:36:43 +00:00
|
|
|
|
2015-03-30 22:55:00 +00:00
|
|
|
app.get('/wiki/getWikiList', wikiController.showAllWikis);
|
|
|
|
|
2015-01-24 22:42:34 +00:00
|
|
|
app.get('/playground', bonfireController.index);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
app.get('/bonfires', bonfireController.returnNextBonfire);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
app.get('/bonfire-json-generator', bonfireController.returnGenerator);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
app.post('/bonfire-json-generator', bonfireController.generateChallenge);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
app.get('/bonfire-challenge-generator', bonfireController.publicGenerator);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-30 22:55:00 +00:00
|
|
|
app.post('/bonfire-challenge-generator', bonfireController.testBonfire);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-22 18:20:46 +00:00
|
|
|
app.get(
|
2015-01-26 23:28:14 +00:00
|
|
|
'/bonfires/:bonfireName',
|
2015-01-24 22:29:50 +00:00
|
|
|
bonfireController.returnIndividualBonfire
|
2015-01-22 18:20:46 +00:00
|
|
|
);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-26 17:30:04 +00:00
|
|
|
app.get('/bonfire', function(req, res) {
|
|
|
|
res.redirect(301, '/playground');
|
|
|
|
});
|
2014-02-01 08:30:14 +00:00
|
|
|
|
2015-03-31 01:02:50 +00:00
|
|
|
app.post('/completed-bonfire/', bonfireController.completedBonfire);
|
|
|
|
|
2015-03-30 20:48:54 +00:00
|
|
|
/**
|
|
|
|
* Wiki related routes
|
|
|
|
*/
|
2015-02-22 07:27:38 +00:00
|
|
|
|
2015-03-30 20:48:54 +00:00
|
|
|
|
2015-04-05 23:44:07 +00:00
|
|
|
app.get('/wiki/:wikiName', wikiController.returnIndividualWiki);
|
|
|
|
|
|
|
|
app.get('/wiki', wikiController.returnNextWiki);
|
|
|
|
|
|
|
|
app.post('/completed-wiki/', wikiController.completedWiki);
|
2015-02-22 07:27:38 +00:00
|
|
|
|
2015-01-24 05:44:08 +00:00
|
|
|
|
2015-02-02 07:35:27 +00:00
|
|
|
/**
|
|
|
|
* Courseware related routes
|
|
|
|
*/
|
|
|
|
|
2015-03-21 09:42:19 +00:00
|
|
|
app.get('/challenges/', coursewareController.returnNextCourseware);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-02-02 07:35:27 +00:00
|
|
|
app.get(
|
2015-03-21 09:42:19 +00:00
|
|
|
'/challenges/:coursewareName',
|
2015-02-02 07:35:27 +00:00
|
|
|
coursewareController.returnIndividualCourseware
|
|
|
|
);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-02-02 07:35:27 +00:00
|
|
|
app.post('/completed-courseware/', coursewareController.completedCourseware);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-29 11:39:41 +00:00
|
|
|
app.post('/completed-zipline-or-basejump',
|
|
|
|
coursewareController.completedZiplineOrBasejump);
|
2015-02-02 07:35:27 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
// Unique Check API route
|
|
|
|
app.get('/api/checkUniqueUsername/:username', userController.checkUniqueUsername);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
app.get('/api/checkExistingUsername/:username', userController.checkExistingUsername);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
app.get('/api/checkUniqueEmail/:email', userController.checkUniqueEmail);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
app.get('/account', userController.getAccount);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
app.post('/account/profile', userController.postUpdateProfile);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
app.post('/account/password', userController.postUpdatePassword);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
app.post('/account/delete', userController.postDeleteAccount);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-01-28 01:12:51 +00:00
|
|
|
app.get('/account/unlink/:provider', userController.getOauthUnlink);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2015-03-06 08:20:39 +00:00
|
|
|
app.get('/sitemap.xml', resourcesController.sitemap);
|
2015-03-31 01:02:50 +00:00
|
|
|
|
2014-02-01 08:30:14 +00:00
|
|
|
/**
|
2014-06-06 18:58:30 +00:00
|
|
|
* OAuth sign-in routes.
|
2014-02-01 08:30:14 +00:00
|
|
|
*/
|
2014-12-23 21:50:14 +00:00
|
|
|
|
|
|
|
var passportOptions = {
|
2015-01-16 23:58:27 +00:00
|
|
|
successRedirect: '/',
|
|
|
|
failureRedirect: '/login'
|
2014-12-23 21:50:14 +00:00
|
|
|
};
|
|
|
|
|
2015-01-18 02:52:58 +00:00
|
|
|
app.get('/auth/twitter', passport.authenticate('twitter'));
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2014-11-19 23:30:36 +00:00
|
|
|
app.get(
|
2015-01-16 23:58:27 +00:00
|
|
|
'/auth/twitter/callback',
|
|
|
|
passport.authenticate('twitter', {
|
|
|
|
successRedirect: '/',
|
|
|
|
failureRedirect: '/login'
|
|
|
|
})
|
2014-12-23 21:50:14 +00:00
|
|
|
);
|
|
|
|
|
2014-11-19 23:30:36 +00:00
|
|
|
app.get(
|
2015-01-16 23:58:27 +00:00
|
|
|
'/auth/linkedin',
|
|
|
|
passport.authenticate('linkedin', {
|
|
|
|
state: 'SOME STATE'
|
|
|
|
})
|
2014-12-23 21:50:14 +00:00
|
|
|
);
|
2014-11-19 23:30:36 +00:00
|
|
|
|
|
|
|
app.get(
|
2015-01-16 23:58:27 +00:00
|
|
|
'/auth/linkedin/callback',
|
|
|
|
passport.authenticate('linkedin', passportOptions)
|
2014-12-23 21:50:14 +00:00
|
|
|
);
|
2014-11-19 23:30:36 +00:00
|
|
|
|
2014-12-23 16:48:28 +00:00
|
|
|
app.get(
|
2015-01-16 23:58:27 +00:00
|
|
|
'/auth/facebook',
|
|
|
|
passport.authenticate('facebook', {scope: ['email', 'user_location']})
|
2014-12-23 16:48:28 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
app.get(
|
2015-01-16 23:58:27 +00:00
|
|
|
'/auth/facebook/callback',
|
|
|
|
passport.authenticate('facebook', passportOptions), function (req, res) {
|
|
|
|
res.redirect(req.session.returnTo || '/');
|
|
|
|
}
|
2014-12-23 16:48:28 +00:00
|
|
|
);
|
2014-11-30 06:22:27 +00:00
|
|
|
|
|
|
|
app.get('/auth/github', passport.authenticate('github'));
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2014-12-23 16:48:28 +00:00
|
|
|
app.get(
|
2015-01-16 23:58:27 +00:00
|
|
|
'/auth/github/callback',
|
|
|
|
passport.authenticate('github', passportOptions), function (req, res) {
|
|
|
|
res.redirect(req.session.returnTo || '/');
|
|
|
|
}
|
2014-12-23 16:48:28 +00:00
|
|
|
);
|
2014-11-30 06:22:27 +00:00
|
|
|
|
2014-12-23 16:48:28 +00:00
|
|
|
app.get(
|
2015-01-16 23:58:27 +00:00
|
|
|
'/auth/google',
|
|
|
|
passport.authenticate('google', {scope: 'profile email'})
|
2014-12-23 16:48:28 +00:00
|
|
|
);
|
2015-03-30 22:15:07 +00:00
|
|
|
|
2014-12-23 16:48:28 +00:00
|
|
|
app.get(
|
2015-01-16 23:58:27 +00:00
|
|
|
'/auth/google/callback',
|
|
|
|
passport.authenticate('google', passportOptions), function (req, res) {
|
|
|
|
res.redirect(req.session.returnTo || '/');
|
|
|
|
}
|
2014-12-23 16:48:28 +00:00
|
|
|
);
|
2014-11-30 06:22:27 +00:00
|
|
|
|
2015-03-24 15:03:59 +00:00
|
|
|
// put this route last
|
2015-01-18 02:52:58 +00:00
|
|
|
app.get(
|
|
|
|
'/:username',
|
|
|
|
userController.returnUser
|
|
|
|
);
|
2015-01-11 05:45:22 +00:00
|
|
|
|
2014-11-19 23:30:36 +00:00
|
|
|
/**
|
|
|
|
* 500 Error Handler.
|
|
|
|
*/
|
2015-03-24 15:03:59 +00:00
|
|
|
if (process.env.NODE_ENV === 'development') {
|
|
|
|
app.use(errorHandler({ log: true }));
|
|
|
|
} else {
|
|
|
|
// error handling in production
|
|
|
|
app.use(function(err, req, res, next) {
|
|
|
|
|
|
|
|
// respect err.status
|
|
|
|
if (err.status) {
|
|
|
|
res.statusCode = err.status;
|
|
|
|
}
|
|
|
|
|
|
|
|
// default status code to 500
|
|
|
|
if (res.statusCode < 400) {
|
|
|
|
res.statusCode = 500;
|
|
|
|
}
|
|
|
|
|
|
|
|
// parse res type
|
|
|
|
var accept = accepts(req);
|
|
|
|
var type = accept.type('html', 'json', 'text');
|
|
|
|
|
|
|
|
var message = 'opps! Something went wrong. Please try again later';
|
|
|
|
if (type === 'html') {
|
|
|
|
req.flash('errors', { msg: message });
|
|
|
|
return res.redirect('/');
|
|
|
|
// json
|
|
|
|
} else if (type === 'json') {
|
|
|
|
res.setHeader('Content-Type', 'application/json');
|
|
|
|
return res.send({ message: message });
|
|
|
|
// plain text
|
|
|
|
} else {
|
|
|
|
res.setHeader('Content-Type', 'text/plain');
|
|
|
|
return res.send(message);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2014-11-19 23:30:36 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Start Express server.
|
|
|
|
*/
|
2015-01-16 23:58:27 +00:00
|
|
|
app.listen(app.get('port'), function () {
|
|
|
|
console.log(
|
|
|
|
'FreeCodeCamp server listening on port %d in %s mode',
|
|
|
|
app.get('port'),
|
|
|
|
app.get('env')
|
|
|
|
);
|
2014-11-19 23:30:36 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = app;
|