mirror of
https://github.com/badges/shields.git
synced 2025-09-18 05:05:28 +03:00
* migrate some services from examples to openApi * improve and de-dupe service titles * improve description
84 lines
2.2 KiB
JavaScript
84 lines
2.2 KiB
JavaScript
import Joi from 'joi'
|
|
import { NotFound, InvalidParameter, pathParams } from '../index.js'
|
|
import { GithubAuthV3Service } from './github-auth-service.js'
|
|
import { documentation, httpErrorsFor } from './github-helpers.js'
|
|
|
|
const schema = Joi.object({
|
|
// https://stackoverflow.com/a/23969867/893113
|
|
status: Joi.equal('identical', 'ahead', 'behind', 'diverged'),
|
|
}).required()
|
|
|
|
export default class GithubCommitStatus extends GithubAuthV3Service {
|
|
static category = 'issue-tracking'
|
|
static route = {
|
|
base: 'github/commit-status',
|
|
pattern: ':user/:repo/:branch/:commit',
|
|
}
|
|
|
|
static openApi = {
|
|
'/github/commit-status/{user}/{repo}/{branch}/{commit}': {
|
|
get: {
|
|
summary: 'GitHub commit merge status',
|
|
description: documentation,
|
|
parameters: pathParams(
|
|
{
|
|
name: 'user',
|
|
example: 'badges',
|
|
},
|
|
{
|
|
name: 'repo',
|
|
example: 'shields',
|
|
},
|
|
{
|
|
name: 'branch',
|
|
example: 'master',
|
|
},
|
|
{
|
|
name: 'commit',
|
|
example: '5d4ab86b1b5ddfb3c4a70a70bd19932c52603b8c',
|
|
},
|
|
),
|
|
},
|
|
},
|
|
}
|
|
|
|
static defaultBadgeData = { label: 'commit status' }
|
|
|
|
static render({ isInBranch, branch }) {
|
|
if (isInBranch) {
|
|
return {
|
|
message: `in ${branch}`,
|
|
color: 'brightgreen',
|
|
}
|
|
} else {
|
|
// status: ahead or diverged
|
|
return {
|
|
message: `not in ${branch}`,
|
|
color: 'yellow',
|
|
}
|
|
}
|
|
}
|
|
|
|
async handle({ user, repo, branch, commit }) {
|
|
let status
|
|
try {
|
|
;({ status } = await this._requestJson({
|
|
url: `/repos/${user}/${repo}/compare/${branch}...${commit}`,
|
|
httpErrors: httpErrorsFor('commit or branch not found'),
|
|
schema,
|
|
}))
|
|
} catch (e) {
|
|
if (e instanceof NotFound) {
|
|
const { message } = this._parseJson(e.buffer)
|
|
if (message && message.startsWith('No common ancestor between')) {
|
|
throw new InvalidParameter({ prettyMessage: 'no common ancestor' })
|
|
}
|
|
}
|
|
throw e
|
|
}
|
|
|
|
const isInBranch = status === 'identical' || status === 'behind'
|
|
return this.constructor.render({ isInBranch, branch })
|
|
}
|
|
}
|