github-script

github-script

GitHub Actions 的灵活脚本执行工具

github-script 是一个 GitHub Actions 工具,用于在工作流中执行脚本以操作 GitHub API 和工作流上下文。它集成了 Octokit 客户端、上下文对象和实用工具包,简化了 GitHub 自动化流程。该工具可用于评论问题、添加标签和执行 GraphQL 查询等多种任务。

GitHub Actionsworkflow脚本API自动化Github开源项目

actions/github-script

.github/workflows/integration.yml .github/workflows/ci.yml .github/workflows/licensed.yml

这个 Action 可以让你在工作流程中轻松快速地编写脚本,使用 GitHub API 和工作流运行上下文。

要使用这个 Action,请提供一个名为 script 的输入,其中包含异步函数调用的主体。将提供以下参数:

  • github 一个预先认证的 octokit/rest.js 客户端,带有分页插件
  • context 一个包含工作流运行上下文的对象
  • core @actions/core 包的引用
  • glob @actions/glob 包的引用
  • io @actions/io 包的引用
  • exec @actions/exec 包的引用
  • require 一个围绕普通 Node.js require 的代理包装器,用于启用相对路径(相对于当前工作目录)的 require 和在当前工作目录中安装的 npm 包的 require。如果由于某种原因你需要未包装的 require,有一个逃生舱可用:__original_require__require 的原始值,没有应用我们的包装。

由于 script 只是一个函数体,这些值将已经被定义,所以你不需要导入它们(参见下面的例子)。

有关 API 客户端文档,请参阅 octokit/rest.js

重大变更

V7

此 Action 的版本 7 将运行时更新到 Node 20 - https://docs.github.com/en/actions/creating-actions/metadata-syntax-for-github-actions#runs-for-javascript-actions

所有脚本现在都使用 Node 20 而不是 Node 16 运行,并受到 Node 16 和 20 之间的任何重大变更的影响。

previews 输入现在只适用于 GraphQL API 调用,因为 REST API 预览不再必要 - https://github.blog/changelog/2021-10-14-rest-api-preview-promotions/。

V6

此 Action 的版本 6 将运行时更新到 Node 16 - https://docs.github.com/en/actions/creating-actions/metadata-syntax-for-github-actions#runs-for-javascript-actions

所有脚本现在都使用 Node 16 而不是 Node 12 运行,并受到 Node 12 和 16 之间的任何重大变更的影响。

V5

此 Action 的版本 5 包括 @actions/github@octokit/plugin-rest-endpoint-methods 的版本 5。作为此更新的一部分,通过 github 可用的 Octokit 上下文不再直接具有 REST 方法。这些方法通过 github.rest.* 提供 - https://github.com/octokit/plugin-rest-endpoint-methods.js/releases/tag/v5.0.0

例如,V4 中的 github.issues.createComment 在 V5 中变为 github.rest.issues.createComment

github.requestgithub.paginategithub.graphql 保持不变。

开发

请参阅 development.md

读取步骤结果

脚本的返回值将在步骤的输出中的 "result" 键下。

- uses: actions/github-script@v7 id: set-result with: script: return "Hello!" result-encoding: string - name: Get result run: echo "${{steps.set-result.outputs.result}}"

有关如何更改这些输出的编码方式的详细信息,请参阅"结果编码"

结果编码

默认情况下,函数的 JSON 编码返回值被设置为 github-script 步骤输出中的 "result"。对于某些工作流程,首选字符串编码。可以使用 result-encoding 输入设置此选项:

- uses: actions/github-script@v7 id: my-script with: result-encoding: string script: return "I will be string (not JSON) encoded!"

重试

默认情况下,使用 github 实例发出的请求不会重试。你可以使用 retries 选项配置此行为:

- uses: actions/github-script@v7 id: my-script with: result-encoding: string retries: 3 script: | github.rest.issues.get({ issue_number: context.issue.number, owner: context.repo.owner, repo: context.repo.repo, })

在这个例子中,github.rest.issues.get() 的请求失败将重试最多 3 次。

你还可以通过 retry-exempt-status-codes 选项配置哪些状态码应该免于重试:

- uses: actions/github-script@v7 id: my-script with: result-encoding: string retries: 3 retry-exempt-status-codes: 400,401 script: | github.rest.issues.get({ issue_number: context.issue.number, owner: context.repo.owner, repo: context.repo.repo, })

默认情况下,以下状态码不会重试:400, 401, 403, 404, 422 (来源)

