name: Publish on: push: branches: [main] paths-ignore: - '.github/**' - '.vscode/**' - '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: name: Publish Docker image ${{ matrix.image.name }} needs: - test-php runs-on: ubuntu-latest permissions: contents: read packages: write strategy: matrix: image: - name: app dockerfile: ./.docker/app/Dockerfile repository_dockerhub: supahgreg/tt-rss repository_ghcr: ghcr.io/tt-rss/tt-rss - name: web-nginx dockerfile: ./.docker/web-nginx/Dockerfile repository_dockerhub: supahgreg/tt-rss-web-nginx repository_ghcr: ghcr.io/tt-rss/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 GitHub Container Registry uses: docker/login-action@v3 with: registry: ghcr.io username: ${{ github.actor }} password: ${{ secrets.GITHUB_TOKEN }} - 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_dockerhub }} ${{ matrix.image.repository_ghcr }} 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 image registries 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