From da20453e8257c79d77b2dea9c340980dd7b9d1b5 Mon Sep 17 00:00:00 2001 From: zias Date: Wed, 8 Apr 2026 11:52:54 +0200 Subject: [PATCH] fix(ci):this might work?? :pray: --- .gitea/workflows/docker-build-dashboard.yml | 5 + .github/workflows/docker-build.yml | 265 -------------------- apps/start/Dockerfile | 19 +- 3 files changed, 12 insertions(+), 277 deletions(-) delete mode 100644 .github/workflows/docker-build.yml diff --git a/.gitea/workflows/docker-build-dashboard.yml b/.gitea/workflows/docker-build-dashboard.yml index d2c99369..ee7ec05b 100644 --- a/.gitea/workflows/docker-build-dashboard.yml +++ b/.gitea/workflows/docker-build-dashboard.yml @@ -17,6 +17,11 @@ jobs: steps: - uses: actions/checkout@v4 + # FIX: Install the latest QEMU binaries to ensure stable and fast + # cross-compilation/emulation on your ARM64 Raspberry Pi + - name: Set up QEMU + uses: docker/setup-qemu-action@v3 + - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 diff --git a/.github/workflows/docker-build.yml b/.github/workflows/docker-build.yml deleted file mode 100644 index fcfac62d..00000000 --- a/.github/workflows/docker-build.yml +++ /dev/null @@ -1,265 +0,0 @@ -name: Docker Build and Push - -on: - workflow_dispatch: - push: - paths-ignore: - # README and docs - - "**/README*" - - "**/readme*" - - "**/*.md" - - "**/docs/**" - - "**/CHANGELOG*" - - "**/LICENSE*" - # Test files - - "**/*.test.*" - - "**/*.spec.*" - - "**/__tests__/**" - - "**/tests/**" - # SDKs (published separately) - - "packages/sdks/**" - # Public app (docs/marketing, not part of Docker deploy) - - "apps/public/**" - # Dev / tooling - - "**/.vscode/**" - - "**/.cursor/**" - - "**/.env.example" - - "**/.env.*.example" - - "**/.gitignore" - - "**/.eslintignore" - - "**/.prettierignore" - -env: - repo_owner: "openpanel-dev" - -jobs: - lint-and-test: - runs-on: ubuntu-latest - services: - redis: - image: redis:7-alpine - ports: - - 6379:6379 - options: >- - --health-cmd "redis-cli ping || exit 1" - --health-interval 5s - --health-timeout 3s - --health-retries 20 - steps: - - uses: actions/checkout@v4 - - - name: Setup Node.js - uses: actions/setup-node@v4 - with: - node-version: "20" - - - name: Install pnpm - uses: pnpm/action-setup@v4 - - - name: Get pnpm store directory - shell: bash - run: | - echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV - - - name: Setup pnpm cache - uses: actions/cache@v3 - with: - path: ${{ env.STORE_PATH }} - key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} - restore-keys: | - ${{ runner.os }}-pnpm-store- - - - name: Install dependencies - run: pnpm install - - - name: Codegen - run: pnpm codegen - - # - name: Run Biome - # run: pnpm lint - - # - name: Run TypeScript checks - # run: pnpm typecheck - - # - name: Run tests - # run: pnpm test - - build-and-push-api: - permissions: - packages: write - contents: write - needs: lint-and-test - runs-on: ubuntu-latest - steps: - - name: Checkout repository - uses: actions/checkout@v4 - - - name: Generate tags - id: tags - run: | - # Sanitize branch name by replacing / with - - BRANCH_NAME=$(echo "${{ github.ref_name }}" | sed 's/\//-/g') - # Get first 4 characters of commit SHA - SHORT_SHA=$(echo "${{ github.sha }}" | cut -c1-4) - echo "branch_name=$BRANCH_NAME" >> $GITHUB_OUTPUT - echo "short_sha=$SHORT_SHA" >> $GITHUB_OUTPUT - - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 - - - name: Log in to GitHub Container Registry - uses: docker/login-action@v3 - with: - registry: ghcr.io - username: ${{ github.actor }} - password: ${{ secrets.GITHUB_TOKEN }} - - - name: Build and push Docker image - uses: docker/build-push-action@v6 - with: - context: . - file: apps/api/Dockerfile - push: true - cache-from: type=gha - cache-to: type=gha,mode=max - tags: | - ghcr.io/${{ env.repo_owner }}/api:${{ steps.tags.outputs.branch_name }}-${{ steps.tags.outputs.short_sha }} - build-args: | - DATABASE_URL=postgresql://dummy:dummy@localhost:5432/dummy - - - name: Create/Update API tag - if: github.ref == 'refs/heads/main' - run: | - # Delete existing tag if it exists - if git tag -l "api" | grep -q "api"; then - git tag -d "api" - echo "Deleted local tag: api" - fi - - # Create new tag - git tag "api" "${{ github.sha }}" - echo "Created tag: api" - - # Push tag to remote - git push origin "api" --force - echo "Pushed tag: api" - - build-and-push-worker: - permissions: - packages: write - contents: write - needs: lint-and-test - runs-on: ubuntu-latest - steps: - - name: Checkout repository - uses: actions/checkout@v4 - - - name: Generate tags - id: tags - run: | - # Sanitize branch name by replacing / with - - BRANCH_NAME=$(echo "${{ github.ref_name }}" | sed 's/\//-/g') - # Get first 4 characters of commit SHA - SHORT_SHA=$(echo "${{ github.sha }}" | cut -c1-4) - echo "branch_name=$BRANCH_NAME" >> $GITHUB_OUTPUT - echo "short_sha=$SHORT_SHA" >> $GITHUB_OUTPUT - - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 - - - name: Log in to GitHub Container Registry - uses: docker/login-action@v3 - with: - registry: ghcr.io - username: ${{ github.actor }} - password: ${{ secrets.GITHUB_TOKEN }} - - - name: Build and push Docker image - uses: docker/build-push-action@v6 - with: - context: . - file: apps/worker/Dockerfile - push: true - cache-from: type=gha - cache-to: type=gha,mode=max - tags: | - ghcr.io/${{ env.repo_owner }}/worker:${{ steps.tags.outputs.branch_name }}-${{ steps.tags.outputs.short_sha }} - build-args: | - DATABASE_URL=postgresql://dummy:dummy@localhost:5432/dummy - - - name: Create/Update Worker tag - if: github.ref == 'refs/heads/main' - run: | - # Delete existing tag if it exists - if git tag -l "worker" | grep -q "worker"; then - git tag -d "worker" - echo "Deleted local tag: worker" - fi - - # Create new tag - git tag "worker" "${{ github.sha }}" - echo "Created tag: worker" - - # Push tag to remote - git push origin "worker" --force - echo "Pushed tag: worker" - - build-and-push-dashboard: - permissions: - packages: write - contents: write - needs: lint-and-test - runs-on: ubuntu-latest - steps: - - name: Checkout repository - uses: actions/checkout@v4 - - - name: Generate tags - id: tags - run: | - # Sanitize branch name by replacing / with - - BRANCH_NAME=$(echo "${{ github.ref_name }}" | sed 's/\//-/g') - # Get first 4 characters of commit SHA - SHORT_SHA=$(echo "${{ github.sha }}" | cut -c1-4) - echo "branch_name=$BRANCH_NAME" >> $GITHUB_OUTPUT - echo "short_sha=$SHORT_SHA" >> $GITHUB_OUTPUT - - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 - - - name: Log in to GitHub Container Registry - uses: docker/login-action@v3 - with: - registry: ghcr.io - username: ${{ github.actor }} - password: ${{ secrets.GITHUB_TOKEN }} - - - name: Build and push Docker image - uses: docker/build-push-action@v6 - with: - context: . - file: apps/start/Dockerfile - push: true - cache-from: type=gha - cache-to: type=gha,mode=max - tags: | - ghcr.io/${{ env.repo_owner }}/dashboard:${{ steps.tags.outputs.branch_name }}-${{ steps.tags.outputs.short_sha }} - build-args: | - NO_CLOUDFLARE=1 - - - name: Create/Update Dashboard tag - if: github.ref == 'refs/heads/main' - run: | - # Delete existing tag if it exists - if git tag -l "dashboard" | grep -q "dashboard"; then - git tag -d "dashboard" - echo "Deleted local tag: dashboard" - fi - - # Create new tag - git tag "dashboard" "${{ github.sha }}" - echo "Created tag: dashboard" - - # Push tag to remote - git push origin "dashboard" --force - echo "Pushed tag: dashboard" diff --git a/apps/start/Dockerfile b/apps/start/Dockerfile index 533631cb..ad8be58b 100644 --- a/apps/start/Dockerfile +++ b/apps/start/Dockerfile @@ -48,6 +48,7 @@ FROM --platform=$BUILDPLATFORM node:${NODE_VERSION}-slim AS base-build ENV COREPACK_INTEGRITY_KEYS=0 +# Keep C++ build tools ONLY in the native build stage RUN rm -f /usr/local/bin/pnpm /usr/local/bin/pnpx && npm install -g pnpm@10.6.2 && apt-get update && \ apt-get install -y --no-install-recommends \ ca-certificates \ @@ -96,20 +97,16 @@ COPY apps/start ./apps/start COPY packages ./packages COPY tooling ./tooling -# Generate Prisma client and build the app +# Generate Prisma client and build the app natively RUN pnpm --filter start run build # PROD - Install only production dependencies FROM base AS prod -ENV npm_config_build_from_source=true - -RUN apt-get update && apt-get install -y --no-install-recommends \ - python3 \ - make \ - g++ && \ - apt-get clean && \ - rm -rf /var/lib/apt/lists/* +# FIX: +# Removed `npm_config_build_from_source`, `python3`, `make`, `g++`, and `pnpm rebuild`. +# This allows pnpm to instantly download pre-compiled AMD64 binaries instead of forcing +# QEMU to cross-compile C++ code on your Raspberry Pi. WORKDIR /app COPY --from=build /app/package.json ./ @@ -131,16 +128,14 @@ COPY --from=build /app/packages/integrations/package.json ./packages/integration COPY --from=build /app/packages/sdks/_info/package.json ./packages/sdks/_info/ COPY --from=build /app/patches ./patches -# Install production dependencies only +# Install production dependencies only (fetches prebuilt binaries fast) RUN pnpm install --frozen-lockfile --prod && \ - pnpm rebuild && \ pnpm store prune # FINAL - Minimal runtime image FROM base AS runner ENV NODE_ENV=production -ENV npm_config_build_from_source=true WORKDIR /app