name: Build & Push Docker Images on: push: branches: [main] pull_request: branches: [main] env: REGISTRY: code.letsbe.solutions IMAGE_APP: letsbe/pn-new-crm/crm-app IMAGE_WORKER: letsbe/pn-new-crm/crm-worker jobs: lint: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: actions/setup-node@v4 with: node-version: 20 - name: Install pnpm run: corepack enable && corepack prepare pnpm@latest --activate - name: Install dependencies run: pnpm install --frozen-lockfile - name: Lint run: pnpm lint - name: Type check run: pnpm exec tsc --noEmit build-and-push: runs-on: ubuntu-latest needs: lint if: github.event_name == 'push' && github.ref == 'refs/heads/main' steps: - uses: actions/checkout@v4 - name: Log in to Gitea Container Registry uses: docker/login-action@v3 with: registry: ${{ env.REGISTRY }} username: ${{ secrets.REGISTRY_USER }} password: ${{ secrets.REGISTRY_TOKEN }} - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - name: Build & push crm-app uses: docker/build-push-action@v5 with: context: . file: ./Dockerfile push: true tags: | ${{ env.REGISTRY }}/${{ env.IMAGE_APP }}:latest ${{ env.REGISTRY }}/${{ env.IMAGE_APP }}:${{ github.sha }} cache-from: type=registry,ref=${{ env.REGISTRY }}/${{ env.IMAGE_APP }}:buildcache cache-to: type=registry,ref=${{ env.REGISTRY }}/${{ env.IMAGE_APP }}:buildcache,mode=max - name: Build & push crm-worker uses: docker/build-push-action@v5 with: context: . file: ./Dockerfile.worker push: true tags: | ${{ env.REGISTRY }}/${{ env.IMAGE_WORKER }}:latest ${{ env.REGISTRY }}/${{ env.IMAGE_WORKER }}:${{ github.sha }} cache-from: type=registry,ref=${{ env.REGISTRY }}/${{ env.IMAGE_WORKER }}:buildcache cache-to: type=registry,ref=${{ env.REGISTRY }}/${{ env.IMAGE_WORKER }}:buildcache,mode=max deploy: runs-on: ubuntu-latest needs: build-and-push if: github.event_name == 'push' && github.ref == 'refs/heads/main' steps: - uses: actions/checkout@v4 - name: Deploy to server via SSH uses: appleboy/ssh-action@v1 with: host: ${{ secrets.DEPLOY_HOST }} username: ${{ secrets.DEPLOY_USER }} key: ${{ secrets.DEPLOY_SSH_KEY }} script: | cd ${{ secrets.DEPLOY_PATH }} docker login ${{ env.REGISTRY }} -u ${{ secrets.REGISTRY_USER }} -p ${{ secrets.REGISTRY_TOKEN }} docker compose -f docker-compose.prod.yml pull crm-app crm-worker docker compose -f docker-compose.prod.yml up -d --no-deps crm-app crm-worker docker image prune -f