限制组织政策的构建

借助 Cloud Build,您可以定义组织政策 (constraints/cloudbuild.allowedIntegrations),以控制哪些外部服务可以调用构建触发器。例如,如果您的触发器监听 GitHub 代码库更改,但 GitHub 在组织政策中遭到拒绝,则触发器不会运行。您可以为您的组织或项目指定任意数量的允许或拒绝的值。

本页面介绍如何使用 Google Cloud 控制台和 gcloud 命令行工具为集成设置组织政策 (constraints/cloudbuild.allowedIntegrations)。

准备工作

  • 启用 Cloud Build and Organization Policy API。

    启用 API

  • 如需使用本指南中的命令行示例,请安装并配置 Google Cloud SDK

  • 如需设置、更改或删除组织政策,您必须拥有 Organization Policy Administrator (roles/orgpolicy.policyAdmin) 角色。如需了解如何向您的帐号添加角色,请参阅添加组织政策管理员

为允许的集成设置组织政策

本部分介绍如何设置组织政策 (constraints/cloudbuild.allowedIntegrations),以便为允许的集成定义 build。

控制台

  1. 在 Google Cloud 控制台中打开组织政策页面。

    打开“组织政策”页面

  2. 点击包含允许的集成 (Cloud Build) 政策的行。

    您会看到政策详情页面。

  3. 如需修改政策,请点击修改

    您将看到修改政策页面。

  4. 应用对象部分中,选择自定义以设置政策的定义。

  5. 强制执行政策部分,选择替换以定义您自己的政策规则。否则,请选择与父级合并,以确保将父级资源的规则应用到您的设置。如需了解详情,请参阅了解层次结构评估

  6. 规则部分中,点击添加规则为您的政策添加新规则。

  7. 政策值下,选择全部允许以允许来自所有服务的构建,选择全部拒绝以拒绝来自所有服务的构建,或者选择自定义以允许或拒绝来自特定服务的构建。

    如果您选择自定义作为值,请完成以下步骤:

    1. 政策类型部分中,选择允许拒绝

    2. 自定义值部分中,输入您要允许或拒绝其构建作业的实例或代码库的主机网址。例如,如需允许或拒绝来自 GitHub 的构建,请输入 github.comwww.github.com 格式的网址。

      您也可以输入多个网址,网址之间用空格分隔。例如,github.com ghe.staging-test.com

      根据具体事件,您指定的主机网址是以下之一:

      • RepoSync 事件:主机为 source.developers.google.com
      • GitHub 应用事件:主机派生自 JSON 载荷中的 repository.html_url 字段,该字段始终为 github.com
      • GitHub Enterprise 事件:主机派生自 JSON 载荷中的 repository.html_url 字段。例如 ghe.staging-test.com
      • Pub/Sub 事件:主机派生自触发器中指定的来源。如果触发器中未指定来源,则不会进行组织政策检查。
      • 网络钩子事件:主机派生自触发器中指定的来源。如果触发器中未指定来源,则会进行组织政策检查。
  8. 要保存规则,请点击完成

  9. 如需添加其他规则,请点击添加规则。否则,如需保存政策,请点击保存

gcloud

  1. 打开一个终端窗口。

  2. 如果要允许或拒绝来自所有服务的构建,请创建一个包含以下内容的 YAML 文件:

    name: projects/PROJECT_NUMBER/policies/cloudbuild.allowedIntegrations
    spec:
      inheritFromParent: INHERIT
      rules:
        - ALLOW_OR_DENY: true
    

    其中:

    • PROJECT_NUMBER 是您的项目编号。
    • 如果您希望从父资源继承政策规则,则 INHERITtrue。否则,为 false
    • 如果要允许通过所有主机网址进行构建,ALLOW_OR_DENYallowAll。否则,为 denyAll
    • HOST_URL 是您的主机网址。例如 github.com。您还可以在下面几行代码中指定其他网址。

    如果要允许或拒绝来自所选服务的构建,请创建一个包含以下内容的 YAML 文件:

    name: projects/PROJECT_NUMBER/policies/cloudbuild.allowedIntegrations
    spec:
      inheritFromParent: INHERIT
      rules:
        - values:
            ALLOW_OR_DENY:
              HOST_URL
              ...
    

    其中:

    • PROJECT_NUMBER 是您的项目编号。
    • 如果您希望从父资源继承政策规则,则 INHERITtrue。否则,为 false
    • 如果要指定允许从中构建的主机网址,则 ALLOW_OR_DENYallowedValues。否则,为 deniedValues
    • HOST_URL 是您的主机网址。例如 github.com。您还可以在下面几行代码中指定其他网址。
  3. 通过运行以下命令设置组织政策,其中 FILE_NAME 是 YAML 文件的名称:

     gcloud org-policies set-policy FILE_NAME
    
  4. 如需确认您的政策是否已设置,请运行以下命令,其中 PROJECT_ID 是您的项目 ID:

     gcloud org-policies describe cloudbuild.allowedIntegrations --effective --project PROJECT_ID
    

测试允许的集成的组织政策

本部分介绍如何使用构建触发器测试组织政策 (constraints/cloudbuild.allowedIntegrations)。

  1. 创建构建触发器(如果您尚未创建)。

  2. 将更改推送到来源。

  3. 如果您的政策设置为允许来自源代码的构建,您将能够在构建记录页面上查看来自触发器的构建执行。否则,您的构建将不会执行。如需查看受政策定义限制的构建的历史记录,请参阅 Logs Explorer 页面,了解 JSON 载荷原因和拒绝原因。

后续步骤