Add: Forgejo CI/CD workflow (migrated from GitLab CI)
Some checks failed
Build & Deploy / build (push) Failing after 7s
Build & Deploy / deploy (push) Has been skipped
Build & Deploy / electron-build (push) Has been skipped
Build & Deploy / bump-version (push) Has been skipped

This commit is contained in:
root 2026-03-10 17:38:06 +01:00
parent c24b4c5d9e
commit 5796a6d620

View file

@ -0,0 +1,175 @@
name: Build & Deploy
on:
push:
branches: [main, nightly, feature/nightly]
env:
REGISTRY: 192.168.1.100:3000
IMAGE: root/gaming-hub
jobs:
build:
runs-on: ubuntu-latest
container:
image: docker:latest
volumes:
- /var/run/docker.sock:/var/run/docker.sock
steps:
- uses: actions/checkout@v4
- 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
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
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 }}" \
-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
electron-build:
runs-on: ubuntu-latest
needs: deploy
if: github.ref_name == 'main'
container:
image: docker:latest
volumes:
- /var/run/docker.sock:/var/run/docker.sock
steps:
- uses: actions/checkout@v4
- name: Build Electron app
run: |
VERSION=$(cat VERSION 2>/dev/null || echo "0.0.0")
CONTAINER_NAME="gaming-hub"
apk add --no-cache nodejs npm
cd electron
node -e "
const pkg = require('./package.json');
pkg.version = '${VERSION}';
require('fs').writeFileSync('package.json', JSON.stringify(pkg, null, 2) + '\n');
"
npm ci --no-audit --no-fund
npx electron-forge make --platform win32 --arch x64
SRC_DIR="out/make/squirrel.windows/x64"
docker exec "$CONTAINER_NAME" mkdir -p /data/downloads
docker cp "${SRC_DIR}/RELEASES" "${CONTAINER_NAME}:/data/downloads/RELEASES"
for f in ${SRC_DIR}/*.nupkg; do
docker cp "$f" "${CONTAINER_NAME}:/data/downloads/$(basename "$f")"
done
SETUP_EXE=$(ls ${SRC_DIR}/*Setup*.exe 2>/dev/null | head -1)
if [ -n "$SETUP_EXE" ]; then
docker cp "$SETUP_EXE" "${CONTAINER_NAME}:/data/downloads/GamingHub-Setup.exe"
fi
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:
- uses: actions/checkout@v4
with:
fetch-depth: 0
token: ${{ secrets.PUSH_TOKEN }}
- name: Bump patch version
run: |
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