This is consistent with what we're pretty much already doing, and saves us from making the request during code review. These were all autofixed and most of them seem easier to read. Some in the legacy services should be rewritten in more legible forms during refactor (ie using intermediate variables, or using request’s qs option). There are some in helper functions and elsewhere that should get rewritten separately. I don't want to change them in this PR because the changes will get lost in this diff, though we could identify them here and fix them before or just after.
117 lines
3.5 KiB
JavaScript
117 lines
3.5 KiB
JavaScript
'use strict'
|
|
|
|
const LegacyService = require('../legacy-service')
|
|
const {
|
|
makeBadgeData: getBadgeData,
|
|
makeLogo: getLogo,
|
|
} = require('../../lib/badge-data')
|
|
const { metric } = require('../../lib/text-formatters')
|
|
const {
|
|
checkErrorResponse: githubCheckErrorResponse,
|
|
} = require('./github-helpers')
|
|
|
|
module.exports = class GithubDownloads extends LegacyService {
|
|
static registerLegacyRouteHandler({ camp, cache, githubApiProvider }) {
|
|
camp.route(
|
|
/^\/github\/(downloads|downloads-pre)\/([^/]+)\/([^/]+)(\/.+)?\/([^/]+)\.(svg|png|gif|jpg|json)$/,
|
|
cache((data, match, sendBadge, request) => {
|
|
const type = match[1] // downloads or downloads-pre
|
|
const user = match[2] // eg, qubyte/rubidium
|
|
const repo = match[3]
|
|
|
|
let tag = match[4] // eg, v0.190.0, latest, null if querying all releases
|
|
const assetName = match[5].toLowerCase() // eg. total, atom-amd64.deb, atom.x86_64.rpm
|
|
const format = match[6]
|
|
|
|
if (tag) {
|
|
tag = tag.slice(1)
|
|
}
|
|
|
|
let total = true
|
|
if (tag) {
|
|
total = false
|
|
}
|
|
|
|
let apiUrl = `/repos/${user}/${repo}/releases`
|
|
if (!total) {
|
|
const releasePath =
|
|
tag === 'latest'
|
|
? type === 'downloads'
|
|
? 'latest'
|
|
: ''
|
|
: `tags/${tag}`
|
|
if (releasePath) {
|
|
apiUrl = `${apiUrl}/${releasePath}`
|
|
}
|
|
}
|
|
const badgeData = getBadgeData('downloads', data)
|
|
if (badgeData.template === 'social') {
|
|
badgeData.logo = getLogo('github', data)
|
|
}
|
|
githubApiProvider.request(request, apiUrl, {}, (err, res, buffer) => {
|
|
if (
|
|
githubCheckErrorResponse(
|
|
badgeData,
|
|
err,
|
|
res,
|
|
'repo or release not found'
|
|
)
|
|
) {
|
|
sendBadge(format, badgeData)
|
|
return
|
|
}
|
|
try {
|
|
let data = JSON.parse(buffer)
|
|
if (type === 'downloads-pre' && tag === 'latest') {
|
|
data = data[0]
|
|
}
|
|
let downloads = 0
|
|
|
|
const labelWords = []
|
|
if (total) {
|
|
data.forEach(tagData => {
|
|
tagData.assets.forEach(asset => {
|
|
if (
|
|
assetName === 'total' ||
|
|
assetName === asset.name.toLowerCase()
|
|
) {
|
|
downloads += asset.download_count
|
|
}
|
|
})
|
|
})
|
|
|
|
labelWords.push('total')
|
|
if (assetName !== 'total') {
|
|
labelWords.push(`[${assetName}]`)
|
|
}
|
|
} else {
|
|
data.assets.forEach(asset => {
|
|
if (
|
|
assetName === 'total' ||
|
|
assetName === asset.name.toLowerCase()
|
|
) {
|
|
downloads += asset.download_count
|
|
}
|
|
})
|
|
|
|
if (tag !== 'latest') {
|
|
labelWords.push(tag)
|
|
}
|
|
if (assetName !== 'total') {
|
|
labelWords.push(`[${assetName}]`)
|
|
}
|
|
}
|
|
labelWords.unshift(metric(downloads))
|
|
badgeData.text[1] = labelWords.join(' ')
|
|
badgeData.colorscheme = 'brightgreen'
|
|
sendBadge(format, badgeData)
|
|
} catch (e) {
|
|
badgeData.text[1] = 'none'
|
|
sendBadge(format, badgeData)
|
|
}
|
|
})
|
|
})
|
|
)
|
|
}
|
|
}
|