After building and pushing to adriahub, the CI pipeline now also tags and pushes images to forgejo.daddelolymp.de as a backup. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
153 lines
5.7 KiB
YAML
153 lines
5.7 KiB
YAML
name: Build & Deploy
|
|
|
|
on:
|
|
push:
|
|
branches: [main, nightly, feature/nightly]
|
|
|
|
env:
|
|
REGISTRY: forgejo.adriahub.de
|
|
REGISTRY_MIRROR: forgejo.daddelolymp.de
|
|
IMAGE: root/gaming-hub
|
|
|
|
jobs:
|
|
build:
|
|
runs-on: ubuntu-latest
|
|
container:
|
|
image: docker:latest
|
|
volumes:
|
|
- /var/run/docker.sock:/var/run/docker.sock
|
|
steps:
|
|
- name: Checkout
|
|
run: |
|
|
apk add --no-cache git
|
|
git clone --branch "${GITHUB_REF_NAME}" --depth 1 \
|
|
"http://root:${{ secrets.PUSH_TOKEN }}@192.168.1.100:3000/${GITHUB_REPOSITORY}.git" .
|
|
|
|
- name: Determine version and tag
|
|
id: vars
|
|
run: |
|
|
VERSION=$(cat VERSION 2>/dev/null || echo "0.0.0")
|
|
BRANCH="${GITHUB_REF_NAME}"
|
|
|
|
if [ "$BRANCH" = "main" ]; then
|
|
TAG="main"
|
|
CHANNEL="stable"
|
|
elif [ "$BRANCH" = "nightly" ] || [ "$BRANCH" = "feature/nightly" ]; then
|
|
TAG="nightly"
|
|
VERSION="${VERSION}-nightly"
|
|
CHANNEL="nightly"
|
|
else
|
|
TAG=$(echo "$BRANCH" | sed 's/\//-/g')
|
|
VERSION="${VERSION}-dev"
|
|
CHANNEL="dev"
|
|
fi
|
|
|
|
echo "tag=$TAG" >> "$GITHUB_OUTPUT"
|
|
echo "version=$VERSION" >> "$GITHUB_OUTPUT"
|
|
echo "channel=$CHANNEL" >> "$GITHUB_OUTPUT"
|
|
|
|
- name: Build Docker image
|
|
run: |
|
|
docker build \
|
|
--build-arg "VITE_BUILD_CHANNEL=${{ steps.vars.outputs.channel }}" \
|
|
--build-arg "VITE_APP_VERSION=${{ steps.vars.outputs.version }}" \
|
|
-t ${{ env.REGISTRY }}/${{ env.IMAGE }}:${{ steps.vars.outputs.tag }} \
|
|
.
|
|
|
|
if [ "${GITHUB_REF_NAME}" = "main" ]; then
|
|
docker tag ${{ env.REGISTRY }}/${{ env.IMAGE }}:${{ steps.vars.outputs.tag }} \
|
|
${{ env.REGISTRY }}/${{ env.IMAGE }}:latest
|
|
fi
|
|
|
|
- name: Push to registry (adriahub)
|
|
run: |
|
|
echo "${{ secrets.REGISTRY_PASSWORD }}" | docker login ${{ env.REGISTRY }} -u root --password-stdin
|
|
docker push ${{ env.REGISTRY }}/${{ env.IMAGE }}:${{ steps.vars.outputs.tag }}
|
|
if [ "${GITHUB_REF_NAME}" = "main" ]; then
|
|
docker push ${{ env.REGISTRY }}/${{ env.IMAGE }}:latest
|
|
fi
|
|
|
|
- name: Mirror to registry (daddelolymp)
|
|
run: |
|
|
echo "${{ secrets.REGISTRY_DADDELOLYMP_PASSWORD }}" | docker login ${{ env.REGISTRY_MIRROR }} -u root --password-stdin
|
|
docker tag ${{ env.REGISTRY }}/${{ env.IMAGE }}:${{ steps.vars.outputs.tag }} \
|
|
${{ env.REGISTRY_MIRROR }}/${{ env.IMAGE }}:${{ steps.vars.outputs.tag }}
|
|
docker push ${{ env.REGISTRY_MIRROR }}/${{ env.IMAGE }}:${{ steps.vars.outputs.tag }}
|
|
if [ "${GITHUB_REF_NAME}" = "main" ]; then
|
|
docker tag ${{ env.REGISTRY }}/${{ env.IMAGE }}:latest \
|
|
${{ env.REGISTRY_MIRROR }}/${{ env.IMAGE }}:latest
|
|
docker push ${{ env.REGISTRY_MIRROR }}/${{ env.IMAGE }}:latest
|
|
fi
|
|
|
|
deploy:
|
|
runs-on: ubuntu-latest
|
|
needs: build
|
|
if: github.ref_name == 'main'
|
|
container:
|
|
image: docker:latest
|
|
volumes:
|
|
- /var/run/docker.sock:/var/run/docker.sock
|
|
steps:
|
|
- name: Deploy container
|
|
run: |
|
|
DEPLOY_IMAGE="${{ env.REGISTRY }}/${{ env.IMAGE }}:latest"
|
|
CONTAINER_NAME="gaming-hub"
|
|
|
|
echo "${{ secrets.REGISTRY_PASSWORD }}" | docker login ${{ env.REGISTRY }} -u root --password-stdin
|
|
docker pull "$DEPLOY_IMAGE"
|
|
docker stop "$CONTAINER_NAME" || true
|
|
docker rm "$CONTAINER_NAME" || true
|
|
|
|
docker run -d \
|
|
--name "$CONTAINER_NAME" \
|
|
--network pangolin \
|
|
--restart unless-stopped \
|
|
-p 8085:8080 \
|
|
-e TZ=Europe/Berlin \
|
|
-e NODE_ENV=production \
|
|
-e PORT=8080 \
|
|
-e DATA_DIR=/data \
|
|
-e SOUNDS_DIR=/data/sounds \
|
|
-e "NODE_OPTIONS=--dns-result-order=ipv4first" \
|
|
-e ADMIN_PWD="${{ secrets.GAMING_HUB_ADMIN_PWD }}" \
|
|
-e PCM_CACHE_MAX_MB=2048 \
|
|
-e DISCORD_TOKEN_JUKEBOX="${{ secrets.DISCORD_TOKEN_JUKEBOX }}" \
|
|
-e DISCORD_TOKEN_RADIO="${{ secrets.DISCORD_TOKEN_RADIO }}" \
|
|
-e DISCORD_TOKEN_NOTIFICATIONS="${{ secrets.DISCORD_TOKEN_NOTIFICATIONS }}" \
|
|
-e PUBLIC_URL="${{ secrets.PUBLIC_URL }}" \
|
|
-e STEAM_API_KEY="${{ secrets.STEAM_API_KEY }}" \
|
|
-e DISCORD_CLIENT_ID="${{ secrets.DISCORD_CLIENT_ID }}" \
|
|
-e DISCORD_CLIENT_SECRET="${{ secrets.DISCORD_CLIENT_SECRET }}" \
|
|
-v /mnt/cache/appdata/gaming-hub/data:/data:rw \
|
|
-v /mnt/cache/appdata/dockge/container/jukebox/sounds/:/data/sounds:rw \
|
|
"$DEPLOY_IMAGE"
|
|
|
|
docker ps --filter name="$CONTAINER_NAME"
|
|
docker image prune -f || true
|
|
|
|
bump-version:
|
|
runs-on: ubuntu-latest
|
|
needs: deploy
|
|
if: github.ref_name == 'main' && !contains(github.event.head_commit.message, '[skip ci]')
|
|
container:
|
|
image: alpine/git:latest
|
|
steps:
|
|
- name: Checkout and bump
|
|
run: |
|
|
git clone --branch main --depth 5 \
|
|
"http://root:${{ secrets.PUSH_TOKEN }}@192.168.1.100:3000/${GITHUB_REPOSITORY}.git" repo
|
|
cd repo
|
|
git config user.name "Forgejo CI"
|
|
git config user.email "ci@adriahub.de"
|
|
|
|
VERSION=$(cat VERSION)
|
|
MAJOR=$(echo "$VERSION" | cut -d. -f1)
|
|
MINOR=$(echo "$VERSION" | cut -d. -f2)
|
|
PATCH=$(echo "$VERSION" | cut -d. -f3)
|
|
NEXT_PATCH=$((PATCH + 1))
|
|
NEXT_VERSION="${MAJOR}.${MINOR}.${NEXT_PATCH}"
|
|
|
|
echo "$NEXT_VERSION" > VERSION
|
|
git add VERSION
|
|
git commit -m "v${NEXT_VERSION} [skip ci]"
|
|
git push origin main
|