概述
OpenID Connect (OIDC) 允许您的 GitHub Actions 工作流对 JFrog 进行身份验证,以便下载和发布工件,而无需在 GitHub 中存储 JFrog 密码、令牌或 API 密钥。
本指南概述了如何配置 JFrog 以信任 GitHub 的 OIDC 作为联合身份,并演示了如何在 GitHub Actions 工作流中使用此配置。
有关示例 GitHub Actions 工作流,请参阅 JFrog 文档中的 示例 GitHub Actions 集成。
有关使用 JFrog CLI 的示例 GitHub Actions 工作流,请参阅 build-publish.yml
(位于 jfrog-github-oidc-example
存储库中)。
先决条件
-
要了解 GitHub 如何使用 OpenID Connect (OIDC) 的基本概念及其架构和优势,请参阅“关于使用 OpenID Connect 加强安全性”。
-
在继续之前,您必须规划您的安全策略,以确保仅以可预测的方式分配访问令牌。要控制您的云提供商如何发出访问令牌,您**必须**定义至少一个条件,以便不受信任的存储库无法请求您云资源的访问令牌。有关更多信息,请参阅“关于使用 OpenID Connect 加强安全性”。
-
为了安全起见,您需要在配置身份映射时在JFrog中设置Claims JSON。更多信息,请参阅“AUTOTITLE”和“关于使用OpenID Connect增强安全性”。
例如,您可以将
iss
设置为https://token.actions.githubusercontent.com
,并将repository
设置为类似“octo-org/octo-repo”的内容。这将确保只有来自指定存储库的Actions工作流才能访问您的JFrog平台。以下是配置身份映射时Claims JSON的示例。JSON { "iss": "https://token.actions.githubusercontent.com", "repository": "octo-org/octo-repo" }
{ "iss": "https://token.actions.githubusercontent.com", "repository": "octo-org/octo-repo" }
将身份提供商添加到JFrog
要在JFrog中使用OIDC,请在GitHub Actions和JFrog平台之间建立信任关系。有关此过程的更多信息,请参阅JFrog文档中的OpenID Connect集成。
- 登录您的JFrog平台。
- 配置JFrog和您的GitHub Actions工作流之间的信任关系。
- 配置身份映射。
更新您的GitHub Actions工作流
在您建立GitHub Actions和JFrog平台之间的信任关系后,您可以更新您的GitHub Actions工作流文件。
在您的GitHub Actions工作流文件中,确保您使用的是在JFrog平台中配置的提供程序名称和受众。
以下示例使用占位符YOUR_PROVIDER_NAME
。
- name: Fetch Access Token from Artifactory
id: fetch_access_token
env:
ID_TOKEN: $
run: |
ACCESS_TOKEN=$(curl \
-X POST \
-H "Content-type: application/json" \
https://example.jfrog.io/access/api/v1/oidc/token \
-d \
"{\"grant_type\": \"urn:ietf:params:oauth:grant-type:token-exchange\", \"subject_token_type\":\"urn:ietf:params:oauth:token-type:id_token\", \"subject_token\": \"$ID_TOKEN\", \"provider_name\": \"YOUR_PROVIDER_NAME\"}" | jq .access_token | tr -d '"')
echo ACCESS_TOKEN=$ACCESS_TOKEN >> $GITHUB_OUTPUT
以下示例显示了使用cURL的GitHub Actions工作流文件的一部分。
- name: Get ID Token (cURL method)
id: idtoken
run: |
ID_TOKEN=$(curl -sLS -H "User-Agent: actions/oidc-client" -H "Authorization: Bearer $ACTIONS_ID_TOKEN_REQUEST_TOKEN" \
"${ACTIONS_ID_TOKEN_REQUEST_URL}&audience=jfrog-github" | jq .value | tr -d '"')
echo "ID_TOKEN=${ID_TOKEN}" >> $GITHUB_OUTPUT
或者,您可以使用env
上下文将受众设置为环境变量。有关env
上下文的更多信息,请参阅“访问有关工作流运行的上下文信息”。
注意
当在工作流或OIDC策略中使用环境时,我们建议向环境添加保护规则以增强安全性。例如,您可以配置环境上的部署规则,以限制哪些分支和标签可以部署到环境或访问环境机密。更多信息,请参阅“管理用于部署的环境”。
jobs:
build:
runs-on: ubuntu-latest
env:
OIDC_AUDIENCE: 'YOUR_AUDIENCE'
然后,在您的工作流文件中,检索存储在env
上下文中的变量的值。以下示例使用env
上下文检索OIDC受众。
- name: Get ID Token (using env context)
uses: actions/github-script@v6
id: idtoken
with:
script: |
const coredemo = require('@actions/core');
let id_token = await coredemo.getIDToken(process.env.OIDC_AUDIENCE);
coredemo.setOutput('id_token', id_token);