mirror of
https://code.forgejo.org/actions/setup-node.git
synced 2024-11-06 12:05:48 +00:00
78148dae50
* Updates * Update * Update * Update * Update * Yarn sometimes prefers npmrc, so use same token * Description * Update readme * Feedback * Add type * new toolkit and scoped registries * npmrc in RUNNER_TEMP * Dont always auth * Try exporting blank token * Get auth working for now pending runner changes * Fix string interpolation for auth token. * Don't export both userconfigs * Update authutil.js * Add single quotes for authString * Fix the registry string. * Use userconfig and append trailing slash * Keep in root of repo * Try just adding auth token * Remove auth token * Try changes again * Add tests * Npm and GPR samples * Add types
87 lines
2.7 KiB
JavaScript
87 lines
2.7 KiB
JavaScript
module.exports = registerEndpoints
|
||
|
||
const { Deprecation } = require('deprecation')
|
||
|
||
function registerEndpoints (octokit, routes) {
|
||
Object.keys(routes).forEach(namespaceName => {
|
||
if (!octokit[namespaceName]) {
|
||
octokit[namespaceName] = {}
|
||
}
|
||
|
||
Object.keys(routes[namespaceName]).forEach(apiName => {
|
||
const apiOptions = routes[namespaceName][apiName]
|
||
|
||
const endpointDefaults = ['method', 'url', 'headers'].reduce((map, key) => {
|
||
if (typeof apiOptions[key] !== 'undefined') {
|
||
map[key] = apiOptions[key]
|
||
}
|
||
|
||
return map
|
||
}, {})
|
||
|
||
endpointDefaults.request = {
|
||
validate: apiOptions.params
|
||
}
|
||
|
||
let request = octokit.request.defaults(endpointDefaults)
|
||
|
||
// patch request & endpoint methods to support deprecated parameters.
|
||
// Not the most elegant solution, but we don’t want to move deprecation
|
||
// logic into octokit/endpoint.js as it’s out of scope
|
||
const hasDeprecatedParam = Object.keys(apiOptions.params || {}).find(key => apiOptions.params[key].deprecated)
|
||
if (hasDeprecatedParam) {
|
||
const patch = patchForDeprecation.bind(null, octokit, apiOptions)
|
||
request = patch(
|
||
octokit.request.defaults(endpointDefaults),
|
||
`.${namespaceName}.${apiName}()`
|
||
)
|
||
request.endpoint = patch(
|
||
request.endpoint,
|
||
`.${namespaceName}.${apiName}.endpoint()`
|
||
)
|
||
request.endpoint.merge = patch(
|
||
request.endpoint.merge,
|
||
`.${namespaceName}.${apiName}.endpoint.merge()`
|
||
)
|
||
}
|
||
|
||
if (apiOptions.deprecated) {
|
||
octokit[namespaceName][apiName] = function deprecatedEndpointMethod () {
|
||
octokit.log.warn(new Deprecation(`[@octokit/rest] ${apiOptions.deprecated}`))
|
||
octokit[namespaceName][apiName] = request
|
||
return request.apply(null, arguments)
|
||
}
|
||
|
||
return
|
||
}
|
||
|
||
octokit[namespaceName][apiName] = request
|
||
})
|
||
})
|
||
}
|
||
|
||
function patchForDeprecation (octokit, apiOptions, method, methodName) {
|
||
const patchedMethod = (options) => {
|
||
options = Object.assign({}, options)
|
||
|
||
Object.keys(options).forEach(key => {
|
||
if (apiOptions.params[key] && apiOptions.params[key].deprecated) {
|
||
const aliasKey = apiOptions.params[key].alias
|
||
|
||
octokit.log.warn(new Deprecation(`[@octokit/rest] "${key}" parameter is deprecated for "${methodName}". Use "${aliasKey}" instead`))
|
||
|
||
if (!(aliasKey in options)) {
|
||
options[aliasKey] = options[key]
|
||
}
|
||
delete options[key]
|
||
}
|
||
})
|
||
|
||
return method(options)
|
||
}
|
||
Object.keys(method).forEach(key => {
|
||
patchedMethod[key] = method[key]
|
||
})
|
||
|
||
return patchedMethod
|
||
}
|