Skip to content

Merge pull request #11 from Matt0550/master #3

Merge pull request #11 from Matt0550/master

Merge pull request #11 from Matt0550/master #3

Workflow file for this run

name: Docker Image CI
on:
push:
branches:
- production
pull_request:
branches:
- production
jobs:
build_and_push:
name: Build and Push Multi-Arch Docker Image
runs-on: ubuntu-latest
permissions:
packages: write
contents: read
attestations: write
id-token: write
env:
REGISTRY: docker.io
IMAGE_NAME: matt0550/tageveryone_telegrambot
steps:
# Step 1: Check out the repository
- name: Check out the repo
uses: actions/checkout@v4
# Step 2: Set up Docker Buildx
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
# Step 3: Log in to Docker Hub
- name: Log in to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
# Step 4: Extract metadata (tags and labels)
- name: Extract metadata for Docker
id: meta
uses: docker/metadata-action@v4
with:
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
# Step 5: Build and push the multi-arch Docker image
- name: Build and Push Multi-Arch Image
id: build-push
uses: docker/build-push-action@v5
with:
context: .
file: ./Dockerfile
push: true
platforms: linux/amd64,linux/arm64,linux/arm/v7,linux/arm/v8
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
# Step 6: Generate artifact attestation
- name: Generate artifact attestation
uses: actions/attest-build-provenance@v2
with:
subject-name: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
subject-digest: ${{ steps.build-push.outputs.digest }}
push-to-registry: true