Skip to content

[builder] CI for nightly build releases #1816

[builder] CI for nightly build releases

[builder] CI for nightly build releases #1816

name: "[builder] CI for nightly build releases"
on:
schedule:
- cron: "0 0 * * *"
workflow_dispatch: ~
env:
REGISTRY: ghcr.io
jobs:
release:
runs-on: ubuntu-latest
permissions:
id-token: write
contents: read
attestations: write
packages: write
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Dockerhub login
uses: docker/login-action@v3
with:
username: ${{ vars.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Login to Container Registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Set date
id: date
uses: docker/metadata-action@v5
with:
images: |
${{ vars.DOCKER_USERNAME }}/ttrss
${{ env.REGISTRY }}/${{ github.repository }}
tags: |
type=raw,value=nightly,enable={{ is_default_branch }}
type=raw,value=nightly-{{ date 'YYYY-MM-DD' }},enable={{ is_default_branch }}
type=raw,value={{ branch }}-nightly,enable=${{ github.ref != format('refs/heads/{0}', 'main') }}
type=raw,value={{ branch }}-nightly-{{date 'YYYY-MM-DD'}},enable=${{ github.ref != format('refs/heads/{0}', 'main') }}
flavor: latest=false
- name: Build dockerfile (with push)
uses: docker/build-push-action@v6
id: push
with:
context: .
push: true
tags: ${{ steps.date.outputs.tags }}
labels: ${{ steps.date.outputs.labels }}
platforms: linux/amd64,linux/arm/v7,linux/arm64
cache-from: type=gha
cache-to: type=gha,mode=max
- name: Attest
uses: actions/attest-build-provenance@v2
with:
subject-name: |
${{ vars.DOCKER_USERNAME }}/ttrss
${{ env.REGISTRY }}/${{ github.repository }}
subject-digest: ${{ steps.push.outputs.digest }}