name: Jellyseerr CI on: pull_request: branches: - '*' push: branches: - develop jobs: test: name: Lint & Test Build if: github.event_name == 'pull_request' runs-on: ubuntu-24.04 container: node:22-alpine steps: - name: Checkout uses: actions/checkout@v4 - name: Pnpm Setup uses: pnpm/action-setup@v4 with: version: 9 - name: Get pnpm store directory shell: sh run: | echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV - name: Setup pnpm cache uses: actions/cache@v4 with: path: ${{ env.STORE_PATH }} key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} restore-keys: | ${{ runner.os }}-pnpm-store- - name: Install dependencies env: HUSKY: 0 run: pnpm install - name: Lint run: pnpm lint - name: Formatting run: pnpm format:check - name: Build run: pnpm build build_and_push: name: Build & Publish Docker Images if: github.ref == 'refs/heads/develop' && !contains(github.event.head_commit.message, '[skip ci]') strategy: matrix: include: - runner: ubuntu-24.04 platform: linux/amd64 - runner: ubuntu-24.04-arm platform: linux/arm64 runs-on: ${{ matrix.runner }} steps: - name: Checkout uses: actions/checkout@v4 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - name: Log in to Docker Hub uses: docker/login-action@v3 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_TOKEN }} - name: Log in to GitHub Container Registry uses: docker/login-action@v3 with: registry: ghcr.io username: ${{ github.repository_owner }} password: ${{ secrets.GITHUB_TOKEN }} - name: Sanitize Owner and Platform name run: | echo "OWNER_LC=${OWNER,,}" >>${GITHUB_ENV} echo "PLATFORM=$(echo '${PLATFORM}' | sed 's|/|-|g')" >> $GITHUB_ENV env: OWNER: ${{ github.repository_owner }} PLATFORM: ${{ matrix.platform }} - name: Build architecture specific images uses: docker/build-push-action@v5 with: context: . file: ./Dockerfile # platforms: linux/amd64,linux/arm64 platforms: ${{ matrix.platform }} # dont push until merged push: false build-args: | COMMIT_TAG=${{ github.sha }} tags: | fallenbagel/jellyseerr:develop-${{ env.PLATFORM }} ghcr.io/${{ env.OWNER_LC }}/jellyseerr:develop-${{ env.PLATFORM }} cache-from: type=gha,scope=${{ matrix.platform }} cache-to: type=gha,mode=max,scope=${{ matrix.platform }} provenance: false create_manifest: name: Create Multi-Architecture Image needs: build_and_push runs-on: ubuntu-24.04 steps: - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - name: Create and Push Multi-Architecture Image uses: docker/build-push-action@v5 with: images: | fallenbagel/jellyseerr:develop-linux-amd64 fallenbagel/jellyseerr:develop-linux-arm64 ghcr.io/${{ github.repository_owner }}/jellyseerr:develop-linux-amd64 ghcr.io/${{ github.repository_owner }}/jellyseerr:develop-linux-arm64 target: | fallenbagel/jellyseerr:develop ghcr.io/fallenbagel/jellyseerr:develop - name: Inspect Manifest run: | docker buildx imagetools inspect fallenbagel/jellyseerr:develop docker buildx imagetools inspect ghcr.io/fallenbagel/jellyseerr:develop discord: name: Send Discord Notification needs: build_and_push if: always() && github.event_name != 'pull_request' && !contains(github.event.head_commit.message, '[skip ci]') runs-on: ubuntu-24.04 steps: - name: Get Build Job Status uses: technote-space/workflow-conclusion-action@v3 - name: Combine Job Status id: status run: | failures=(neutral, skipped, timed_out, action_required) if [[ ${array[@]} =~ $WORKFLOW_CONCLUSION ]]; then echo "status=failure" >> $GITHUB_OUTPUT else echo "status=$WORKFLOW_CONCLUSION" >> $GITHUB_OUTPUT fi - name: Post Status to Discord uses: sarisia/actions-status-discord@v1 with: webhook: ${{ secrets.DISCORD_WEBHOOK }} status: ${{ steps.status.outputs.status }} title: ${{ github.workflow }} nofail: true