78 lines
2.7 KiB
YAML
78 lines
2.7 KiB
YAML
name: Build and Deploy Gateway
|
|
|
|
on:
|
|
push:
|
|
branches: [master]
|
|
workflow_dispatch:
|
|
|
|
env:
|
|
DEPLOY_PATH: /opt/vpn-proxy
|
|
BASE_IMAGE: mirror.gcr.io/library/debian:bookworm-slim
|
|
SINGBOX_VERSION: 1.12.13
|
|
|
|
jobs:
|
|
build-and-push:
|
|
runs-on: lxc-107
|
|
steps:
|
|
- name: Clone repository
|
|
env:
|
|
GIT_TOKEN: ${{ secrets.REGISTRY_TOKEN }}
|
|
run: |
|
|
set -euo pipefail
|
|
SERVER_HOST=$(echo "${{ gitea.server_url }}" | sed 's|https\?://||')
|
|
rm -rf repo
|
|
git clone --depth 2 "http://${{ gitea.actor }}:${GIT_TOKEN}@${SERVER_HOST}/${{ gitea.repository }}.git" repo
|
|
cd repo
|
|
git checkout ${{ gitea.sha }}
|
|
|
|
- name: Build frontend and gateway image
|
|
run: |
|
|
set -euo pipefail
|
|
cd repo
|
|
npm ci --no-audit --no-fund
|
|
npm run build
|
|
|
|
REGISTRY_HOST=$(echo "${{ gitea.server_url }}" | sed 's|https\?://||')
|
|
IMAGE="${REGISTRY_HOST}/${{ gitea.repository }}/gateway"
|
|
|
|
echo "Build runner: $(hostname)"
|
|
echo "Base image: ${{ env.BASE_IMAGE }}"
|
|
echo "Docker context: $(docker context show 2>/dev/null || true)"
|
|
docker info 2>/dev/null | sed -n '/HTTP Proxy:/p;/HTTPS Proxy:/p;/Name:/p'
|
|
|
|
echo "${{ secrets.REGISTRY_TOKEN }}" | docker login "$REGISTRY_HOST" -u "${{ gitea.actor }}" --password-stdin
|
|
DOCKER_BUILDKIT=1 docker build \
|
|
--network host \
|
|
--pull=false \
|
|
--build-arg BASE_IMAGE="${{ env.BASE_IMAGE }}" \
|
|
--build-arg SINGBOX_VERSION="${{ env.SINGBOX_VERSION }}" \
|
|
-t "${IMAGE}:latest" \
|
|
-t "${IMAGE}:${{ gitea.sha }}" \
|
|
.
|
|
docker push "${IMAGE}:latest"
|
|
docker push "${IMAGE}:${{ gitea.sha }}"
|
|
|
|
deploy:
|
|
runs-on: lxc-111
|
|
needs: build-and-push
|
|
steps:
|
|
- name: Clone repository
|
|
env:
|
|
GIT_TOKEN: ${{ secrets.REGISTRY_TOKEN }}
|
|
run: |
|
|
set -euo pipefail
|
|
SERVER_HOST=$(echo "${{ gitea.server_url }}" | sed 's|https\?://||')
|
|
rm -rf repo
|
|
git clone --depth 2 "http://${{ gitea.actor }}:${GIT_TOKEN}@${SERVER_HOST}/${{ gitea.repository }}.git" repo
|
|
cd repo
|
|
git checkout ${{ gitea.sha }}
|
|
|
|
- name: Deploy gateway to LXC 111
|
|
run: |
|
|
set -euo pipefail
|
|
cd repo
|
|
REGISTRY_HOST=$(echo "${{ gitea.server_url }}" | sed 's|https\?://||')
|
|
IMAGE="${REGISTRY_HOST}/${{ gitea.repository }}/gateway"
|
|
echo "${{ secrets.REGISTRY_TOKEN }}" | docker login "$REGISTRY_HOST" -u "${{ gitea.actor }}" --password-stdin
|
|
DEPLOY_PATH="${{ env.DEPLOY_PATH }}" GATEWAY_IMAGE="${IMAGE}:${{ gitea.sha }}" bash scripts/deploy-gateway.sh
|