将 webhook 与 Amazon CodeBuild - Amazon CodeBuild
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅 中国的 Amazon Web Services 服务入门 (PDF)

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

将 webhook 与 Amazon CodeBuild

Amazon CodeBuild 支持 webhook 与 GitHub、 GitHub 企业服务器和 Bitbucket 集成。

将 Webhook 与 Amazon CodeBuild结合使用的最佳实操

对于使用公共存储库来设置 Webhook 的项目,我们建议使用以下选项:

设置 ACTOR_ACCOUNT_ID 筛选条件

ACTOR_ACCOUNT_ID 筛选条件添加到项目的 Webhook 筛选条件组可指定哪些用户可以触发构建。发送到的每个 webhook 事件都 CodeBuild 附带指定参与者标识符的发送者信息。 CodeBuild 将根据过滤器中提供的正则表达式模式过滤 webhook。您可以使用此筛选器指定允许触发构建的特定用户。有关更多信息,请参阅 GitHub webhook 事件Bitbucket Webhook 事件

设置 FILE_PATH 筛选条件

FILE_PATH 筛选条件添加到项目的 Webhook 筛选条件组中,以包含或排除更改后可能触发构建的文件。例如,您可以使用正则表达式模式(例如 ^buildspec.yml$)和 excludeMatchedPattern 属性来拒绝对 buildspec.yml 文件进行更改的构建请求。有关更多信息,请参阅 GitHub webhook 事件Bitbucket Webhook 事件

缩小构建 IAM 角色的权限

由 Webhook 触发的构建使用项目中指定的 IAM 服务角色。我们建议将服务角色中的权限设置为运行构建所需的最低权限集。例如,在测试和部署场景中,创建一个用于测试的项目和另一个用于部署的项目。测试项目接受存储库中的 Webhook 构建,但不提供对您的资源的写入权限。部署项目提供对您的资源的写入权限,并且 Webhook 筛选条件配置为仅允许受信任的用户触发构建。

使用内联或 Amazon S3 存储的 buildspec

如果您自行在项目内定义内联 buildspec,或者将 buildspec 文件存储在 Amazon S3 存储桶中,则该 buildspec 文件仅对项目所有者可见。这样可以防止拉取请求对 buildspec 文件进行代码更改并触发不必要的构建。有关更多信息,请参阅 CodeBuildAPI 参考中的 ProjectSource.buildspec