这些重试使用 octokit/plugin-retry.js 插件实现。重试使用指数退避来间隔重试。(来源

示例

请注意,在这个 Action 中 github-token 是可选的,输入存在是为了在需要使用非默认令牌的情况下使用。

默认情况下,github-script 将使用提供给你的工作流程的令牌。

打印 context 的可用属性

- name: View context attributes uses: actions/github-script@v7 with: script: console.log(context)

在 issue 上评论

on: issues: types: [opened] jobs: comment: runs-on: ubuntu-latest steps: - uses: actions/github-script@v7 with: script: | github.rest.issues.createComment({ issue_number: context.issue.number, owner: context.repo.owner, repo: context.repo.repo, body: '👋 感谢你的报告!' })

给 issue 添加标签

on: issues: types: [opened] jobs: apply-label: runs-on: ubuntu-latest steps: - uses: actions/github-script@v7 with: script: | github.rest.issues.addLabels({ issue_number: context.issue.number, owner: context.repo.owner, repo: context.repo.repo, labels: ['分类'] })

欢迎首次贡献者

你可以使用与 GitHub 网页界面相同的 Markdown 语法 来格式化评论中的文本:

on: pull_request_target jobs: welcome: runs-on: ubuntu-latest steps: - uses: actions/github-script@v7 with: script: | // 获取PR创建者创建的所有issue列表 // 参见:https://octokit.github.io/rest.js/#pagination const creator = context.payload.sender.login const opts = github.rest.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 // 创建者已经是贡献者了。 } } await github.rest.issues.createComment({ issue_number: context.issue.number, owner: context.repo.owner, repo: context.repo.repo, body: `**欢迎**,新贡献者! 请确保你已经阅读了我们的[贡献指南](CONTRIBUTING.md),我们期待很快审核你的 Pull request ✨` })

从 URL 下载数据

你可以使用 github 对象访问 Octokit API。例如,github.request

on: pull_request jobs: diff: runs-on: ubuntu-latest steps: - uses: actions/github-script@v7 with: script: | const diff_url = context.payload.pull_request.diff_url const result = await github.request(diff_url) console.log(result)

(请注意,这个特定的例子只适用于公共 URL,其中 diff URL 是公开可访问的。获取私有 URL 的 diff 需要使用 API。)

这将在屏幕上打印完整的 diff 对象;result.data 将包含实际的 diff 文本。

运行自定义 GraphQL 查询

你可以使用 github.graphql 对象对 GitHub API 运行自定义 GraphQL 查询。

jobs: list-issues: runs-on: ubuntu-latest steps: - uses: actions/github-script@v7 with: script: | const query = `query($owner:String!, $name:String!, $label:String!) { repository(owner:$owner, name:$name){ issues(first:100, labels: [$label]) { nodes { id } } } }`; const variables = { owner: context.repo.owner, name: context.repo.repo, label: 'wontfix' } const result = await github.graphql(query, variables) console.log(result)

运行单独的文件

如果你不想内联你想运行的整个脚本,你可以使用存储库中的单独 JavaScript 模块,如下所示:

on: push jobs: echo-input: runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 - uses: actions/github-script@v7 with: script: | const script = require('./path/to/script.js') console.log(script({github, context}))

然后从你的模块导出一个函数:

module.exports = ({github, context}) => { return context.payload.client_payload.value }

请注意,因为你不能 require 像 GitHub 上下文或 Actions Toolkit 库这样的东西,你会想把它们作为参数传递给你的外部函数。

此外,你会想使用 checkout action 来确保你的脚本文件可用。

运行带有异步函数的单独文件

你也可以以这种方式使用异步函数,只要你在内联脚本中 await 它。

在你的工作流程中:

on: push jobs: echo-input: runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 - uses: actions/github-script@v7 env: SHA: '${{env.parentSHA}}' with: script: | const script = require('./path/to/script.js') await script({github, context, core})

然后从你的模块导出一个异步函数:

module.exports = async ({github, context, core}) => { const {SHA} = process.env const commit = await github.rest.repos.getCommit({ owner: context.repo.owner, repo: context.repo.repo, ref: `${SHA}` }) core.exportVariable('author', commit.data.commit.author.email) }

使用 npm 包

像上面导入你自己的文件一样,你也可以使用已安装的模块。请注意,这是通过 require 的包装器实现的,所以如

编辑推荐精选

博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

下拉加载更多