Skip to content

Commit

Permalink
Bump deprecated GH Action (#39)
Browse files Browse the repository at this point in the history
Signed-off-by: peterdeme <[email protected]>
  • Loading branch information
peterdeme authored Mar 28, 2023
1 parent ef735f1 commit 273b2a2
Show file tree
Hide file tree
Showing 9 changed files with 129 additions and 105 deletions.
36 changes: 10 additions & 26 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,8 @@ jobs:
deployment:
strategy:
matrix:
base_image: ["alpine:3.17", "gcr.io/google.com/cloudsdktool/google-cloud-cli:alpine"]
target: [aws, gcp]
platform: [linux/amd64, linux/arm64]
name: Build the image
runs-on: ubuntu-latest
container: docker
Expand All @@ -23,35 +24,18 @@ jobs:

- name: Set up QEMU
uses: docker/setup-qemu-action@v2
if: matrix.platform == 'linux/arm64'
with:
platforms: linux/arm64

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2

- name: Test if image can be built with buildx
uses: docker/build-push-action@v3
- name: Bake the ${{ matrix.target }} image
uses: docker/bake-action@v2
with:
push: false
build-args: |
BASE_IMAGE=${{ matrix.base_image }}
platforms: linux/amd64,linux/arm64
tags: runner-terraform:latest

# Can't use the output of the previous step because it's
# a multiplatform build, so we need to build it again.
- name: Test if terragrunt & infracost & gcloud are executable (AMD64)
run: |
docker build --build-arg TARGETARCH=amd64 --build-arg BASE_IMAGE=${{ matrix.base_image }} -t runner-terraform-test .
docker run --rm runner-terraform-test sh -c "terragrunt --version && infracost --version && aws --version && python --version"
if [ ${{ matrix.base_image }} = "gcr.io/google.com/cloudsdktool/google-cloud-cli:alpine" ]; then
docker run --rm runner-terraform-test sh -c "gcloud --version"
fi
- name: Test if terragrunt & infracost & gcloud are executable (ARM64)
run: |
docker build --build-arg TARGETARCH=arm64 --build-arg BASE_IMAGE=${{ matrix.base_image }} -t runner-terraform-test .
docker run --rm runner-terraform-test sh -c "terragrunt --version && infracost --version && aws --version && python --version"
if [ ${{ matrix.base_image }} = "gcr.io/google.com/cloudsdktool/google-cloud-cli:alpine" ]; then
docker run --rm runner-terraform-test sh -c "gcloud --version"
fi
targets: ${{ matrix.target }}
load: true
set: |
${{ matrix.target }}.tags=runner-terraform:${{ github.sha }}
${{ matrix.target }}.platform=${{ matrix.platform }}
21 changes: 9 additions & 12 deletions .github/workflows/publish/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@ name: Publish
description: Builds and pushes the Docker image to the public ECR and GitHub registry

inputs:
base_image:
description: Base image to use for the Dockerfile
bake_target:
description: The target of the bake action
required: true
aws_role_to_assume:
description: The AWS role to assume. Used to authenticate with ECR.
Expand All @@ -14,8 +14,8 @@ inputs:
git_tag:
description: Git tag to use for the GitHub Release
required: false
image_tags:
description: The tags of the Docker image to push
bake_set:
description: The `set` argument of the bake action
required: true
publish_release:
description: Whether to publish a GitHub Release
Expand All @@ -39,7 +39,7 @@ runs:
pip3 install awscli
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v1
uses: aws-actions/configure-aws-credentials@v2
with:
aws-region: us-east-1
role-to-assume: ${{ inputs.aws_role_to_assume }}
Expand All @@ -65,14 +65,11 @@ runs:
uses: docker/setup-buildx-action@v2

- name: Build and push the image
uses: docker/build-push-action@v3
uses: docker/bake-action@v2
with:
push: true
context: .
build-args: |
BASE_IMAGE=${{ inputs.base_image }}
platforms: linux/amd64,linux/arm64
tags: ${{ inputs.image_tags }}
targets: ${{ inputs.bake_target }}
set: ${{ inputs.bake_set }}

- name: Create release
uses: ncipollo/release-action@v1
Expand All @@ -82,4 +79,4 @@ runs:
tag: ${{ inputs.git_tag }}
body: ${{ inputs.release_body }}
generateReleaseNotes: true
allowUpdates: true
allowUpdates: true
20 changes: 10 additions & 10 deletions .github/workflows/publish_future.yml
Original file line number Diff line number Diff line change
Expand Up @@ -26,24 +26,24 @@ jobs:
with:
fetch-depth: 0

- name: Build and push future image without gcloud
- name: Build and push future image (w/ aws cli)
uses: ./.github/workflows/publish
with:
base_image: 'alpine:3.17'
bake_target: aws
aws_role_to_assume: ${{ secrets.AWS_ROLE_TO_ASSUME }}
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_release: false
image_tags: |
${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:future
ghcr.io/spacelift-io/runner-terraform:future
bake_set: |
aws.tags=${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:future
aws.tags=ghcr.io/spacelift-io/runner-terraform:future
- name: Build and push future image with gcloud
- name: Build and push future image (w/ gcloud cli)
uses: ./.github/workflows/publish
with:
base_image: 'gcr.io/google.com/cloudsdktool/google-cloud-cli:alpine'
bake_target: gcp
aws_role_to_assume: ${{ secrets.AWS_ROLE_TO_ASSUME }}
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_release: false
image_tags: |
${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-future
ghcr.io/spacelift-io/runner-terraform:gcp-future
bake_set: |
gcp.tags=${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-future
gcp.tags=ghcr.io/spacelift-io/runner-terraform:gcp-future
54 changes: 33 additions & 21 deletions .github/workflows/publish_scheduled.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ name: Scheduled publish
on:
schedule:
- cron: '20 8 * * 1'
workflow_dispatch:

jobs:
deployment:
Expand Down Expand Up @@ -34,47 +35,58 @@ jobs:
- name: Set nicely formatted current date as env variable
run: echo "TODAY_FORMATTED=$(date +'%Y-%m-%d')" >> $GITHUB_ENV

- name: Build and push weekly image without gcloud
- name: Create weekly tag
id: tag
env:
TAG: ${{ steps.latest-tag.outputs.tag }}_${{ env.TODAY }}
run: |
git config --global user.email "github-actions[bot]@users.noreply.github.com"
git config --global user.name "github-actions[bot]"
git tag -a $TAG -m "Weekly rebuild of ${{ steps.latest-tag.outputs.tag }}"
git push origin $TAG
echo "TAG=$TAG" >> $GITHUB_OUTPUT
- name: Build and push weekly image (w/ aws cli)
uses: ./.github/workflows/publish
with:
base_image: 'alpine:3.17'
bake_target: aws
aws_role_to_assume: ${{ secrets.AWS_ROLE_TO_ASSUME }}
github_token: ${{ secrets.GITHUB_TOKEN }}
git_tag: ${{ steps.latest-tag.outputs.tag }}
git_tag: ${{ steps.tag.outputs.TAG }}
publish_release: true
release_title: ${{ steps.latest-tag.outputs.tag }} - weekly release (${{ env.TODAY_FORMATTED }})
release_body: |
## Weekly rebuild
This is a weekly rebuild of the latest image (`${{ steps.latest-tag.outputs.tag }}`).
The image is rebuilt to ensure that it is up to date with the latest security patches.
## Updated images
### Without gcloud CLI
### Image with aws cli
- `${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:latest`
- `${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:${{ steps.latest-tag.outputs.tag }}_${{ env.TODAY }}`
- `${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:${{ steps.tag.outputs.TAG }}`
- `ghcr.io/spacelift-io/runner-terraform:latest`
- `ghcr.io/spacelift-io/runner-terraform:${{ steps.latest-tag.outputs.tag }}_${{ env.TODAY }}`
- `ghcr.io/spacelift-io/runner-terraform:${{ steps.tag.outputs.TAG }}`
### With gcloud CLI
### Image with gcloud cli
- `${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-latest`
- `${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-${{ steps.latest-tag.outputs.tag }}_${{ env.TODAY }}`
- `${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-${{ steps.tag.outputs.TAG }}`
- `ghcr.io/spacelift-io/runner-terraform:gcp-latest`
- `ghcr.io/spacelift-io/runner-terraform:gcp-${{ steps.latest-tag.outputs.tag }}_${{ env.TODAY }}`
image_tags: |
${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:latest
${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:${{ steps.latest-tag.outputs.tag }}_${{ env.TODAY }}
ghcr.io/spacelift-io/runner-terraform:latest
ghcr.io/spacelift-io/runner-terraform:${{ steps.latest-tag.outputs.tag }}_${{ env.TODAY }}
- `ghcr.io/spacelift-io/runner-terraform:gcp-${{ steps.tag.outputs.TAG }}`
bake_set: |
aws.tags=${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:latest
aws.tags=${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:${{ steps.tag.outputs.TAG }}
aws.tags=ghcr.io/spacelift-io/runner-terraform:latest
aws.tags=ghcr.io/spacelift-io/runner-terraform:${{ steps.tag.outputs.TAG }}
- name: Build and push weekly image with gcloud
- name: Build and push weekly image (w/ gcloud cli)
uses: ./.github/workflows/publish
with:
base_image: 'gcr.io/google.com/cloudsdktool/google-cloud-cli:alpine'
bake_target: gcp
aws_role_to_assume: ${{ secrets.AWS_ROLE_TO_ASSUME }}
github_token: ${{ secrets.GITHUB_TOKEN }}
git_tag: ${{ steps.latest-tag.outputs.tag }}
publish_release: false
image_tags: |
${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-latest
${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-${{ steps.latest-tag.outputs.tag }}_${{ env.TODAY }}
ghcr.io/spacelift-io/runner-terraform:gcp-latest
ghcr.io/spacelift-io/runner-terraform:gcp-${{ steps.latest-tag.outputs.tag }}_${{ env.TODAY }}
bake_set: |
gcp.tags=${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-latest
gcp.tags=${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-${{ steps.tag.outputs.TAG }}
gcp.tags=ghcr.io/spacelift-io/runner-terraform:gcp-latest
gcp.tags=ghcr.io/spacelift-io/runner-terraform:gcp-${{ steps.tag.outputs.TAG }}
28 changes: 14 additions & 14 deletions .github/workflows/publish_tagged.yml
Original file line number Diff line number Diff line change
Expand Up @@ -28,31 +28,31 @@ jobs:
with:
fetch-depth: 0

- name: Build and push latest image without gcloud
- name: Build and push latest image (w/ aws cli)
uses: ./.github/workflows/publish
with:
base_image: 'alpine:3.17'
bake_target: aws
aws_role_to_assume: ${{ secrets.AWS_ROLE_TO_ASSUME }}
github_token: ${{ secrets.GITHUB_TOKEN }}
git_tag: ${{ steps.latest-tag.outputs.tag }}
publish_release: true
release_title: ${{ steps.latest-tag.outputs.tag }}
image_tags: |
${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:latest
${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:${{ steps.latest-tag.outputs.tag }}
ghcr.io/spacelift-io/runner-terraform:latest
ghcr.io/spacelift-io/runner-terraform:${{ steps.latest-tag.outputs.tag }}
bake_set: |
aws.tags=${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:latest
aws.tags=${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:${{ steps.latest-tag.outputs.tag }}
aws.tags=ghcr.io/spacelift-io/runner-terraform:latest
aws.tags=ghcr.io/spacelift-io/runner-terraform:${{ steps.latest-tag.outputs.tag }}
- name: Build and push latest image with gcloud
- name: Build and push latest image (w/ gcloud cli)
uses: ./.github/workflows/publish
with:
base_image: 'gcr.io/google.com/cloudsdktool/google-cloud-cli:alpine'
bake_target: gcp
aws_role_to_assume: ${{ secrets.AWS_ROLE_TO_ASSUME }}
github_token: ${{ secrets.GITHUB_TOKEN }}
git_tag: ${{ steps.latest-tag.outputs.tag }}
publish_release: false
image_tags: |
${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-latest
${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-${{ steps.latest-tag.outputs.tag }}
ghcr.io/spacelift-io/runner-terraform:gcp-latest
ghcr.io/spacelift-io/runner-terraform:gcp-${{ steps.latest-tag.outputs.tag }}
bake_set: |
gcp.tags=${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-latest
gcp.tags=${{ secrets.PUBLIC_RUNNER_TERRAFORM_ECR_REPOSITORY_URL }}:gcp-${{ steps.latest-tag.outputs.tag }}
gcp.tags=ghcr.io/spacelift-io/runner-terraform:gcp-latest
gcp.tags=ghcr.io/spacelift-io/runner-terraform:gcp-${{ steps.latest-tag.outputs.tag }}
29 changes: 17 additions & 12 deletions .github/workflows/trivy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,31 +16,36 @@ jobs:
build:
strategy:
matrix:
arch: [amd64, arm64]
base_image: ["alpine:3.17", "gcr.io/google.com/cloudsdktool/google-cloud-cli:alpine"]
target: [aws, gcp]
platform: [linux/amd64, linux/arm64]
name: Analyze
runs-on: ubuntu-latest
env:
IMAGE_TAG: spacelift:${{ github.sha }}-${{ matrix.arch }}
IMAGE_TAG: spacelift-${{ matrix.target }}:${{ github.sha }}

steps:
- name: Checkout code
uses: actions/checkout@main

- name: Set up QEMU
if: matrix.arch == 'arm64'
if: matrix.platform == 'linux/arm64'
uses: docker/setup-qemu-action@v2
with:
platforms: linux/arm64

- name: Build an image from Dockerfile (${{ matrix.base_image }} ${{ matrix.arch }} image)
env:
PLATFORM: linux/${{ matrix.arch }}
DOCKERFILE: ${{ matrix.base_image }}
run: |
docker build --platform $PLATFORM --pull --build-arg TARGETARCH=${{ matrix.arch }} --build-arg BASE_IMAGE=${{ matrix.base_image }} -t $IMAGE_TAG .
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2

- name: Run Trivy vulnerability scanner (${{ matrix.base_image }} ${{ matrix.arch }} image)
- name: Bake the image
uses: docker/bake-action@v2
with:
targets: ${{ matrix.target }}
load: true
set: |
${{ matrix.target }}.tags=${{ env.IMAGE_TAG }}
${{ matrix.target }}.platform=${{ matrix.platform }}
- name: Run Trivy vulnerability scanner
uses: aquasecurity/trivy-action@master
with:
image-ref: ${{ env.IMAGE_TAG }}
Expand All @@ -49,7 +54,7 @@ jobs:
severity: "CRITICAL,HIGH"
timeout: "10m"

- name: Upload Trivy scan results to GitHub Security tab (${{ matrix.base_image }} ${{ matrix.arch }} image)
- name: Upload Trivy scan results to GitHub Security tab
uses: github/codeql-action/upload-sarif@v2
with:
sarif_file: "trivy-results.sarif"
29 changes: 22 additions & 7 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
ARG BASE_IMAGE=alpine:3.17

FROM ${BASE_IMAGE}
FROM ${BASE_IMAGE} AS base

ARG TARGETARCH

Expand All @@ -16,12 +16,6 @@ RUN apk -U upgrade && apk add --no-cache \
tzdata

RUN [ -e /usr/bin/python ] || ln -s python3 /usr/bin/python
RUN if [ -e /google-cloud-sdk/bin/gcloud ]; then \
gcloud components install gke-gcloud-auth-plugin; \
fi

COPY --from=ghcr.io/spacelift-io/aws-cli-alpine /usr/local/aws-cli/ /usr/local/aws-cli/
COPY --from=ghcr.io/spacelift-io/aws-cli-alpine /aws-cli-bin/ /usr/local/bin/

# Download infracost
ADD "https://github.com/infracost/infracost/releases/latest/download/infracost-linux-${TARGETARCH}.tar.gz" /tmp/infracost.tar.gz
Expand All @@ -37,4 +31,25 @@ RUN chmod 755 /bin/terragrunt
RUN echo "hosts: files dns" > /etc/nsswitch.conf \
&& adduser --disabled-password --uid=1983 spacelift

FROM base AS aws

COPY --from=ghcr.io/spacelift-io/aws-cli-alpine /usr/local/aws-cli/ /usr/local/aws-cli/
COPY --from=ghcr.io/spacelift-io/aws-cli-alpine /aws-cli-bin/ /usr/local/bin/

RUN aws --version && \
terragrunt --version && \
python --version && \
infracost --version

USER spacelift

FROM base AS gcp

RUN gcloud components install gke-gcloud-auth-plugin

RUN gcloud --version && \
terragrunt --version && \
python --version && \
infracost --version

USER spacelift
Loading

0 comments on commit 273b2a2

Please sign in to comment.