2019-05-14 20:52:48 +02:00
|
|
|
const ms = require('ms')
|
|
|
|
const { logError } = require('./util/logger')
|
|
|
|
|
|
|
|
const fetchGitHubRepos = require('./networks/github')
|
|
|
|
const fetchBounties = require('./networks/bounties')
|
|
|
|
const fetchMedium = require('./networks/medium')
|
2019-05-14 20:59:15 +02:00
|
|
|
const fetchTwitter = require('./networks/twitter')
|
2019-05-14 20:52:48 +02:00
|
|
|
|
|
|
|
let cacheGithub = null
|
|
|
|
let cacheBounties = null
|
|
|
|
let cacheMedium = null
|
2019-05-14 20:59:15 +02:00
|
|
|
let cacheTwitter = null
|
2019-05-14 20:52:48 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// Create the response
|
|
|
|
//
|
|
|
|
module.exports = async (req, res) => {
|
|
|
|
res.setHeader('Access-Control-Allow-Origin', '*')
|
|
|
|
res.setHeader('Access-Control-Allow-Methods', 'GET')
|
|
|
|
|
|
|
|
try {
|
|
|
|
if (!cacheGithub || Date.now() - cacheGithub.lastUpdate > ms('5m')) {
|
|
|
|
cacheGithub = await fetchGitHubRepos()
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!cacheBounties || Date.now() - cacheBounties.lastUpdate > ms('5m')) {
|
|
|
|
cacheBounties = await fetchBounties()
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!cacheMedium || Date.now() - cacheMedium.lastUpdate > ms('5m')) {
|
|
|
|
cacheMedium = await fetchMedium()
|
|
|
|
}
|
2019-05-14 20:59:15 +02:00
|
|
|
|
|
|
|
if (!cacheTwitter || Date.now() - cacheTwitter.lastUpdate > ms('5m')) {
|
|
|
|
cacheTwitter = await fetchTwitter()
|
|
|
|
}
|
2019-05-14 20:52:48 +02:00
|
|
|
} catch (error) {
|
|
|
|
logError(error.message)
|
|
|
|
}
|
|
|
|
|
|
|
|
res.end(JSON.stringify({
|
|
|
|
github: cacheGithub,
|
|
|
|
bounties: cacheBounties,
|
2019-05-14 20:59:15 +02:00
|
|
|
medium: cacheMedium,
|
|
|
|
twitter: cacheTwitter
|
2019-05-14 20:52:48 +02:00
|
|
|
}))
|
|
|
|
}
|