diff --git a/.github/workflows/release-publish.yml b/.github/workflows/release-publish.yml index 9196a7fccb047..f0115901d54b1 100644 --- a/.github/workflows/release-publish.yml +++ b/.github/workflows/release-publish.yml @@ -1,20 +1,19 @@ -name: 'Release: Publish' +name: 'Build and Publish Docker Image' on: - pull_request: - types: - - closed + push: branches: - - 'release/*' + - 'feat/*' jobs: publish-to-npm: name: Publish to NPM runs-on: ubuntu-latest - if: github.event.pull_request.merged == true timeout-minutes: 10 permissions: id-token: write + contents: read + packages: write env: NPM_CONFIG_PROVENANCE: true outputs: @@ -24,7 +23,6 @@ jobs: uses: actions/checkout@v4.1.1 with: fetch-depth: 0 - - run: corepack enable - uses: actions/setup-node@v4.0.2 with: @@ -54,133 +52,39 @@ jobs: node .github/scripts/ensure-provenance-fields.mjs sed -i "s/default: 'dev'/default: 'stable'/g" packages/cli/dist/config/schema.js pnpm publish -r --publish-branch ${{github.event.pull_request.base.ref}} --access public --tag rc --no-git-checks - npm dist-tag rm n8n rc - id: set-release run: echo "release=${{ env.RELEASE }}" >> $GITHUB_OUTPUT - publish-to-docker-hub: - name: Publish to DockerHub + build-and-push: needs: [publish-to-npm] runs-on: ubuntu-latest - if: github.event.pull_request.merged == true - timeout-minutes: 10 steps: - - name: Checkout - uses: actions/checkout@v4.1.1 - with: - fetch-depth: 0 - - - name: Set up QEMU - uses: docker/setup-qemu-action@v3.0.0 - - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3.0.0 - - - name: Login to GitHub Container Registry - uses: docker/login-action@v3.0.0 - with: - registry: ghcr.io - username: ${{ github.actor }} - password: ${{ secrets.GITHUB_TOKEN }} - - - name: Login to DockerHub - uses: docker/login-action@v3.0.0 - with: - username: ${{ secrets.DOCKER_USERNAME }} - password: ${{ secrets.DOCKER_PASSWORD }} - - - name: Build - uses: docker/build-push-action@v5.1.0 - with: - context: ./docker/images/n8n - build-args: | + - name: Checkout repository + uses: actions/checkout@v4.1.1 + with: + fetch-depth: 0 + + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3.0.0 + + - name: Login to Docker Hub + uses: docker/login-action@v3.0.0 + with: + username: ${{ secrets.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_PASSWORD }} + + - name: Build and Push Docker Image + uses: docker/build-push-action@v5.1.0 + with: + context: ./docker/images/n8n + build-args: | N8N_VERSION=${{ needs.publish-to-npm.outputs.release }} - platforms: linux/amd64,linux/arm64 - provenance: false - push: true - tags: | - ${{ secrets.DOCKER_USERNAME }}/n8n:${{ needs.publish-to-npm.outputs.release }} - ghcr.io/${{ github.repository_owner }}/n8n:${{ needs.publish-to-npm.outputs.release }} - - create-github-release: - name: Create a GitHub Release - needs: [publish-to-npm, publish-to-docker-hub] - runs-on: ubuntu-latest - if: github.event.pull_request.merged == true - timeout-minutes: 5 - - permissions: - contents: write - id-token: write - - steps: - - name: Create a Release on GitHub - uses: ncipollo/release-action@v1 - with: - commit: ${{github.event.pull_request.base.ref}} - tag: 'n8n@${{ needs.publish-to-npm.outputs.release }}' - prerelease: true - makeLatest: false - body: ${{github.event.pull_request.body}} - - create-sentry-release: - name: Create a Sentry Release - needs: [publish-to-npm, publish-to-docker-hub] - runs-on: ubuntu-latest - if: github.event.pull_request.merged == true - timeout-minutes: 5 - env: - SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} - SENTRY_ORG: ${{ secrets.SENTRY_ORG }} - - steps: - - uses: actions/checkout@v4.1.1 - - name: Restore cached build artifacts - uses: actions/cache/restore@v4.0.0 - with: - path: ./packages/**/dist - key: ${{ github.sha }}-release:build - - - name: Create a frontend release - uses: getsentry/action-release@v1.7.0 - continue-on-error: true - with: - projects: ${{ secrets.SENTRY_FRONTEND_PROJECT }} - version: ${{ needs.publish-to-npm.outputs.release }} - sourcemaps: packages/editor-ui/dist - - - name: Create a backend release - uses: getsentry/action-release@v1.7.0 - continue-on-error: true - with: - projects: ${{ secrets.SENTRY_BACKEND_PROJECT }} - version: ${{ needs.publish-to-npm.outputs.release }} - sourcemaps: packages/cli/dist packages/core/dist packages/nodes-base/dist packages/@n8n/n8n-nodes-langchain/dist - - trigger-release-note: - name: Trigger a release note - needs: [publish-to-npm, create-github-release] - if: github.event.pull_request.merged == true - runs-on: ubuntu-latest - steps: - - name: Trigger a release note - run: curl -u docsWorkflows:${{ secrets.N8N_WEBHOOK_DOCS_PASSWORD }} --request GET 'https://internal.users.n8n.cloud/webhook/trigger-release-note' --header 'Content-Type:application/json' --data '{"version":"${{ needs.publish-to-npm.outputs.release }}"}' + platforms: linux/amd64,linux/arm64 + provenance: false + push: true + tags: | + ${{ secrets.DOCKERHUB_USERNAME }}/n8n:${{ needs.publish-to-npm.outputs.release }} + docker.io/${{ github.repository_owner }}/n8n:${{ needs.publish-to-npm.outputs.release }} - # merge-back-into-master: - # name: Merge back into master - # needs: [publish-to-npm, create-github-release] - # if: ${{ github.event.pull_request.merged == true && !contains(github.event.pull_request.labels.*.name, 'release:patch') }} - # runs-on: ubuntu-latest - # steps: - # - uses: actions/checkout@v4.1.1 - # with: - # fetch-depth: 0 - # - run: | - # git checkout --track origin/master - # git config user.name "github-actions[bot]" - # git config user.email 41898282+github-actions[bot]@users.noreply.github.com - # git merge --ff n8n@${{ needs.publish-to-npm.outputs.release }} - # git push origin master - # git push origin :${{github.event.pull_request.base.ref}}