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