feat(route): csair #2
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: '[docker] CI for releases' | |
on: | |
push: | |
branches: | |
- master | |
paths: | |
- '.github/workflows/docker-release.yml' | |
- 'lib/**' | |
- '!**/maintainer.js' | |
- '!**/radar.js' | |
- '!**/radar-rules.js' | |
- 'Dockerfile' | |
- 'package.json' | |
- 'yarn.lock' | |
workflow_dispatch: ~ | |
jobs: | |
check-env: | |
permissions: | |
contents: none | |
runs-on: ubuntu-latest | |
outputs: | |
check-docker: ${{ steps.check-docker.outputs.defined }} | |
steps: | |
- id: check-docker | |
env: | |
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} | |
if: ${{ env.DOCKER_USERNAME != '' }} | |
run: echo "::set-output name=defined::true" | |
release: | |
runs-on: ubuntu-latest | |
needs: check-env | |
if: needs.check-env.outputs.check-docker == 'true' | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v2 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v2 | |
- name: Login to DockerHub | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- name: Extract Docker metadata (ordinary version) | |
id: meta-ordinary | |
uses: docker/metadata-action@v4 | |
with: | |
images: ${{ secrets.DOCKER_USERNAME }}/rsshub | |
tags: | | |
type=raw,value=latest,enable=true | |
type=raw,value={{date 'YYYY-MM-DD'}},enable=true | |
flavor: latest=false | |
- name: Build and push Docker image (ordinary version) | |
uses: docker/build-push-action@v3 | |
with: | |
context: . | |
push: true | |
tags: ${{ steps.meta-ordinary.outputs.tags }} | |
labels: ${{ steps.meta-ordinary.outputs.labels }} | |
platforms: linux/amd64,linux/arm/v7,linux/arm64 | |
cache-from: type=gha,scope=docker-release | |
cache-to: type=gha,mode=max,scope=docker-release | |
# cache-from: type=registry,ref=${{ secrets.DOCKER_USERNAME }}/rsshub:buildcache | |
# cache-to: type=registry,ref=${{ secrets.DOCKER_USERNAME }}/rsshub:buildcache,mode=max | |
- name: Extract Docker metadata (Chromium-bundled version) | |
id: meta-chromium-bundled | |
uses: docker/metadata-action@v4 | |
with: | |
images: ${{ secrets.DOCKER_USERNAME }}/rsshub | |
tags: | | |
type=raw,value=chromium-bundled,enable=true | |
type=raw,value=chromium-bundled-{{date 'YYYY-MM-DD'}},enable=true | |
flavor: latest=false | |
- name: Build and push Docker image (Chromium-bundled version) | |
uses: docker/build-push-action@v3 | |
with: | |
context: . | |
build-args: PUPPETEER_SKIP_CHROMIUM_DOWNLOAD=0 | |
push: true | |
tags: ${{ steps.meta-chromium-bundled.outputs.tags }} | |
labels: ${{ steps.meta-chromium-bundled.outputs.labels }} | |
platforms: linux/amd64,linux/arm/v7,linux/arm64 | |
cache-from: | | |
type=registry,ref=${{ secrets.DOCKER_USERNAME }}/rsshub:chromium-bundled | |
# type=gha,scope=docker-release # not needed, Docker automatically uses local cache from the builder | |
# type=registry,ref=${{ secrets.DOCKER_USERNAME }}/rsshub:buildcache | |
cache-to: type=inline,ref=${{ secrets.DOCKER_USERNAME }}/rsshub:chromium-bundled # inline cache is enough | |
description: | |
runs-on: ubuntu-latest | |
needs: check-env | |
if: needs.check-env.outputs.check-docker == 'true' | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Docker Hub Description | |
uses: peter-evans/dockerhub-description@v3 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
repository: ${{ secrets.DOCKER_USERNAME }}/rsshub |