Files
spage/.github/workflows/build-aio.yaml

305 lines
8.9 KiB
YAML

name: Build & Publish All-in-One
on:
push:
branches: [main]
tags: [v*]
workflow_dispatch:
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
BIN_NAME: spage
BIN_OUT: build
# for Go build
GO_PKG_ROOT: github.com/LiteyukiStudio/spage
# for container build
CONTAINER_PLATFORMS: linux/amd64,linux/arm64,linux/386,linux/arm,linux/ppc64le,linux/s390x
REG_GHCR: ghcr.io
REG_DOCKERHUB: docker.io
REG_LCR: reg.liteyuki.org
NAMESPACE_GHCR: liteyukistudio
NAMESPACE_DOCKERHUB: liteyukistudio
NAMESPACE_LCR: spage
ARCH_MAP: |
amd64:amd64-v1
arm64:arm64
arm:armv7
386:386-sse2
ppc64le:ppc64le
s390x:s390x
concurrency:
group: "build-aio"
cancel-in-progress: true
permissions:
contents: write
packages: write
jobs:
frontend:
name: Build Frontend
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: 20
- name: Build frontend
run: |
cd web-src
npm install pnpm -g
pnpm install
pnpm build
- name: Upload frontend artifact
uses: actions/upload-artifact@v4
with:
name: web
path: web-src/out
backend:
name: Build Backend
needs: frontend
runs-on: ubuntu-latest
outputs:
version: ${{ steps.version.outputs.version }}
tag: ${{ steps.version.outputs.tag }}
nightly: ${{ steps.version.outputs.nightly }}
strategy:
matrix:
include:
- goos: darwin
goarch: amd64
goamd64: v1
output: amd64-v1
- goos: darwin
goarch: amd64
goamd64: v3
output: amd64-v3
- goos: darwin
goarch: arm64
output: arm64
- goos: freebsd
goarch: amd64
goamd64: v1
output: amd64-v1
- goos: freebsd
goarch: amd64
goamd64: v3
output: amd64-v3
- goos: freebsd
goarch: arm64
output: arm64
- goos: freebsd
goarch: 386
output: 386
- goos: freebsd
goarch: arm
output: arm
- goos: linux
goarch: amd64
goamd64: v1
output: amd64-v1
- goos: linux
goarch: amd64
goamd64: v3
output: amd64-v3
- goos: linux
goarch: arm64
output: arm64
- goos: linux
goarch: 386
go386: sse2
output: 386-sse2
- goos: linux
goarch: arm
goarm: 7
output: armv7
- goos: linux
goarch: arm
goarm: 6
output: armv6
- goos: linux
goarch: arm
goarm: 5
output: armv5
- goos: linux
goarch: ppc64le
output: ppc64le
- goos: linux
goarch: s390x
output: s390x
- goos: windows
goarch: amd64
goamd64: v1
output: amd64-v1
- goos: windows
goarch: amd64
goamd64: v3
output: amd64-v3
- goos: windows
goarch: arm64
output: arm64
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Go
uses: actions/setup-go@v5
- name: Set version/tag
id: version
run: |
if [[ "${GITHUB_REF}" == refs/tags/v* ]]; then
VERSION="${GITHUB_REF#refs/tags/}"
TAG="${VERSION}"
NIGHTLY="false"
else
VERSION="${GITHUB_SHA}"
TAG="nightly"
NIGHTLY="true"
fi
echo "version=${VERSION}" >> $GITHUB_OUTPUT
echo "tag=${TAG}" >> $GITHUB_OUTPUT
echo "nightly=${NIGHTLY}" >> $GITHUB_OUTPUT
- name: Download frontend artifact
uses: actions/download-artifact@v4
with:
name: web
path: static/dist/
- name: Build Go binary (single file naming)
env:
GOOS: ${{ matrix.goos }}
GOARCH: ${{ matrix.goarch }}
GOAMD64: ${{ matrix.goamd64 }}
GOARM: ${{ matrix.goarm }}
GO386: ${{ matrix.go386 }}
run: |
mkdir -p build
OUTNAME="${{ env.BIN_NAME }}-${{ matrix.goos }}-${{ matrix.goarch }}"
if [ -n "${{ matrix.goamd64 }}" ]; then
OUTNAME="${OUTNAME}-${{ matrix.goamd64 }}"
fi
if [ -n "${{ matrix.goarm }}" ]; then
OUTNAME="${OUTNAME}v${{ matrix.goarm }}"
fi
if [ -n "${{ matrix.go386 }}" ]; then
OUTNAME="${OUTNAME}-${{ matrix.go386 }}"
fi
if [ "${{ matrix.goos }}" = "windows" ]; then
OUTNAME="${OUTNAME}.exe"
fi
go build \
-trimpath \
-ldflags "-X '${{ env.GO_PKG_ROOT }}/config.CommitHash=${{ github.sha }}' \
-X '${{ env.GO_PKG_ROOT }}/config.BuildTime=$(date -u +%Y-%m-%dT%H:%M:%SZ)' \
-X '${{ env.GO_PKG_ROOT }}/config.Version=${{ steps.version.outputs.version }}'" \
-o build/$OUTNAME ./cmd/server
- name: Upload all backend binaries
uses: actions/upload-artifact@v4
with:
name: ${{ env.BIN_NAME }}-all
path: build/*
docker:
name: Build & Push Docker Images
runs-on: ubuntu-latest
needs: backend
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Download all linux artifacts for docker
uses: actions/download-artifact@v4
with:
pattern: ${{ env.BIN_NAME }}-linux-*
path: build/
merge-multiple: true
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Login to GHCR
uses: docker/login-action@v3
with:
registry: ${{ env.REG_GHCR }}
username: ${{ secrets.GHCR_USER }}
password: ${{ secrets.GHCR_TOKEN }}
- name: Login to DockerHub
uses: docker/login-action@v3
with:
registry: ${{ env.REG_DOCKERHUB }}
username: ${{ secrets.DOCKERHUB_USER }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Login to LCR
uses: docker/login-action@v3
with:
registry: ${{ env.REG_LCR }}
username: ${{ secrets.LITEYUKIREG_USER }}
password: ${{ secrets.LITEYUKIREG_TOKEN }}
- name: Build & Push Docker Images (tag & latest)
if: ${{ needs.backend.outputs.nightly == 'false' }}
uses: docker/build-push-action@v6
with:
context: .
push: true
tags: |
${{ env.NAMESPACE_DOCKERHUB }}/${{ env.BIN_NAME }}:${{ needs.backend.outputs.tag }}
${{ env.NAMESPACE_DOCKERHUB }}/${{ env.BIN_NAME }}:latest
${{ env.NAMESPACE_DOCKERHUB }}/${{ env.BIN_NAME }}:nightly
${{ env.REG_GHCR }}/${{ env.NAMESPACE_GHCR }}/${{ env.BIN_NAME }}:${{ needs.backend.outputs.tag }}
${{ env.REG_GHCR }}/${{ env.NAMESPACE_GHCR }}/${{ env.BIN_NAME }}:latest
${{ env.REG_GHCR }}/${{ env.NAMESPACE_GHCR }}/${{ env.BIN_NAME }}:nightly
${{ env.REG_LCR }}/${{ env.NAMESPACE_LCR }}/${{ env.BIN_NAME }}:${{ needs.backend.outputs.tag }}
${{ env.REG_LCR }}/${{ env.NAMESPACE_LCR }}/${{ env.BIN_NAME }}:latest
${{ env.REG_LCR }}/${{ env.NAMESPACE_LCR }}/${{ env.BIN_NAME }}:nightly
platforms: ${{ env.CONTAINER_PLATFORMS }}
- name: Build & Push Docker Images (nightly only)
if: ${{ needs.backend.outputs.nightly == 'true' }}
uses: docker/build-push-action@v6
with:
context: .
push: true
tags: |
${{ env.NAMESPACE_DOCKERHUB }}/${{ env.BIN_NAME }}:nightly
${{ env.REG_GHCR }}/${{ env.NAMESPACE_GHCR }}/${{ env.BIN_NAME }}:nightly
${{ env.REG_LCR }}/${{ env.NAMESPACE_LCR }}/${{ env.BIN_NAME }}:nightly
platforms: ${{ env.CONTAINER_PLATFORMS }}
release:
name: Publish GitHub Release
runs-on: ubuntu-latest
needs: backend
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Download all artifacts for release
uses: actions/download-artifact@v4
with:
pattern: |
${{ env.BIN_NAME }}-*
path: bin/
merge-multiple: true
- name: Publish GitHub Release
if: ${{ needs.backend.outputs.nightly == 'false' }}
uses: softprops/action-gh-release@v2.3.0
with:
tag_name: ${{ needs.backend.outputs.tag }}
name: Release ${{ needs.backend.outputs.tag }}
body: |
Release ${{ needs.backend.outputs.tag }}
Built from tag ${{ needs.backend.outputs.tag }}
files: bin/**