From fbcef63cf36b216fe555cf0b70cea48b9aaac93f Mon Sep 17 00:00:00 2001 From: Dmitri Fedotov Date: Thu, 9 Jan 2025 10:05:55 +0200 Subject: [PATCH] push image to ghcr --- .../workflows/container-registry-ghcr.yaml | 58 +++++++++++++++++++ Makefile.maker.yaml | 8 +++ shell.nix | 1 - 3 files changed, 66 insertions(+), 1 deletion(-) create mode 100644 .github/workflows/container-registry-ghcr.yaml diff --git a/.github/workflows/container-registry-ghcr.yaml b/.github/workflows/container-registry-ghcr.yaml new file mode 100644 index 0000000..cb0cb20 --- /dev/null +++ b/.github/workflows/container-registry-ghcr.yaml @@ -0,0 +1,58 @@ +################################################################################ +# This file is AUTOGENERATED with # +# Edit Makefile.maker.yaml instead. # +################################################################################ + +# Copyright 2024 SAP SE +# SPDX-License-Identifier: Apache-2.0 + +name: Container Registry GHCR +"on": + push: + branches: + - master + workflow_dispatch: {} +permissions: + contents: read + packages: write +jobs: + build-and-push-image: + name: Push container to ghcr.io + runs-on: ubuntu-latest + steps: + - name: Check out code + uses: actions/checkout@v4 + - name: Log in to the Container registry + uses: docker/login-action@v3 + with: + password: ${{ secrets.GITHUB_TOKEN }} + registry: ghcr.io + username: ${{ github.actor }} + - name: Extract metadata (tags, labels) for Docker + id: meta + uses: docker/metadata-action@v5 + with: + images: ghcr.io/${{ github.repository }} + tags: | + # https://github.com/docker/metadata-action#typeedge + type=edge + # https://github.com/docker/metadata-action#latest-tag + type=raw,value=latest,enable={{is_default_branch}} + # https://github.com/docker/metadata-action#typesemver + type=semver,pattern={{raw}} + type=semver,pattern=v{{major}}.{{minor}} + type=semver,pattern=v{{major}} + # https://github.com/docker/metadata-action#typesha + type=sha,format=long + - name: Set up QEMU + uses: docker/setup-qemu-action@v3 + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + - name: Build and push Docker image + uses: docker/build-push-action@v6 + with: + context: . + labels: ${{ steps.meta.outputs.labels }} + platforms: linux/amd64 + push: true + tags: ${{ steps.meta.outputs.tags }} diff --git a/Makefile.maker.yaml b/Makefile.maker.yaml index 14e5613..18401bf 100644 --- a/Makefile.maker.yaml +++ b/Makefile.maker.yaml @@ -28,6 +28,14 @@ githubWorkflow: enabled: true securityChecks: enabled: true + pushContainerToGhcr: + enabled: true + platforms: "linux/amd64" + tagStrategy: + - edge + - latest + - semver + - sha renovate: enabled: true diff --git a/shell.nix b/shell.nix index 6232e6d..d60e417 100644 --- a/shell.nix +++ b/shell.nix @@ -7,7 +7,6 @@ with pkgs; mkShell { nativeBuildInputs = [ - addlicense go-licence-detector go_1_23 golangci-lint