# Linux packaging build test: AppImage, deb, rpm, Flatpak (branches and PRs). # Tagged release assets run in .github/workflows/build-release.yml with draft. # # Pinned first-party actions (bump tag and SHA together when upgrading): # actions/checkout@v6.0.1 8e8c483db84b4bee98b60c0593521ed34d9990e8 # actions/setup-python@v6.2.0 a309ff8b426b58ec0e2a45f0f869d46889d02405 # actions/setup-node@v6.1.0 395ad3262231945c25e8478fd5baf05154b1d79f # actions/upload-artifact@v5.0.0 330a01c490aca151604b8cf639adc76d48f6c5d4 # actions/download-artifact@v5.0.0 634f93cb2916e3fdff6788551b99b062d0335ce0 # actions/cache@v4.2.0 1bd1e32a3bdc45362d1e726936510720a7c30a57 name: Build Linux packages on: push: branches: - dev pull_request: branches: - dev paths: - "package.json" - "forge.config.js" - "scripts/electron-forge-local-tmp.js" - "scripts/ensure-flatpak-flathub-remote.sh" - "scripts/ci/github-build-linux-*.sh" - ".github/workflows/build-linux-packages.yml" - ".github/workflows/build-release.yml" - ".github/workflows/frontend-build.yml" workflow_dispatch: permissions: contents: read concurrency: group: ${{ github.workflow }}-${{ github.ref }} cancel-in-progress: true env: FORCE_JAVASCRIPT_ACTIONS_TO_NODE24: true NODE_OPTIONS: --max-old-space-size=8192 PYTHON_VERSION: "3.14" NODE_VERSION: "24" UV_VERSION: "0.11.12" PNPM_VERSION: "10.32.1" jobs: frontend: name: Build frontend artifact uses: ./.github/workflows/frontend-build.yml permissions: contents: read with: artifact_name: meshchatx-frontend-linux-pkg-${{ github.run_id }}-${{ github.run_attempt }} retention_days: 1 linux-test-x64: name: Linux build test (x64) needs: frontend runs-on: ubuntu-latest timeout-minutes: 120 permissions: contents: read actions: write env: FRONTEND_ARTIFACT_NAME: ${{ needs.frontend.outputs.artifact_name }} MESHCHATX_FRONTEND_PREBUILT: "1" steps: - name: Checkout uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 - name: Set up Python uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 with: python-version: ${{ env.PYTHON_VERSION }} - name: Install UV (PyPI pin) env: UV_VERSION: ${{ env.UV_VERSION }} run: bash scripts/ci/github-install-uv.sh - name: Cache UV downloads uses: actions/cache@1bd1e32a3bdc45362d1e726936510720a7c30a57 with: path: ~/.cache/uv key: ${{ runner.os }}-uv-${{ hashFiles('uv.lock') }} restore-keys: | ${{ runner.os }}-uv- - name: Enable pnpm (corepack) run: corepack enable && corepack prepare "pnpm@${PNPM_VERSION}" --activate - name: Set up Node uses: actions/setup-node@395ad3262231945c25e8478fd5baf05154b1d79f with: node-version: ${{ env.NODE_VERSION }} cache: pnpm cache-dependency-path: pnpm-lock.yaml - name: Linux packaging APT dependencies run: bash scripts/ci/github-apt-linux-packaging.sh - name: Install project dependencies run: bash scripts/ci/github-install-deps.sh - name: Download frontend artifact uses: actions/download-artifact@634f93cb2916e3fdff6788551b99b062d0335ce0 with: name: ${{ env.FRONTEND_ARTIFACT_NAME }} path: meshchatx/public - name: Verify frontend artifact contents run: | set -euo pipefail test -f meshchatx/public/index.html test -d meshchatx/public/assets test -d meshchatx/public/reticulum-docs-bundled/current - name: Setup Task run: sh scripts/ci/setup-task.sh - name: Build release-assets run: bash scripts/ci/github-build-linux-release-assets.sh - name: Upload Linux build-test artifact (x64) uses: actions/upload-artifact@330a01c490aca151604b8cf639adc76d48f6c5d4 with: name: meshchatx-linux-build-test-x64-${{ github.ref_name }}-${{ github.run_id }} path: release-assets/ if-no-files-found: warn retention-days: 1 linux-test-arm64: name: Linux build test (arm64) needs: frontend runs-on: ubuntu-24.04-arm timeout-minutes: 120 permissions: contents: read actions: write env: FRONTEND_ARTIFACT_NAME: ${{ needs.frontend.outputs.artifact_name }} MESHCHATX_FRONTEND_PREBUILT: "1" steps: - name: Checkout uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 - name: Set up Python uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 with: python-version: ${{ env.PYTHON_VERSION }} - name: Install UV (PyPI pin) env: UV_VERSION: ${{ env.UV_VERSION }} run: bash scripts/ci/github-install-uv.sh - name: Cache UV downloads uses: actions/cache@1bd1e32a3bdc45362d1e726936510720a7c30a57 with: path: ~/.cache/uv key: ${{ runner.os }}-uv-${{ hashFiles('uv.lock') }} restore-keys: | ${{ runner.os }}-uv- - name: Enable pnpm (corepack) run: corepack enable && corepack prepare "pnpm@${PNPM_VERSION}" --activate - name: Set up Node uses: actions/setup-node@395ad3262231945c25e8478fd5baf05154b1d79f with: node-version: ${{ env.NODE_VERSION }} cache: pnpm cache-dependency-path: pnpm-lock.yaml - name: Linux packaging APT dependencies run: bash scripts/ci/github-apt-linux-packaging.sh - name: Install project dependencies run: bash scripts/ci/github-install-deps.sh - name: Download frontend artifact uses: actions/download-artifact@634f93cb2916e3fdff6788551b99b062d0335ce0 with: name: ${{ env.FRONTEND_ARTIFACT_NAME }} path: meshchatx/public - name: Verify frontend artifact contents run: | set -euo pipefail test -f meshchatx/public/index.html test -d meshchatx/public/assets test -d meshchatx/public/reticulum-docs-bundled/current - name: Setup Task run: sh scripts/ci/setup-task.sh - name: Build release-assets run: bash scripts/ci/github-build-linux-release-assets.sh - name: Upload Linux build-test artifact (arm64) uses: actions/upload-artifact@330a01c490aca151604b8cf639adc76d48f6c5d4 with: name: meshchatx-linux-build-test-arm64-${{ github.ref_name }}-${{ github.run_id }} path: release-assets/ if-no-files-found: warn retention-days: 1 flatpak: name: Flatpak (electron-forge) needs: frontend runs-on: ubuntu-latest timeout-minutes: 90 permissions: contents: read env: FRONTEND_ARTIFACT_NAME: ${{ needs.frontend.outputs.artifact_name }} MESHCHATX_FRONTEND_PREBUILT: "1" steps: - name: Checkout uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 - name: Install flatpak toolchain run: | set -euo pipefail sudo apt-get update -y sudo apt-get install -y --no-install-recommends \ flatpak \ flatpak-builder \ elfutils \ zstd \ desktop-file-utils \ appstream - name: Install flatpak runtimes (user scope) run: | set -euo pipefail bash scripts/ensure-flatpak-flathub-remote.sh flatpak --user install -y --noninteractive flathub \ org.freedesktop.Platform//25.08 \ org.freedesktop.Sdk//25.08 \ org.electronjs.Electron2.BaseApp//25.08 - name: Set up Python uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 with: python-version: ${{ env.PYTHON_VERSION }} - name: Install UV (PyPI pin) env: UV_VERSION: ${{ env.UV_VERSION }} run: bash scripts/ci/github-install-uv.sh - name: Cache UV downloads uses: actions/cache@1bd1e32a3bdc45362d1e726936510720a7c30a57 with: path: ~/.cache/uv key: ${{ runner.os }}-uv-${{ hashFiles('uv.lock') }} restore-keys: | ${{ runner.os }}-uv- - name: Enable pnpm (corepack) run: corepack enable && corepack prepare "pnpm@${PNPM_VERSION}" --activate - name: Set up Node uses: actions/setup-node@395ad3262231945c25e8478fd5baf05154b1d79f with: node-version: ${{ env.NODE_VERSION }} cache: pnpm cache-dependency-path: pnpm-lock.yaml - name: Install dependencies run: bash scripts/ci/github-install-deps.sh - name: Download frontend artifact uses: actions/download-artifact@634f93cb2916e3fdff6788551b99b062d0335ce0 with: name: ${{ env.FRONTEND_ARTIFACT_NAME }} path: meshchatx/public - name: Verify frontend artifact contents run: | set -euo pipefail test -f meshchatx/public/index.html test -d meshchatx/public/assets test -d meshchatx/public/reticulum-docs-bundled/current - name: Build flatpak bundle run: bash scripts/ci/github-build-linux-flatpak.sh - name: List flatpak output run: | set -euo pipefail ls -la out/make 2>/dev/null || true find out/make -maxdepth 5 -type f \( -name "*.flatpak" -o -name "*.flatpakref" \) -print || true - name: Upload flatpak artifact uses: actions/upload-artifact@330a01c490aca151604b8cf639adc76d48f6c5d4 with: name: meshchatx-linux-flatpak-${{ github.ref_name }}-${{ github.run_id }} path: | out/make/**/*.flatpak if-no-files-found: warn retention-days: 7