如何在 gitlab ci/cd 管道上进行 docker 构建期间解锁 git-crypt 文件

Dax*_*cor 3 git gitlab docker git-crypt

我有一个包含加密文件的存储库,使用 git-crypt。我已将密钥导出到文件中。现在我使用 gitlab 上的默认 docker 镜像构建模板来构建我的镜像。管道工作得很好。我只是不知道如何在构建过程中“解锁”文件,以便图像具有可供使用的明文文件。管道构建如下所示:

docker-build:
  # Use the official docker image.
  image: docker:latest
  stage: build
  services:
    - docker:dind
  before_script:
    - docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
  # Default branch leaves tag empty (= latest tag)
  # All other branches are tagged with the escaped branch name (commit ref slug)
  script:
    - |
      if [[ "$CI_COMMIT_BRANCH" == "$CI_DEFAULT_BRANCH" ]]; then
        tag=""
        echo "Running on default branch '$CI_DEFAULT_BRANCH': tag = 'latest'"
      else
        tag=":$CI_COMMIT_REF_SLUG"
        echo "Running on branch '$CI_COMMIT_BRANCH': tag = $tag"
      fi
      echo $CI_REGISTRY_IMAGE${tag}
    - docker build --pull -t "$CI_REGISTRY_IMAGE${tag}" .
    - docker push "$CI_REGISTRY_IMAGE${tag}"
  # Run this job in a branch where a Dockerfile exists
  rules:
    - if: $CI_COMMIT_BRANCH
      exists:
        - Dockerfile
Run Code Online (Sandbox Code Playgroud)

我只是不确定解锁发生在何时何地。它发生在 Dockerfile 中还是在此构建过程中?我用谷歌搜索过,并认为这是一个常见问题,但到目前为止还没有。

预先感谢您提供的任何帮助或链接。

布拉德

Dax*_*cor 5

I think the reason no one has answered because it is almost impossible to answer. There are so many permutations to how to use runners. So I will share my solution.

The thing I had to realize is that the OS image that runs the docker image doesn't have git-crypt installed in it. So that was my first task.

- apk add git-crypt

Now that the binary is in the building image I need to somehow get the unlock key into the image. Thankfully, gitlab has project variables that you can use in your builds. However, they do not currently have a way to upload a binary file, which the unlock key is. So what to do. Well you base64 encode it.

base64 binaryfile.key > baseecodeded.key

You can now paste the text with NO cr/lf into the gitlab project variables and make sure you set it to File not text. Then you can decode the variable back to a file and use it in your build.

- cat "$CRYPT_KEY" | base64 -d > key-file
- git-crypt unlock key-file
Run Code Online (Sandbox Code Playgroud)

最终的.gitlab-ci.yml如下。我要做的一件事就是更改它以跳过创建文件..并将解码的变量直接通过管道传输到 git-crypt 解锁。

docker-build:
  # Use the official docker image.
  image: docker:latest
  stage: build
  tags:
    - "docker"
  services:
    - docker:dind
  before_script:
    - docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
    - apk add git-crypt
    - cat "$CRYPT_KEY" | base64 -d > key-file
    - git-crypt unlock key-file
  script:
    - |
      if [[ "$CI_COMMIT_BRANCH" == "$CI_DEFAULT_BRANCH" ]]; then
        tag=""
        echo "Running on default branch '$CI_DEFAULT_BRANCH': tag = 'latest'"
      fi

    - docker build --pull -t "$CI_REGISTRY_IMAGE${tag}" .
    - docker push "$CI_REGISTRY_IMAGE${tag}"

  # Run this job in a branch where a Dockerfile exists
  rules:
    - if: "$CI_COMMIT_BRANCH =~ /^dev/"
      when: never
    - if: "$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH"
      exists:
        - Dockerfile
Run Code Online (Sandbox Code Playgroud)