chore: add docker action #1
Workflow file for this run
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: Build WeWeRSS Server images and push image to docker hub | |
on: | |
workflow_dispatch: | |
push: | |
paths: | |
- "apps/**" | |
- "Dockerfile" | |
tags: | |
- "v*.*.*" | |
jobs: | |
build-images: | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 1 | |
- name: Install Dependencies | |
run: | | |
sudo apt update && sudo apt install -y nodejs npm | |
- name: Set up QEMU (optional) | |
uses: docker/setup-qemu-action@v2 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v2 | |
with: | |
driver-opts: network=host | |
- name: Cache Docker layers | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/.buildx-cache | |
key: ${{ runner.os }}-buildx-${{ github.sha }} | |
restore-keys: | | |
${{ runner.os }}-buildx- | |
- name: Login to GitHub Container Registry | |
uses: docker/login-action@v2 | |
with: | |
registry: ghcr.io | |
username: ${{ github.repository_owner }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Set DOCKER_REPO_TAGGED based on branch or tag | |
run: | | |
if [[ "${{ github.ref_name }}" == "main" ]]; then | |
echo "DOCKER_REPO_TAGGED=ghcr.io/${{ github.repository_owner }}/wewe-rss-server:latest" >> $GITHUB_ENV | |
else | |
echo "DOCKER_REPO_TAGGED=ghcr.io/${{ github.repository_owner }}/wewe-rss-server:${{ github.ref_name }}" >> $GITHUB_ENV | |
fi | |
- name: Build and publish image for main branch or tag push event | |
env: | |
DOCKER_REPO_TAGGED: ${{ env.DOCKER_REPO_TAGGED }} | |
run: | | |
docker buildx build \ | |
--build-arg name=app \ | |
--platform linux/amd64,linux/arm64 \ | |
--label "org.opencontainers.image.source=https://github.com/${{ github.repository_owner }}/wewe-rss-server" \ | |
--label "org.opencontainers.image.description=wewe-rss server image" \ | |
--push \ | |
--target server \ | |
--cache-from=type=local,src=/tmp/.buildx-cache \ | |
--cache-to=type=local,dest=/tmp/.buildx-cache \ | |
-t ${DOCKER_REPO_TAGGED} \ | |
-f Dockerfile \ | |
. | |
push-to-docker-hub: | |
needs: build-images | |
runs-on: ubuntu-20.04 | |
if: github.repository == 'cooderl/wewe-rss-server' | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
- name: Login to Docker Hub | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.DOCKER_HUB_NAME }} | |
password: ${{ secrets.DOCKER_HUB_PASSWORD }} | |
- name: Set DOCKER_REPO_TAGGED based on branch or tag | |
run: | | |
if [[ "${{ github.ref_name }}" == "main" ]]; then | |
echo "IMAGE_TAG=latest" >> $GITHUB_ENV | |
else | |
echo "IMAGE_TAG=${{ github.ref_name }}" >> $GITHUB_ENV | |
fi | |
- name: Pull image from GitHub Container Registry | |
run: docker pull ghcr.io/${{ github.repository_owner }}/wewe-rss-server:${{env.IMAGE_TAG}} | |
- name: Tag image with Docker Hub repository name and version tag | |
run: docker tag ghcr.io/${{ github.repository_owner }}/wewe-rss-server:${{env.IMAGE_TAG}} ${{ github.repository_owner }}/wewe-rss-server:${{env.IMAGE_TAG}} | |
- name: Push image to Docker Hub | |
run: docker push ${{ github.repository_owner }}/wewe-rss-server:${{env.IMAGE_TAG}} |