From 9e81c9feb65a34d49ce50faa823819fef4b5907a Mon Sep 17 00:00:00 2001 From: mposolda Date: Mon, 9 Dec 2024 13:19:38 +0100 Subject: [PATCH] Create workflows to release Node.js adapter from own repo closes #520 Signed-off-by: mposolda Co-authored-by: Jon Koops Signed-off-by: Marek Posolda --- .github/workflows/release-nightly.yml | 18 +++++ .github/workflows/release.yml | 21 +++++ .github/workflows/x-release.yml | 107 ++++++++++++++++++++++++++ release.sh | 23 ------ 4 files changed, 146 insertions(+), 23 deletions(-) create mode 100644 .github/workflows/release-nightly.yml create mode 100644 .github/workflows/release.yml create mode 100644 .github/workflows/x-release.yml delete mode 100755 release.sh diff --git a/.github/workflows/release-nightly.yml b/.github/workflows/release-nightly.yml new file mode 100644 index 00000000..c4d5975c --- /dev/null +++ b/.github/workflows/release-nightly.yml @@ -0,0 +1,18 @@ +name: Release Nightly + +on: + schedule: + - cron: '0 0 * * *' + workflow_dispatch: + +jobs: + + release-nightly: + name: Nightly release + if: github.event_name != 'schedule' || github.repository == 'keycloak/keycloak-nodejs-connect' + uses: ./.github/workflows/x-release.yml + with: + gh-org: keycloak + branch: ${{ github.ref_name }} + tag: nightly + nightly: true diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 00000000..c66319b5 --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,21 @@ +name: Release + +on: + workflow_dispatch: + inputs: + version: + description: Release version + required: true + +jobs: + + release: + name: Release + uses: ./.github/workflows/x-release.yml + with: + gh-org: keycloak + branch: ${{ github.ref_name }} + tag: ${{ inputs.version }} + nightly: false + secrets: + NPM_TOKEN: ${{ secrets.NPM_TOKEN }} diff --git a/.github/workflows/x-release.yml b/.github/workflows/x-release.yml new file mode 100644 index 00000000..a4a35068 --- /dev/null +++ b/.github/workflows/x-release.yml @@ -0,0 +1,107 @@ +name: X Release + +on: + workflow_call: + inputs: + gh-org: + required: true + type: string + branch: + required: true + type: string + tag: + required: true + type: string + nightly: + required: true + type: boolean + secrets: + NPM_TOKEN: + required: false + +concurrency: rel-${{ github.ref }} + +defaults: + run: + shell: bash + +jobs: + + release-impl: + runs-on: ubuntu-latest + steps: + - name: Checkout repository + uses: actions/checkout@v4 + with: + ref: ${{ inputs.branch }} + + - name: Setup Node.js + uses: actions/setup-node@v4 + with: + node-version: 22 + check-latest: true + registry-url: https://registry.npmjs.org + + - name: Create version commit + if: ${{ !inputs.nightly }} + run: | + git config --global user.email "github-actions[bot]@users.noreply.github.com" + git config --global user.name "github-actions[bot]" + npm version ${{ inputs.tag }} -m "Set version to ${{ inputs.tag }}" + + - name: Tag commit + run: git tag ${{ inputs.tag }} + + - name: Push changes + run: git push --force origin refs/tags/${{ inputs.tag }} + + - name: Check if release exists + id: release-exists + run: > + echo "release-exists=$( + if ( gh release view ${{ inputs.tag }} --repo ${{ inputs.gh-org }}/keycloak-nodejs-connect &> /dev/null ); then + echo 'true' + else + echo 'false' + fi + )" >> "$GITHUB_OUTPUT" + + - name: Create a github release + if: steps.release-exists.outputs.release-exists == 'false' + run: gh release create ${{ inputs.tag }} --repo ${{ inputs.gh-org }}/keycloak-nodejs-connect --title ${{ inputs.tag }} --draft ${{ inputs.nightly && '--prerelease' || '' }} + env: + GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} + + - name: Create package tarball + run: | + npm pack + mv -T *.tgz keycloak-nodejs-connect.tgz + + - name: Upload to GitHub Releases + run: | + for i in `gh release view ${{ inputs.tag }} --json assets --jq '.assets[].name'`; do + test -f $i || gh release delete-asset ${{ inputs.tag }} $i -y + done + gh release upload ${{ inputs.tag }} keycloak-nodejs-connect.tgz --clobber + env: + GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} + + - name: Publish release + run: gh release edit ${{ inputs.tag }} --repo ${{ inputs.gh-org }}/keycloak-nodejs-connect --draft=false + env: + GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} + + - name: Show Output Github + run: | + echo "https://github.com/${{ inputs.gh-org }}/keycloak-nodejs-connect/tree/${{ inputs.tag }} " >> $GITHUB_STEP_SUMMARY + echo "https://github.com/${{ inputs.gh-org }}/keycloak-nodejs-connect/releases/tag/${{ inputs.tag }} " >> $GITHUB_STEP_SUMMARY + + - name: Publish to NPM + if: ${{ !inputs.nightly }} + run: npm publish keycloak-nodejs-connect.tgz --access public --ignore-scripts ${{ inputs.gh-org != 'keycloak' && ' --dry-run' || '' }} + env: + NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} + + - name: Show Output NPM + if: ${{ !inputs.nightly && inputs.gh-org == 'keycloak' }} + run: echo "https://www.npmjs.com/package/keycloak-connect/v/${{ inputs.tag }} " >> $GITHUB_STEP_SUMMARY diff --git a/release.sh b/release.sh deleted file mode 100755 index ce5fa4db..00000000 --- a/release.sh +++ /dev/null @@ -1,23 +0,0 @@ -#!/bin/bash -e - -DIR="$PWD" -VERSION=`./get-version.sh` -echo "Version: $VERSION" - -echo "------------------------------------------------------------------------------------------------------------" -echo "Building:" -echo "" - -npm install - - -echo "------------------------------------------------------------------------------------------------------------" -echo "NPM public:" -echo "" - -npm publish - - -echo "------------------------------------------------------------------------------------------------------------" -echo "Done" -echo "------------------------------------------------------------------------------------------------------------"