Skip to content

chore: add permissions for GitHub #56

chore: add permissions for GitHub

chore: add permissions for GitHub #56

Workflow file for this run

#
# Copyright (C) 2025 Red Hat, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# SPDX-License-Identifier: Apache-2.0
name: build and push builder image
permissions:
contents: read
packages: write
attestations: write
id-token: write
on:
workflow_dispatch:
push:
branches:
- main
jobs:
check-builder-changes:
runs-on: ubuntu-24.04
outputs:
builder_required: ${{ steps.check.outputs.builder_required }}
steps:
- name: Checkout Repository
uses: actions/checkout@v4
with:
fetch-depth: 2 # Ensure we have at least one previous commit for diff check
- name: Check for builder-related changes
id: check
run: |
if git diff --name-only HEAD^ HEAD | grep -E '^(package.json|pnpm-lock.yaml|build/Containerfile.builder|.github/workflows/next-build.yaml)$'; then
echo "builder_required=true" >> $GITHUB_OUTPUT
else
echo "builder_required=false" >> $GITHUB_OUTPUT
fi
builder-image:
needs: check-builder-changes
if: needs.check-builder-changes.outputs.builder_required == 'true'
name: Build and publish builder OCI images only if pnpm-lock.yaml or package.json changes
runs-on: ubuntu-24.04
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Install qemu dependency
run: |
sudo apt-get update
sudo apt-get install -y qemu-user-static
- name: build builder image
id: builder-image
uses: redhat-actions/buildah-build@v2
with:
image: minc-extension-builder
tags: next ${{ github.sha }}
platforms: linux/amd64, linux/arm64
containerfiles: |
build/Containerfile.builder
context: .
oci: true
- name: Log in to ghcr.io
uses: redhat-actions/podman-login@v1
with:
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
registry: ghcr.io
- name: publish builder to ghcr.io
id: push-to-ghcr
uses: redhat-actions/push-to-registry@v2
with:
image: ${{ steps.builder-image.outputs.image }}
tags: ${{ steps.builder-image.outputs.tags }}
registry: ghcr.io/${{ github.repository_owner }}
- name: Generate artifact attestation
uses: actions/attest-build-provenance@v2
with:
subject-name: ghcr.io/${{ github.repository_owner }}/minc-extension-builder
subject-digest: ${{ steps.push-to-ghcr.outputs.digest }}
push-to-registry: true
extension-image:
name: Build and publish extension OCI image
if: always()
runs-on: ubuntu-24.04
needs: builder-image
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Install qemu dependency
run: |
sudo apt-get update
sudo apt-get install -y qemu-user-static
- name: build extension image
id: extension-image
uses: redhat-actions/buildah-build@v2
with:
image: minc-extension
tags: next ${{ github.sha }}
archs: amd64, arm64
containerfiles: |
build/Containerfile
context: .
oci: true
- name: Log in to ghcr.io
uses: redhat-actions/podman-login@v1
with:
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
registry: ghcr.io
- name: publish extension to ghcr.io
id: push-to-ghcr
uses: redhat-actions/push-to-registry@v2
with:
image: ${{ steps.extension-image.outputs.image }}
tags: ${{ steps.extension-image.outputs.tags }}
registry: ghcr.io/${{ github.repository_owner }}
- name: Generate artifact attestation
uses: actions/attest-build-provenance@v2
with:
subject-name: ghcr.io/${{ github.repository_owner }}/minc-extension
subject-digest: ${{ steps.push-to-ghcr.outputs.digest }}
push-to-registry: true