Skip to content

Commit

Permalink
Build tagged images
Browse files Browse the repository at this point in the history
The --verify-clients option requires derper and tailscaled to be on the same version
  • Loading branch information
Runzhi He committed Jul 9, 2024
1 parent 5c2d88f commit eecb302
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 9 deletions.
44 changes: 37 additions & 7 deletions .github/workflows/docker-image.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,34 +6,64 @@ on:
schedule:
# Runs "every Monday" (see https://crontab.guru)
- cron: '0 0 * * MON'
workflow_dispatch:

jobs:
build:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v2

- name: Log in to GitHub Docker Registry
uses: docker/login-action@v1
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: Log in to DockerHub Registry
uses: docker/login-action@v1
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_PASSWORD }}

- name: Get latest tailscale version
run: |
TAILSCALE_VERSION=$(curl -s https://api.github.com/repos/tailscale/tailscale/releases/latest | jq -r '.tag_name')
echo "Latest tailscale version: $TAILSCALE_VERSION"
echo TAILSCALE_VERSION=$TAILSCALE_VERSION >> $GITHUB_ENV
- name: Check if the image exists
run: |
GHCR_TOKEN=$(echo ${{ secrets.GITHUB_TOKEN }} | base64)
HTTP_CODE=$(curl -s -o /dev/null -w "%{http_code}" \
-H "Authorization: Bearer $GHCR_TOKEN" \
https://ghcr.io/v2/${{ github.repository }}/manifests/${{ env.TAILSCALE_VERSION }}
)
IMAGE_EXISTS=$(if [ $HTTP_CODE -eq 200 ]; then echo "true"; else echo "false"; fi)
echo "HTTP code: $HTTP_CODE, Image exists: $IMAGE_EXISTS"
echo IMAGE_EXISTS=$IMAGE_EXISTS >> $GITHUB_ENV
- name: Set up QEMU
uses: docker/setup-qemu-action@v1
if: ${{ env.IMAGE_EXISTS == 'false' || github.event_name != 'schedule' }}
uses: docker/setup-qemu-action@v3

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v1
if: ${{ env.IMAGE_EXISTS == 'false' || github.event_name != 'schedule' }}
uses: docker/setup-buildx-action@v3

- name: Build and push
uses: docker/build-push-action@v2
if: ${{ env.IMAGE_EXISTS == 'false' || github.event_name != 'schedule' }}
uses: docker/build-push-action@v6
with:
context: .
platforms: linux/amd64,linux/arm64
platforms: linux/amd64, linux/arm64
push: true
tags: |
ghcr.io/fredliang44/derper:latest
fredliang/derper:latest
fredliang/derper:${{ github.sha }}
${{ github.actor }}/derper:${{ env.TAILSCALE_VERSION }}
${{ github.actor }}/derper:latest
ghcr.io/${{ github.actor }}/derper:${{ env.TAILSCALE_VERSION }}
ghcr.io/${{ github.actor }}/derper:latest
build-args: |
DERP_VERSION=${{ env.TAILSCALE_VERSION }}
4 changes: 2 additions & 2 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
FROM golang:latest AS builder
WORKDIR /app

# https://tailscale.com/kb/1118/custom-derp-servers/
RUN go install tailscale.com/cmd/derper@main
ARG DERP_VERSION=latest
RUN go install tailscale.com/cmd/derper@${DERP_VERSION}

FROM ubuntu
WORKDIR /app
Expand Down

0 comments on commit eecb302

Please sign in to comment.