无论如何,在github动作工作流上是否有签署Maven软件包的签名?

时间:2019-10-03 07:47:47

标签: maven github continuous-integration github-actions maven-gpg-plugin

我正在运行GitHub Action工作流,尝试运行maven安装时出现失败错误。 在安装Maven软件包之前,需要我签名。 这是我的工作流程yml文件:

name: Github Action

on:
  push:
    branches:
      - master
      - release/*
  schedule:
    - cron: '0 0 * * 0'
jobs:
  build:
    name: Main
    runs-on: ${{ matrix.operating-system }}
    strategy:
        matrix:
          java-version: [1.8]
          operating-system: [ubuntu-latest]
    steps:
      - name: Prepare
        uses: actions/checkout@v1
      - name: Set Up Java Development Kit
        uses: actions/setup-java@v1
        with:
          java-version: ${{ matrix.java-version }}
      - name: Maven build clean, build, test and install
        run: |
          mvn clean
          mvn install
          mvn package --file pom.xml

这就是我得到的:

gpg: directory '/${HOME}/.gnupg' created
gpg: keybox '/${HOME}/.gnupg/pubring.kbx' created
gpg: no default secret key: No secret key
gpg: signing failed: No secret key
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  22.278 s
[INFO] Finished at: 2019-10-03T06:56:51Z
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-gpg-plugin:1.6:sign (sign-artifacts) on project core: Exit code: 2 -> [Help 1]

有什么方法可以使用github动作工作流对我们的软件包进行签名吗?

2 个答案:

答案 0 :(得分:2)

您将获得的最常见答案是使用samuelmeuli/action-maven-publish。这个插件有两个问题-将密钥文件写入主目录中的磁盘,并且不允许您最大程度地自定义Apache Maven命令行。

相反,您可以按照How to Sign and Release to The Central Repository with GitHub Actions中的说明,使用GitHub操作秘密和gpg命令行安装gpg秘密密钥。

答案 1 :(得分:1)

另一种方法是使用设计用于 CI/CD 系统的 Sign Maven Plugin

所有需要的配置都可以通过环境变量来完成。

Sign Maven Plugin 不使用 gpg,因此您不需要任何 gpg 初始化步骤。

你应该定义秘密

  • SIGN_KEY - 装甲 GPG/PGP 密钥 - 这是必需的
  • SIGN_KEY_ID - 十六进制格式的密钥 ID - 可选,将使用 SIGN_KEY 中的第一个密钥
  • SIGN_KEY_PASS - 用于解密私有签名密钥的密码 - 如果密钥未加密,则可选

在 GitHub Action 工作流程中,您传递机密以进行构建:

 - name: Maven build clean, build, test and install
   run: mvn ...
   env:
      SIGN_KEY: ${{ secrets.SIGN_KEY }}
      SIGN_KEY_ID: ${{ secrets. SIGN_KEY_ID }}
      SIGN_KEY_PASS: ${{ secrets. SIGN_KEY_PASS }}