Files
freeCodeCamp/server/boot/randomAPIs.js

205 lines
5.9 KiB
JavaScript
Raw Normal View History

import request from 'request';
import constantStrings from '../utils/constantStrings.json';
import testimonials from '../resources/testimonials.json';
const githubClient = process.env.GITHUB_ID;
const githubSecret = process.env.GITHUB_SECRET;
module.exports = function(app) {
const router = app.loopback.Router();
const User = app.models.User;
2016-06-17 12:35:10 -07:00
const noLangRouter = app.loopback.Router();
noLangRouter.get('/api/github', githubCalls);
noLangRouter.get('/chat', chat);
noLangRouter.get('/twitch', twitch);
noLangRouter.get('/unsubscribe/:email', unsubscribeAll);
noLangRouter.get('/unsubscribe-notifications/:email', unsubscribeAll);
noLangRouter.get('/unsubscribe-quincy/:email', unsubscribeAll);
2016-06-17 12:35:10 -07:00
noLangRouter.get('/submit-cat-photo', submitCatPhoto);
noLangRouter.get(
'/the-fastest-web-page-on-the-internet',
theFastestWebPageOnTheInternet
);
router.get('/unsubscribed', unsubscribed);
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);
router.get('/stories', showTestimonials);
2015-11-03 17:39:02 -08:00
router.get('/all-stories', showAllTestimonials);
router.get('/how-nonprofit-projects-work', howNonprofitProjectsWork);
2016-07-28 00:12:32 -07:00
router.get(
'/software-resources-for-nonprofits',
softwareResourcesForNonprofits
);
router.get('/academic-honesty', academicHonesty);
2016-06-17 12:35:10 -07:00
app.use(noLangRouter);
app.use('/:lang', router);
function chat(req, res) {
res.redirect('https://gitter.im/FreeCodeCamp/FreeCodeCamp');
2015-06-15 21:44:19 -07:00
}
function howNonprofitProjectsWork(req, res) {
res.redirect(301,
'https://medium.freecodecamp.com/open-source-for-good-1a0ea9f32d5a');
}
2016-07-28 00:12:32 -07:00
function softwareResourcesForNonprofits(req, res) {
res.render('resources/software-resources-for-nonprofits', {
title: 'Software Resources for Nonprofits'
});
}
function academicHonesty(req, res) {
res.render('resources/academic-honesty', {
title: 'Academic Honesty policy'
});
}
function theFastestWebPageOnTheInternet(req, res) {
res.render('resources/the-fastest-web-page-on-the-internet', {
title: 'This is the fastest web page on the internet'
});
}
function showTestimonials(req, res) {
2015-10-06 21:28:00 -07:00
res.render('resources/stories', {
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', {
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-08-13 17:20:52 -07:00
function submitCatPhoto(req, res) {
res.send('Submitted!');
}
function bootcampCalculator(req, res) {
res.render('resources/calculator', {
title: 'Coding Bootcamp Cost Calculator'
});
}
function nonprofits(req, res) {
res.render('resources/nonprofits', {
2015-10-31 02:59:09 -07:00
title: 'Your Nonprofit Can Get Pro Bono Code'
});
}
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');
}
function unsubscribeAll(req, res, next) {
2016-03-15 11:22:54 -07:00
req.checkParams('email', 'Must send a valid email').isEmail();
var query = { email: req.params.email };
var params = {
sendQuincyEmail: false,
sendMonthlyEmail: false,
sendNotificationEmail: false
};
return User.updateAll(query, params, function(err, info) {
2016-03-15 11:22:54 -07:00
if (err) { return next(err); }
if (info.count === 0) {
req.flash(
'info',
'Email address not found. ' +
'Please update your Email preferences from your profile.'
);
2016-03-21 22:14:48 +00:00
return res.redirect('/map');
} else {
req.flash(
'info',
'We\'ve successfully updated your Email preferences.'
);
2016-03-15 11:22:54 -07:00
return res.redirect('/unsubscribed');
}
});
}
function unsubscribed(req, res) {
res.render('resources/unsubscribed', {
title: 'You have been unsubscribed'
});
}
function githubCalls(req, res, next) {
var githubHeaders = {
headers: {
'User-Agent': constantStrings.gitHubUserAgent
},
port: 80
};
request(
[
'https://api.github.com/repos/freecodecamp/',
'freecodecamp/pulls?client_id=',
githubClient,
'&client_secret=',
githubSecret
].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(
[
'https://api.github.com/repos/freecodecamp/',
'freecodecamp/issues?client_id=',
githubClient,
'&client_secret=',
githubSecret
].join(''),
githubHeaders,
2015-10-07 00:28:42 -07:00
function(err, status2, issues) {
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({
issues: issues,
pulls: pulls
});
}
);
}
);
}
};