mirror of
https://github.com/actions/github-script.git
synced 2025-12-08 08:06:23 +00:00
d6f96b001567d23db486e623261884f4b11348e7
script
This action makes it easy to quickly write a script in your workflow that uses the GitHub API and the workflow execution context.
In order to use this action, a script input is provided. The value of that input should be the body of an asynchronous function call. Two arguments will be provided:
githubA pre-authenticated octokit/rest.js clientcontextAn object containing the context of the workflow run
Since the script is just a function body, these values will already be defined, so you don't have to (see examples below).
See octokit/rest.js for the API client documentation.
Examples
Comment on an issue
on:
issue: {type: opened}
jobs:
comment:
runs-on: ubuntu-latest
steps:
- uses: actions/script@1.0.0
with:
github-token: ${{github.token}}
script: |
await github.issues.createComment({...context.issue, body: '👋 Thanks for reporting!'})
Apply a label to an issue
on:
issue: {type: opened}
jobs:
apply-label:
runs-on: ubuntu-latest
steps:
- uses: actions/script@1.0.0
with:
github-token: ${{github.token}}
script: |
await github.issues.addLabels({...context.issue, labels: ['Triage']})
Welcome a first-time contributor
on: pull_request
jobs:
welcome:
runs-on: ubuntu-latest
steps:
- uses: actions/script@1.0.0
with:
github-token: ${{github.token}}
script: |
// Get a list of all issues created by the PR opener
// See: https://octokit.github.io/rest.js/#pagination
const creator = context.payload.sender.login
const opts = github.issues.listForRepo.endpoint.merge({
...context.issue,
creator,
state: 'all'
})
const issues = await github.paginate(opts)
for (const issue of issues) {
if (issue.number === context.issue.number) {
continue
}
if (issue.pull_request) {
return // Creator is already a contributor.
}
}
await github.issues.createComment({...context.issue, body: 'Welcome, new contributor!'})
Description
Languages
TypeScript
100%