2016-04-07 13:00:51 -07:00
|
|
|
import request from 'request';
|
2018-08-02 11:34:35 +01:00
|
|
|
import { ObjectId } from 'mongodb';
|
2018-06-28 23:04:11 +01:00
|
|
|
|
2016-04-07 13:00:51 -07:00
|
|
|
import constantStrings from '../utils/constantStrings.json';
|
|
|
|
import testimonials from '../resources/testimonials.json';
|
2016-06-23 20:05:30 -07:00
|
|
|
|
|
|
|
const githubClient = process.env.GITHUB_ID;
|
|
|
|
const githubSecret = process.env.GITHUB_SECRET;
|
2015-06-01 16:48:16 -07:00
|
|
|
|
2015-06-03 16:19:23 -07:00
|
|
|
module.exports = function(app) {
|
2016-04-07 13:00:51 -07:00
|
|
|
const router = app.loopback.Router();
|
|
|
|
const User = app.models.User;
|
2018-05-15 06:12:05 +01:00
|
|
|
|
|
|
|
router.get('/api/github', githubCalls);
|
|
|
|
router.get('/chat', chat);
|
|
|
|
router.get('/twitch', twitch);
|
2018-05-28 22:04:46 +01:00
|
|
|
router.get('/u/:email', unsubscribe);
|
|
|
|
router.get('/unsubscribe/:email', unsubscribe);
|
2018-08-02 11:34:35 +01:00
|
|
|
router.get('/ue/:unsubscribeId', unsubscribeById);
|
2018-05-15 06:12:05 +01:00
|
|
|
router.get(
|
2016-06-17 12:35:10 -07:00
|
|
|
'/the-fastest-web-page-on-the-internet',
|
|
|
|
theFastestWebPageOnTheInternet
|
|
|
|
);
|
2018-08-02 11:34:35 +01:00
|
|
|
router.get('/unsubscribed/:unsubscribeId', unsubscribedWithId);
|
2016-06-17 12:35:10 -07:00
|
|
|
router.get('/unsubscribed', unsubscribed);
|
2018-08-02 11:34:35 +01:00
|
|
|
router.get('/resubscribe/:unsubscribeId', resubscribe);
|
2015-06-03 16:19:23 -07:00
|
|
|
router.get('/nonprofits', nonprofits);
|
|
|
|
router.get('/nonprofits-form', nonprofitsForm);
|
2016-06-17 12:35:10 -07:00
|
|
|
router.get('/pmi-acp-agile-project-managers', agileProjectManagers);
|
|
|
|
router.get('/pmi-acp-agile-project-managers-form', agileProjectManagersForm);
|
|
|
|
router.get('/coding-bootcamp-cost-calculator', bootcampCalculator);
|
2015-10-07 00:26:17 -07:00
|
|
|
router.get('/stories', showTestimonials);
|
2015-11-03 17:39:02 -08:00
|
|
|
router.get('/all-stories', showAllTestimonials);
|
2016-02-19 17:36:03 -08:00
|
|
|
router.get('/how-nonprofit-projects-work', howNonprofitProjectsWork);
|
2016-07-28 00:12:32 -07:00
|
|
|
router.get(
|
|
|
|
'/software-resources-for-nonprofits',
|
|
|
|
softwareResourcesForNonprofits
|
|
|
|
);
|
2016-02-13 16:32:14 -08:00
|
|
|
router.get('/academic-honesty', academicHonesty);
|
2015-06-03 16:19:23 -07:00
|
|
|
|
2018-05-15 06:12:05 +01:00
|
|
|
app.use(router);
|
2015-06-03 16:31:42 -07:00
|
|
|
|
2015-06-03 16:19:23 -07:00
|
|
|
function chat(req, res) {
|
2015-07-31 17:30:27 -07:00
|
|
|
res.redirect('https://gitter.im/FreeCodeCamp/FreeCodeCamp');
|
2015-06-15 21:44:19 -07:00
|
|
|
}
|
|
|
|
|
2016-02-19 17:36:03 -08:00
|
|
|
function howNonprofitProjectsWork(req, res) {
|
2018-04-23 10:47:11 +05:30
|
|
|
res.redirect(301,
|
|
|
|
'https://medium.freecodecamp.com/open-source-for-good-1a0ea9f32d5a');
|
|
|
|
|
2016-02-19 17:36:03 -08:00
|
|
|
}
|
|
|
|
|
2016-07-28 00:12:32 -07:00
|
|
|
function softwareResourcesForNonprofits(req, res) {
|
|
|
|
res.render('resources/software-resources-for-nonprofits', {
|
|
|
|
title: 'Software Resources for Nonprofits'
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2016-02-13 16:32:14 -08:00
|
|
|
function academicHonesty(req, res) {
|
|
|
|
res.render('resources/academic-honesty', {
|
|
|
|
title: 'Academic Honesty policy'
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2015-11-25 10:23:35 -06:00
|
|
|
function theFastestWebPageOnTheInternet(req, res) {
|
|
|
|
res.render('resources/the-fastest-web-page-on-the-internet', {
|
|
|
|
title: 'This is the fastest web page on the internet'
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2015-10-07 00:26:17 -07:00
|
|
|
function showTestimonials(req, res) {
|
2015-10-06 21:28:00 -07:00
|
|
|
res.render('resources/stories', {
|
2017-01-13 21:14:43 -05:00
|
|
|
title: 'Testimonials from Happy freeCodeCamp Students ' +
|
2015-11-03 21:51:16 -08:00
|
|
|
'who got Software Engineer Jobs',
|
2015-11-03 17:58:47 -08:00
|
|
|
stories: testimonials.slice(0, 72),
|
2015-11-03 17:39:02 -08:00
|
|
|
moreStories: true
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function showAllTestimonials(req, res) {
|
|
|
|
res.render('resources/stories', {
|
2017-01-13 21:14:43 -05:00
|
|
|
title: 'Testimonials from Happy freeCodeCamp Students ' +
|
2015-11-03 21:51:16 -08:00
|
|
|
'who got Software Engineer Jobs',
|
2015-11-03 17:39:02 -08:00
|
|
|
stories: testimonials,
|
|
|
|
moreStories: false
|
2015-10-06 18:19:43 -07:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2015-07-31 17:30:27 -07:00
|
|
|
function bootcampCalculator(req, res) {
|
|
|
|
res.render('resources/calculator', {
|
|
|
|
title: 'Coding Bootcamp Cost Calculator'
|
|
|
|
});
|
2015-06-20 18:40:43 -07:00
|
|
|
}
|
|
|
|
|
2015-06-03 16:19:23 -07:00
|
|
|
function nonprofits(req, res) {
|
|
|
|
res.render('resources/nonprofits', {
|
2015-10-31 02:59:09 -07:00
|
|
|
title: 'Your Nonprofit Can Get Pro Bono Code'
|
2015-06-03 16:19:23 -07:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function nonprofitsForm(req, res) {
|
|
|
|
res.render('resources/nonprofits-form', {
|
|
|
|
title: 'Nonprofit Projects Proposal Form'
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function agileProjectManagers(req, res) {
|
|
|
|
res.render('resources/pmi-acp-agile-project-managers', {
|
|
|
|
title: 'Get Agile Project Management Experience for the PMI-ACP'
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function agileProjectManagersForm(req, res) {
|
|
|
|
res.render('resources/pmi-acp-agile-project-managers-form', {
|
|
|
|
title: 'Agile Project Management Program Application Form'
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function twitch(req, res) {
|
2016-03-06 06:20:34 +07:00
|
|
|
res.redirect('https://twitch.tv/freecodecamp');
|
2015-06-03 16:19:23 -07:00
|
|
|
}
|
|
|
|
|
2018-05-28 22:04:46 +01:00
|
|
|
function unsubscribe(req, res, next) {
|
|
|
|
req.checkParams(
|
|
|
|
'email',
|
|
|
|
`"${req.params.email}" isn't a valid email address.`
|
|
|
|
).isEmail();
|
|
|
|
const errors = req.validationErrors(true);
|
|
|
|
if (errors) {
|
|
|
|
req.flash('error', { msg: errors.email.msg });
|
|
|
|
return res.redirect('/');
|
|
|
|
}
|
|
|
|
return User.find({
|
|
|
|
where: {
|
|
|
|
email: req.params.email
|
|
|
|
}
|
|
|
|
}, (err, users) => {
|
2016-03-15 11:22:54 -07:00
|
|
|
if (err) { return next(err); }
|
2018-05-28 22:04:46 +01:00
|
|
|
if (!users.length) {
|
|
|
|
req.flash('info', {
|
|
|
|
msg: 'Email address not found. Please update your Email ' +
|
|
|
|
'preferences from your settings.'
|
|
|
|
});
|
|
|
|
return res.redirect('/');
|
2017-01-04 23:33:25 -07:00
|
|
|
}
|
2018-05-28 22:04:46 +01:00
|
|
|
|
|
|
|
const updates = users.map(user => {
|
|
|
|
return new Promise((resolve, reject) =>
|
|
|
|
user.updateAttributes({
|
|
|
|
sendQuincyEmail: false
|
|
|
|
}, (err) => {
|
|
|
|
if (err) {
|
|
|
|
reject(err);
|
|
|
|
} else {
|
|
|
|
resolve();
|
|
|
|
}
|
|
|
|
})
|
|
|
|
);
|
|
|
|
});
|
|
|
|
return Promise.all(updates)
|
|
|
|
.then(() => {
|
|
|
|
req.flash('info', {
|
|
|
|
msg: 'We\'ve successfully updated your Email preferences.'
|
|
|
|
});
|
2018-08-02 11:34:35 +01:00
|
|
|
return res.redirect('/unsubscribed/');
|
2018-05-28 22:04:46 +01:00
|
|
|
})
|
|
|
|
.catch(next);
|
2015-06-01 18:30:43 -04:00
|
|
|
});
|
2015-06-03 16:19:23 -07:00
|
|
|
}
|
2015-06-01 18:30:43 -04:00
|
|
|
|
2018-08-02 11:34:35 +01:00
|
|
|
function unsubscribeById(req, res, next) {
|
|
|
|
const { unsubscribeId } = req.params;
|
|
|
|
return User.find({ where: { unsubscribeId } }, (err, users) => {
|
|
|
|
if (err || !users.length) {
|
|
|
|
req.flash('info', {
|
|
|
|
msg: 'We could not find an account to unsubscribe'
|
|
|
|
});
|
|
|
|
return res.redirect('/');
|
|
|
|
|
|
|
|
}
|
|
|
|
const [ user ] = users;
|
|
|
|
return new Promise((resolve, reject) =>
|
|
|
|
user.updateAttributes({
|
|
|
|
sendQuincyEmail: false,
|
|
|
|
unsubscribeId: unsubscribeId
|
|
|
|
}, (err) => {
|
|
|
|
if (err) {
|
|
|
|
reject(err);
|
|
|
|
} else {
|
|
|
|
resolve();
|
|
|
|
}
|
|
|
|
})
|
|
|
|
).then(() => {
|
|
|
|
req.flash('success', {
|
|
|
|
msg: 'We\'ve successfully updated your email preferences.'
|
|
|
|
});
|
|
|
|
return res.redirect(`/unsubscribed/${queryId}`);
|
|
|
|
})
|
|
|
|
.catch(next);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2015-06-03 16:19:23 -07:00
|
|
|
function unsubscribed(req, res) {
|
|
|
|
res.render('resources/unsubscribed', {
|
|
|
|
title: 'You have been unsubscribed'
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-08-02 11:34:35 +01:00
|
|
|
function unsubscribedWithId(req, res) {
|
|
|
|
const { unsubscribeId } = req.params;
|
|
|
|
return res.render('resources/unsubscribed', {
|
|
|
|
title: 'You have been unsubscribed',
|
|
|
|
unsubscribeId
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function resubscribe(req, res, next) {
|
|
|
|
const { unsubscribeId: queryId } = req.params;
|
|
|
|
return User.find({
|
|
|
|
where: {
|
|
|
|
or: [
|
|
|
|
{ unsubscribeId: queryId },
|
|
|
|
{ unsubscribeId: ObjectId(queryId).toString() },
|
|
|
|
{ unsubscribeId: ObjectId(queryId) }
|
|
|
|
]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
(err, users) => {
|
|
|
|
if (err || !users.length) {
|
|
|
|
req.flash('info', {
|
|
|
|
msg: 'We could not find an account to unsubscribe'
|
|
|
|
});
|
|
|
|
return res.redirect('/');
|
|
|
|
|
|
|
|
}
|
|
|
|
const [ user ] = users;
|
|
|
|
return new Promise((resolve, reject) =>
|
|
|
|
user.updateAttributes({
|
|
|
|
sendQuincyEmail: true
|
|
|
|
}, (err) => {
|
|
|
|
if (err) {
|
|
|
|
reject(err);
|
|
|
|
} else {
|
|
|
|
resolve();
|
|
|
|
}
|
|
|
|
})
|
|
|
|
)
|
|
|
|
.then(() => {
|
|
|
|
req.flash('success', {
|
|
|
|
msg:
|
|
|
|
'We\'ve successfully updated your email preferences. Thank you ' +
|
|
|
|
'for resubscribing.'
|
|
|
|
});
|
|
|
|
return res.redirect('/');
|
|
|
|
})
|
|
|
|
.catch(next);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-06-03 16:19:23 -07:00
|
|
|
function githubCalls(req, res, next) {
|
|
|
|
var githubHeaders = {
|
|
|
|
headers: {
|
|
|
|
'User-Agent': constantStrings.gitHubUserAgent
|
2015-06-01 18:30:43 -04:00
|
|
|
},
|
2015-06-03 16:19:23 -07:00
|
|
|
port: 80
|
|
|
|
};
|
|
|
|
request(
|
|
|
|
[
|
|
|
|
'https://api.github.com/repos/freecodecamp/',
|
|
|
|
'freecodecamp/pulls?client_id=',
|
2016-06-23 20:05:30 -07:00
|
|
|
githubClient,
|
2015-06-03 16:19:23 -07:00
|
|
|
'&client_secret=',
|
2016-06-23 20:05:30 -07:00
|
|
|
githubSecret
|
2015-06-03 16:19:23 -07:00
|
|
|
].join(''),
|
|
|
|
githubHeaders,
|
|
|
|
function(err, status1, pulls) {
|
|
|
|
if (err) { return next(err); }
|
|
|
|
pulls = pulls ?
|
|
|
|
Object.keys(JSON.parse(pulls)).length :
|
|
|
|
'Can\'t connect to github';
|
|
|
|
|
2016-03-02 20:54:14 -08:00
|
|
|
return request(
|
2015-06-03 16:19:23 -07:00
|
|
|
[
|
|
|
|
'https://api.github.com/repos/freecodecamp/',
|
|
|
|
'freecodecamp/issues?client_id=',
|
2016-06-23 20:05:30 -07:00
|
|
|
githubClient,
|
2015-06-03 16:19:23 -07:00
|
|
|
'&client_secret=',
|
2016-06-23 20:05:30 -07:00
|
|
|
githubSecret
|
2015-06-03 16:19:23 -07:00
|
|
|
].join(''),
|
|
|
|
githubHeaders,
|
2015-10-07 00:28:42 -07:00
|
|
|
function(err, status2, issues) {
|
2015-06-03 16:19:23 -07:00
|
|
|
if (err) { return next(err); }
|
|
|
|
issues = ((pulls === parseInt(pulls, 10)) && issues) ?
|
|
|
|
Object.keys(JSON.parse(issues)).length - pulls :
|
|
|
|
"Can't connect to GitHub";
|
2016-03-02 20:54:14 -08:00
|
|
|
return res.send({
|
2015-06-03 16:19:23 -07:00
|
|
|
issues: issues,
|
|
|
|
pulls: pulls
|
|
|
|
});
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
};
|