CI: Runner-Label auf 'docker' geändert + Forgejo API Upload
All checks were successful
Build AppImage / build (push) Has been skipped

- runs-on: docker (statt ubuntu-latest)
- Container: aspect-build/rust:stable-node22-bookworm
- Manueller git clone mit REGISTRY_TOKEN
- Forgejo API für Release-Upload (statt GitHub Action)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
Eddy 2026-04-15 14:18:35 +02:00
parent e17d94a078
commit 2c64963553

View file

@ -12,62 +12,74 @@ on:
jobs:
build:
# Nur bei [appimage] im Commit oder bei Tag
runs-on: docker
if: contains(github.event.head_commit.message, '[appimage]') || startsWith(github.ref, 'refs/tags/v')
runs-on: ubuntu-latest
container:
image: ghcr.io/tauri-apps/tauri-action-core:latest
image: ghcr.io/aspect-build/rust:stable-node22-bookworm
steps:
- name: Checkout
uses: actions/checkout@v4
run: |
git clone --depth 1 --branch "${GITHUB_REF_NAME}" \
"https://oauth2:${{ secrets.REGISTRY_TOKEN }}@git.data-it-solution.de/${GITHUB_REPOSITORY}.git" .
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: '22'
cache: 'npm'
- name: Setup Rust
uses: dtolnay/rust-toolchain@stable
- name: Rust Cache
uses: Swatinem/rust-cache@v2
with:
workspaces: src-tauri
- name: Install Dependencies
- name: Install System Dependencies
run: |
apt-get update
apt-get install -y libwebkit2gtk-4.1-dev libappindicator3-dev librsvg2-dev patchelf libssl-dev
apt-get install -y \
libwebkit2gtk-4.1-dev \
libappindicator3-dev \
librsvg2-dev \
patchelf \
libssl-dev \
libgtk-3-dev \
libayatana-appindicator3-dev \
file
- name: Install npm packages
run: npm ci
- name: Build Tauri App
run: npm run tauri build -- --bundles appimage
env:
TAURI_SIGNING_PRIVATE_KEY: ${{ secrets.TAURI_SIGNING_KEY }}
run: |
npm run tauri build -- --bundles appimage
ls -la src-tauri/target/release/bundle/appimage/
- name: Get Version
id: version
run: |
VERSION=$(grep '^version' src-tauri/Cargo.toml | head -1 | sed 's/.*"\(.*\)"/\1/')
echo "version=$VERSION" >> $GITHUB_OUTPUT
echo "Version: $VERSION"
echo "version=${VERSION}" >> $GITHUB_OUTPUT
echo "Version: ${VERSION}"
- name: Upload AppImage Artifact
uses: actions/upload-artifact@v4
with:
name: claude-desktop-${{ steps.version.outputs.version }}.AppImage
path: src-tauri/target/release/bundle/appimage/*.AppImage
# Bei Tag: Release erstellen und AppImage hochladen
- name: Create Release
- name: Upload to Release
if: startsWith(github.ref, 'refs/tags/v')
uses: softprops/action-gh-release@v1
with:
files: src-tauri/target/release/bundle/appimage/*.AppImage
generate_release_notes: true
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
APPIMAGE=$(ls src-tauri/target/release/bundle/appimage/*.AppImage | head -1)
FILENAME=$(basename "$APPIMAGE")
TAG="${GITHUB_REF#refs/tags/}"
echo "Lade $FILENAME zu Release $TAG hoch..."
# Release erstellen falls nicht vorhanden
curl -s -X POST \
-H "Authorization: token ${{ secrets.REGISTRY_TOKEN }}" \
-H "Content-Type: application/json" \
"https://git.data-it-solution.de/api/v1/repos/${GITHUB_REPOSITORY}/releases" \
-d "{\"tag_name\":\"${TAG}\",\"name\":\"${TAG}\",\"body\":\"Release ${TAG}\"}" || true
# Release-ID holen
RELEASE_ID=$(curl -s \
-H "Authorization: token ${{ secrets.REGISTRY_TOKEN }}" \
"https://git.data-it-solution.de/api/v1/repos/${GITHUB_REPOSITORY}/releases/tags/${TAG}" \
| grep -o '"id":[0-9]*' | head -1 | sed 's/"id"://')
echo "Release-ID: $RELEASE_ID"
# AppImage hochladen
curl -s -X POST \
-H "Authorization: token ${{ secrets.REGISTRY_TOKEN }}" \
-H "Content-Type: application/octet-stream" \
"https://git.data-it-solution.de/api/v1/repos/${GITHUB_REPOSITORY}/releases/${RELEASE_ID}/assets?name=${FILENAME}" \
--data-binary "@${APPIMAGE}"
echo "Upload abgeschlossen: ${FILENAME}"