-
Notifications
You must be signed in to change notification settings - Fork 81
75 lines (64 loc) · 2.5 KB
/
docker-image.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
name: Docker Image
on:
push:
branches: [main]
schedule:
# Runs "every Monday" (see https://crontab.guru)
- cron: '0 0 * * MON'
workflow_dispatch:
permissions:
contents: read
packages: write
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 }}
logout: false
- 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
if: ${{ env.IMAGE_EXISTS == 'false' || github.event_name != 'schedule' }}
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
if: ${{ env.IMAGE_EXISTS == 'false' || github.event_name != 'schedule' }}
uses: docker/setup-buildx-action@v3
- name: Build and push
if: ${{ env.IMAGE_EXISTS == 'false' || github.event_name != 'schedule' }}
uses: docker/build-push-action@v6
with:
context: .
platforms: linux/amd64, linux/arm64
push: true
tags: |
fredliang/derper:${{ env.TAILSCALE_VERSION }}
fredliang/derper:latest
fredliang/derper:${{ github.sha }}
ghcr.io/${{ github.actor }}/derper:${{ env.TAILSCALE_VERSION }}
ghcr.io/${{ github.actor }}/derper:latest
build-args: |
DERP_VERSION=${{ env.TAILSCALE_VERSION }}