name: Build Docker Image for Raspberry Pi on: push: branches: - main - master - develop tags: - 'v*' pull_request: branches: - main - master env: REGISTRY: 192.168.1.37:30008 IMAGE_NAME: ${{ github.repository }} jobs: build-and-push: runs-on: ubuntu-latest permissions: contents: read packages: write steps: - name: Checkout code uses: actions/checkout@v3 - name: Set up QEMU uses: docker/setup-qemu-action@v2 with: platforms: linux/arm/v7,linux/arm64 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 with: driver-opts: | image=moby/buildkit:latest network=host config-inline: | [registry."192.168.1.37:30008"] http = true insecure = true - name: Docker meta id: meta uses: docker/metadata-action@v4 with: images: | ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} tags: | type=ref,event=branch type=ref,event=pr type=semver,pattern={{version}} type=semver,pattern={{major}}.{{minor}} type=raw,value=latest,enable={{is_default_branch}} - name: Login to Gitea Container Registry if: github.event_name != 'pull_request' run: | echo "Configurazione autenticazione registry..." mkdir -p ~/.docker AUTH=$(echo -n "${{ github.actor }}:${{ secrets.REGISTRY_TOKEN }}" | base64) cat > ~/.docker/config.json << EOF { "auths": { "192.168.1.37:30008": { "auth": "$AUTH" } } } EOF - name: Build and push Docker image id: docker_build uses: docker/build-push-action@v6 with: context: . file: ./Dockerfile.multiarch platforms: linux/arm/v7,linux/arm64 push: ${{ github.event_name != 'pull_request' }} tags: ${{ steps.meta.outputs.tags }} labels: ${{ steps.meta.outputs.labels }} build-args: | BUILD_DATE=${{ github.event.repository.updated_at }} VERSION=${{ steps.meta.outputs.version }} VCS_REF=${{ github.sha }} cache-from: type=gha cache-to: type=gha,mode=max provenance: false outputs: type=registry,registry.insecure=true - name: Image digest run: | echo "Tags pubblicati:" echo "${{ steps.meta.outputs.tags }}" echo "Digest: ${{ steps.docker_build.outputs.digest }}"