This moves a few helpers from `lib/` to `services/`: build-status.js build-status.spec.js color-formatters.js color-formatters.spec.js contributor-count.js licenses.js licenses.spec.js php-version.js php-version.spec.js text-formatters.js text-formatters.spec.js version.js version.spec.js And one from `lib/` to `core/`: unhandled-rejection.spec.js The diff is long, but the changes are straightforward. Ref #2832
161 lines
5.1 KiB
JavaScript
161 lines
5.1 KiB
JavaScript
'use strict'
|
|
|
|
const LegacyService = require('../legacy-service')
|
|
const {
|
|
makeLabel: getLabel,
|
|
makeBadgeData: getBadgeData,
|
|
} = require('../../lib/badge-data')
|
|
const { makeLogo: getLogo } = require('../../lib/logos')
|
|
const { formatDate } = require('../text-formatters')
|
|
const { age: ageColor } = require('../color-formatters')
|
|
const {
|
|
documentation,
|
|
stateColor: githubStateColor,
|
|
commentsColor: githubCommentsColor,
|
|
checkErrorResponse: githubCheckErrorResponse,
|
|
} = require('./github-helpers')
|
|
|
|
// This legacy service should be rewritten to use e.g. BaseJsonService.
|
|
//
|
|
// Tips for rewriting:
|
|
// https://github.com/badges/shields/blob/master/doc/rewriting-services.md
|
|
//
|
|
// Do not base new services on this code.
|
|
module.exports = class GithubIssueDetail extends LegacyService {
|
|
static get category() {
|
|
return 'issue-tracking'
|
|
}
|
|
|
|
static get route() {
|
|
return {
|
|
base: 'github/issues/detail',
|
|
pattern:
|
|
':which(s|state|title|u|author|label|comments|age|last-update)/:user/:repo/:number(0-9+)',
|
|
}
|
|
}
|
|
|
|
static get examples() {
|
|
return [
|
|
{
|
|
title: 'GitHub issue/pull request detail',
|
|
pattern:
|
|
':which(state|title|author|label|comments|age|last-update)/:user/:repo/:number',
|
|
namedParams: {
|
|
which: 'state',
|
|
user: 'badges',
|
|
repo: 'shields',
|
|
number: '979',
|
|
},
|
|
staticPreview: {
|
|
label: 'issue 979',
|
|
message: 'closed',
|
|
color: 'red',
|
|
},
|
|
keywords: [
|
|
'state',
|
|
'title',
|
|
'author',
|
|
'label',
|
|
'comments',
|
|
'age',
|
|
'last update',
|
|
],
|
|
documentation,
|
|
},
|
|
]
|
|
}
|
|
|
|
static registerLegacyRouteHandler({ camp, cache, githubApiProvider }) {
|
|
camp.route(
|
|
/^\/github\/(?:issues|pulls)\/detail\/(s|title|u|label|comments|age|last-update)\/([^/]+)\/([^/]+)\/(\d+)\.(svg|png|gif|jpg|json)$/,
|
|
cache((queryParams, match, sendBadge, request) => {
|
|
const [, which, owner, repo, number, format] = match
|
|
const uri = `/repos/${owner}/${repo}/issues/${number}`
|
|
const badgeData = getBadgeData(
|
|
`issue/pull request ${number}`,
|
|
queryParams
|
|
)
|
|
if (badgeData.template === 'social') {
|
|
badgeData.logo = getLogo('github', queryParams)
|
|
}
|
|
githubApiProvider.request(request, uri, {}, (err, res, buffer) => {
|
|
if (
|
|
githubCheckErrorResponse(
|
|
badgeData,
|
|
err,
|
|
res,
|
|
'issue, pull request or repo not found'
|
|
)
|
|
) {
|
|
sendBadge(format, badgeData)
|
|
return
|
|
}
|
|
try {
|
|
const parsedData = JSON.parse(buffer)
|
|
const isPR = 'pull_request' in parsedData
|
|
const noun = isPR ? 'pull request' : 'issue'
|
|
badgeData.text[0] = getLabel(
|
|
`${noun} ${parsedData.number}`,
|
|
queryParams
|
|
)
|
|
switch (which) {
|
|
case 's':
|
|
case 'state': {
|
|
const state = (badgeData.text[1] = parsedData.state)
|
|
badgeData.colorscheme = undefined
|
|
badgeData.colorB = queryParams.colorB || githubStateColor(state)
|
|
break
|
|
}
|
|
case 'title':
|
|
badgeData.text[1] = parsedData.title
|
|
break
|
|
case 'u':
|
|
case 'author':
|
|
badgeData.text[0] = getLabel('author', queryParams)
|
|
badgeData.text[1] = parsedData.user.login
|
|
break
|
|
case 'label':
|
|
badgeData.text[0] = getLabel('label', queryParams)
|
|
badgeData.text[1] = parsedData.labels
|
|
.map(i => i.name)
|
|
.join(' | ')
|
|
if (parsedData.labels.length === 1) {
|
|
badgeData.colorscheme = undefined
|
|
badgeData.colorB =
|
|
queryParams.colorB || parsedData.labels[0].color
|
|
}
|
|
break
|
|
case 'comments': {
|
|
badgeData.text[0] = getLabel('comments', queryParams)
|
|
const comments = (badgeData.text[1] = parsedData.comments)
|
|
badgeData.colorscheme = undefined
|
|
badgeData.colorB =
|
|
queryParams.coloB || githubCommentsColor(comments)
|
|
break
|
|
}
|
|
case 'age':
|
|
case 'last-update': {
|
|
const label = which === 'age' ? 'created' : 'updated'
|
|
const date =
|
|
which === 'age'
|
|
? parsedData.created_at
|
|
: parsedData.updated_at
|
|
badgeData.text[0] = getLabel(label, queryParams)
|
|
badgeData.text[1] = formatDate(date)
|
|
badgeData.colorscheme = ageColor(Date.parse(date))
|
|
break
|
|
}
|
|
default:
|
|
throw Error('Unreachable due to regex')
|
|
}
|
|
sendBadge(format, badgeData)
|
|
} catch (e) {
|
|
badgeData.text[1] = 'invalid'
|
|
sendBadge(format, badgeData)
|
|
}
|
|
})
|
|
})
|
|
)
|
|
}
|
|
}
|