* Middleware overhaul! - Remove unnecessary 'async' keywords from middleware functions - Ensure all middleware functions we create have names - Wrap the method contents of all async middleware functions in a try-catch+next(error) pattern * Use asyncMiddleware wrapper instead of try-catch+next(error) pattern * Remove unnecessary try-catch+next(error) pattern from context middleware
30 lines
1.3 KiB
JavaScript
30 lines
1.3 KiB
JavaScript
const path = require('path')
|
|
const { defaults } = require('lodash')
|
|
const webhookPayloads = require(path.join(process.cwd(), 'lib/webhooks'))
|
|
const nonEnterpriseDefaultVersion = require('../../lib/non-enterprise-default-version')
|
|
const allVersions = require('../../lib/all-versions')
|
|
|
|
module.exports = function webhooksContext (req, res, next) {
|
|
const currentVersionObj = allVersions[req.context.currentVersion]
|
|
// ignore requests to non-webhook reference paths
|
|
// and to versions that don't exist
|
|
if (!req.path.includes('webhook') || !currentVersionObj) {
|
|
return next()
|
|
}
|
|
|
|
// Get the name of the dir under lib/webhooks/static
|
|
// For example, free-pro-team@latest corresponds to dotcom,
|
|
// enterprise-server@2.22 corresponds to ghes-2.22,
|
|
// and github-ae@latest corresponds to ghae
|
|
const webhookPayloadDir = currentVersionObj.miscVersionName
|
|
|
|
const webhookPayloadsForCurrentVersion = webhookPayloads[webhookPayloadDir]
|
|
|
|
// if current version is non-dotcom, include dotcom payloads in object so we can fall back to them if needed
|
|
req.context.webhookPayloadsForCurrentVersion = req.context.currentVersion === nonEnterpriseDefaultVersion
|
|
? webhookPayloadsForCurrentVersion
|
|
: defaults(webhookPayloadsForCurrentVersion, webhookPayloads[allVersions[nonEnterpriseDefaultVersion].miscVersionName])
|
|
|
|
return next()
|
|
}
|