mirror of
https://github.com/MillironX/setup-nextflow.git
synced 2024-11-22 17:59:54 +00:00
feat: Add throttling to OctkitWrapper
This commit is contained in:
parent
0e885a8e09
commit
803f3d4782
1 changed files with 33 additions and 3 deletions
|
@ -1,17 +1,47 @@
|
||||||
import * as core from "@actions/core"
|
import * as core from "@actions/core"
|
||||||
import * as github from "@actions/github"
|
import * as github from "@actions/github"
|
||||||
import { GitHub } from "@actions/github/lib/utils"
|
import { getOctokitOptions, GitHub } from "@actions/github/lib/utils"
|
||||||
|
import { throttling } from "@octokit/plugin-throttling"
|
||||||
|
|
||||||
import { nextflow_release, NextflowRelease } from "./nextflow-release"
|
import { nextflow_release, NextflowRelease } from "./nextflow-release"
|
||||||
|
|
||||||
const NEXTFLOW_REPO = { owner: "nextflow-io", repo: "nextflow" }
|
const NEXTFLOW_REPO = { owner: "nextflow-io", repo: "nextflow" }
|
||||||
|
|
||||||
export async function setup_octokit(
|
export async function setup_octokit(
|
||||||
github_token: string
|
github_token: string,
|
||||||
|
cooldown = 60,
|
||||||
|
max_retries = 3
|
||||||
): Promise<InstanceType<typeof GitHub>> {
|
): Promise<InstanceType<typeof GitHub>> {
|
||||||
|
const throttledOctokit = GitHub.plugin(throttling)
|
||||||
let octokit = {} as InstanceType<typeof GitHub>
|
let octokit = {} as InstanceType<typeof GitHub>
|
||||||
try {
|
try {
|
||||||
octokit = github.getOctokit(github_token)
|
octokit = new throttledOctokit(
|
||||||
|
getOctokitOptions(github_token, {
|
||||||
|
throttle: {
|
||||||
|
onRateLimit: (retryAfter, options, ok, retryCount) => {
|
||||||
|
ok.log.warn(
|
||||||
|
`Request quota exhausted for request ${options.method} ${options.url}`
|
||||||
|
)
|
||||||
|
|
||||||
|
if (retryCount < max_retries) {
|
||||||
|
ok.log.info(`Retrying after ${retryAfter} seconds!`)
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onSecondaryRateLimit: (retryAfter, options, ok, retryCount) => {
|
||||||
|
ok.log.warn(
|
||||||
|
`SecondaryRateLimit detected for request ${options.method} ${options.url}`
|
||||||
|
)
|
||||||
|
|
||||||
|
if (retryCount < max_retries) {
|
||||||
|
octokit.log.info(`Retrying after ${retryAfter} seconds!`)
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
fallbackSecondaryRateRetryAfter: cooldown
|
||||||
|
}
|
||||||
|
})
|
||||||
|
)
|
||||||
} catch (e: unknown) {
|
} catch (e: unknown) {
|
||||||
if (e instanceof Error) {
|
if (e instanceof Error) {
|
||||||
core.setFailed(
|
core.setFailed(
|
||||||
|
|
Loading…
Reference in a new issue