94 lines
2.3 KiB
YAML
94 lines
2.3 KiB
YAML
name: Publish
|
|
|
|
on:
|
|
push:
|
|
branches: [main]
|
|
paths-ignore:
|
|
- '.**'
|
|
- 'tests/**'
|
|
- '*.*-dist'
|
|
- '*.js'
|
|
- '*.json'
|
|
- '*.lock'
|
|
- '*.md'
|
|
- '*.neon'
|
|
- '*.xml'
|
|
# Allow manual triggering
|
|
workflow_dispatch:
|
|
|
|
|
|
permissions:
|
|
contents: read
|
|
|
|
|
|
jobs:
|
|
test-php:
|
|
uses: ./.github/workflows/php-code-quality.yml
|
|
|
|
publish-dockerhub:
|
|
name: Publish ${{ matrix.image.name }} to Docker Hub
|
|
needs:
|
|
- test-php
|
|
runs-on: ubuntu-latest
|
|
strategy:
|
|
matrix:
|
|
image:
|
|
- name: app
|
|
dockerfile: ./.docker/app/Dockerfile
|
|
repository: supahgreg/tt-rss
|
|
- name: web-nginx
|
|
dockerfile: ./.docker/web-nginx/Dockerfile
|
|
repository: supahgreg/tt-rss-web-nginx
|
|
|
|
steps:
|
|
- name: Check out code
|
|
uses: actions/checkout@v5
|
|
|
|
- name: Get commit timestamp
|
|
run: echo "COMMIT_TIMESTAMP=$(git show -s --format=%ci HEAD)" >> $GITHUB_ENV
|
|
|
|
- name: Get commit short SHA
|
|
run: echo "COMMIT_SHORT_SHA=$(git rev-parse --short HEAD)" >> $GITHUB_ENV
|
|
|
|
- name: Log in to Docker Hub
|
|
uses: docker/login-action@v3
|
|
with:
|
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
|
|
- name: Extract metadata
|
|
id: meta
|
|
uses: docker/metadata-action@v5
|
|
with:
|
|
images: ${{ matrix.image.repository }}
|
|
tags: |
|
|
# update 'latest'
|
|
type=raw,value=latest
|
|
# short SHA with a 'sha-' prefix (e.g. sha-abc123)
|
|
type=sha
|
|
|
|
- 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 to Docker Hub
|
|
id: push
|
|
uses: docker/build-push-action@v6
|
|
with:
|
|
context: .
|
|
file: ${{ matrix.image.dockerfile }}
|
|
platforms: linux/arm64,linux/amd64
|
|
# TODO: clean up build arg and environment variable naming.
|
|
build-args: |
|
|
CI_COMMIT_BRANCH=${{ github.ref_name }}
|
|
CI_COMMIT_SHA=${{ github.sha }}
|
|
CI_COMMIT_SHORT_SHA=${{ env.COMMIT_SHORT_SHA }}
|
|
CI_COMMIT_TIMESTAMP=${{ env.COMMIT_TIMESTAMP }}
|
|
tags: ${{ steps.meta.outputs.tags }}
|
|
labels: ${{ steps.meta.outputs.labels }}
|
|
provenance: true
|
|
sbom: true
|
|
push: true
|