From 7733f682c5fd09a5f8abb6f0140f36126f222bef Mon Sep 17 00:00:00 2001 From: Savitha Raghunathan Date: Wed, 30 Oct 2024 11:22:01 -0400 Subject: [PATCH 1/6] adding release flag Signed-off-by: Savitha Raghunathan --- create-release/action.yml | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/create-release/action.yml b/create-release/action.yml index edbd9bb..6a53465 100644 --- a/create-release/action.yml +++ b/create-release/action.yml @@ -18,7 +18,11 @@ inputs: ref: description: 'The branch or SHA for the release (defaults to main)' required: false - default: ${{ github.ref }} + skip_release: + description: 'Skip creating the release and only generate the changelog' + required: false + default: 'false' + outputs: breaking-changes: description: "Breaking changes introduced in this release" @@ -151,6 +155,7 @@ runs: id: changelog - uses: ncipollo/release-action@main + if: ${{ inputs.skip_release == 'false' }} with: owner: ${{ steps.changelog.outputs.owner }} repo: ${{ steps.changelog.outputs.repo }} From d3493417f311ec0b445826c6810d24eb6efb104f Mon Sep 17 00:00:00 2001 From: Savitha Raghunathan Date: Wed, 30 Oct 2024 12:25:11 -0400 Subject: [PATCH 2/6] removing unused create release workflow Signed-off-by: Savitha Raghunathan --- .github/workflows/create-release.yml | 132 --------------------------- 1 file changed, 132 deletions(-) delete mode 100644 .github/workflows/create-release.yml diff --git a/.github/workflows/create-release.yml b/.github/workflows/create-release.yml deleted file mode 100644 index db0fb31..0000000 --- a/.github/workflows/create-release.yml +++ /dev/null @@ -1,132 +0,0 @@ -name: Reusable Create release - -on: - workflow_call: - inputs: - version: - description: 'Semantic version of the release (eg. v1.2.3 or v1.2.3-alpha.1)' - required: true - type: string - repository: - description: 'The repository where the release should be created' - required: false - default: ${{ github.repository }} - type: string - ref: - description: 'The branch or SHA for the release (defaults to main)' - required: false - default: ${{ github.ref }} - type: string - skip_release: - description: 'Skip creating the release and only generate the changelog' - required: false - default: false - type: boolean - secrets: - token: - description: 'The token to use when interacting with GitHub' - required: true - -env: - GITHUB_TOKEN: ${{ secrets.token }} - -jobs: - release: - runs-on: ubuntu-latest - steps: - - name: Verify tag is semver - run: | - set -x - if [[ ! "${{ inputs.version }}" =~ ^v[0-9]+\.[0-9]+\.[0-9]+(-[0-9A-Za-z-]+(\.[0-9A-Za-z-]+)*)?$ ]]; then - echo "This is not a semver compliant tag" - echo "Exiting" - exit 1 - fi - - if [[ "${{ inputs.version }}" =~ ^v[0-9]+\.[0-9]+\.[0-9]+$ ]]; then - echo "is_prerelease=false" >> "$GITHUB_OUTPUT" - else - echo "is_prerelease=true" >> "$GITHUB_OUTPUT" - fi - - if [[ "${{ inputs.version }}" =~ ^v[0-9]+\.[0-9]+\.0$ ]]; then - echo "is_dotzero=true" >> "$GITHUB_OUTPUT" - else - echo "is_dotzero=false" >> "$GITHUB_OUTPUT" - fi - - XY_VERSION=$(echo ${{ inputs.version }} | awk -F. '{print substr($1,2)"."$2}') - echo "xy_version=${XY_VERSION}" >> "$GITHUB_OUTPUT" - id: check_tag - - - name: Checkout code - uses: actions/checkout@v4 - with: - fetch-depth: 0 - repository: ${{ inputs.repository }} - ref: ${{ inputs.ref }} - path: ${{ inputs.repository }} - token: ${{ secrets.token }} - - - name: Make changelog - working-directory: ./${{ inputs.repository }} - run: | - set -x - - # Details we need in order to create the release - REPOSITORY=${{ inputs.repository }} - echo "owner=${REPOSITORY%/*}" >> "$GITHUB_OUTPUT" - echo "repo=${REPOSITORY#*/}" >> "$GITHUB_OUTPUT" - SHA=$(git rev-parse HEAD) - echo "sha=${SHA}" >> "$GITHUB_OUTPUT" - - # Always compare to latest published full release for repository - PREV_TAG=$(gh api -H "Accept: application/vnd.github+json" -H "X-GitHub-Api-Version: 2022-11-28" /repos/${{ inputs.repository }}/releases/latest | jq -r '.tag_name') - filterfunc() { git log --pretty=format:%s "${PREV_TAG}..HEAD" | grep "^\s*:$1:" | sed "s/^\s*:$1:\s*/ * /"; } - # Handle scenario where no previous tag exists - if [ -z "${PREV_TAG}" ]; then - filterfunc() { git log --pretty=format:%s | grep "^\s*:$1:" | sed "s/^\s*:$1:\s*/ * /"; } - fi - - RELEASE_DOC="${PWD}/release.md" - echo "release_doc=${RELEASE_DOC}" >> "$GITHUB_ENV" - - BREAKING_CHANGES="$(filterfunc warning)" - if [ -n "${BREAKING_CHANGES}" ]; then - echo -e "## :warning: Breaking Changes\n${BREAKING_CHANGES}\n\n" >> "${RELEASE_DOC}" - fi - - FEATURE_CHANGES="$(filterfunc sparkles)" - if [ -n "${FEATURE_CHANGES}" ]; then - echo -e "## :sparkles: Features\n${FEATURE_CHANGES}\n\n" >> "${RELEASE_DOC}" - fi - - BUG_FIXES="$(filterfunc bug)" - if [ -n "${BUG_FIXES}" ]; then - echo -e "## :bug: Bug Fixes\n${BUG_FIXES}\n\n" >> "${RELEASE_DOC}" - fi - - # Add contributors as GitHub would have added them - gh api \ - --method POST \ - -H "Accept: application/vnd.github+json" \ - -H "X-GitHub-Api-Version: 2022-11-28" \ - /repos/${{ inputs.repository }}/releases/generate-notes \ - -f tag_name="${{ inputs.version }}" \ - -f target_commitish="${{ inputs.ref }}" \ - -f previous_tag_name="${PREV_TAG}" | jq -r '.body' | grep -Pzo '.*Contributors(.*\n)*' >> "${RELEASE_DOC}" - id: changelog - - - name: Create Release - if: ${{ inputs.skip_release == false }} - uses: ncipollo/release-action@main - with: - owner: ${{ steps.changelog.outputs.owner }} - repo: ${{ steps.changelog.outputs.repo }} - tag: ${{ inputs.version }} - commit: ${{ steps.changelog.outputs.sha }} - bodyFile: ${{ env.release_doc }} - draft: false - prerelease: ${{ steps.check_tag.outputs.is_prerelease }} - skipIfReleaseExists: true - token: ${{ secrets.token }} From 5406e5468f97b4c9f81359189937de5c99ddf0cd Mon Sep 17 00:00:00 2001 From: Savitha Raghunathan Date: Fri, 1 Nov 2024 12:51:00 -0400 Subject: [PATCH 3/6] adding changelog workflow Signed-off-by: Savitha Raghunathan --- .github/workflows/generate-changelog.yml | 104 +++++++++++++++++++++++ create-release/action.yml | 9 +- 2 files changed, 106 insertions(+), 7 deletions(-) create mode 100644 .github/workflows/generate-changelog.yml diff --git a/.github/workflows/generate-changelog.yml b/.github/workflows/generate-changelog.yml new file mode 100644 index 0000000..184b6dc --- /dev/null +++ b/.github/workflows/generate-changelog.yml @@ -0,0 +1,104 @@ +name: Generate Changelog + +on: + workflow_call: + inputs: + version: + description: 'Semantic version of the release (e.g., v1.2.3)' + required: true + type: string + prev_version: + description: 'Previous release version (e.g., v1.2.2)' + required: false + default: '' + type: string + repository: + description: 'Repository name' + required: false + default: ${{ github.repository }} + type: string + ref: + description: 'Branch or SHA for the release' + required: false + default: ${{ github.ref }} + type: string + secrets: + token: + description: 'GitHub token' + required: true + +jobs: + changelog: + runs-on: ubuntu-latest + steps: + - name: Checkout repository + uses: actions/checkout@v4 + with: + token: ${{ secrets.token }} + repository: ${{ inputs.repository }} + ref: ${{ inputs.ref }} + + - name: Generate Changelog + id: changelog + env: + GITHUB_TOKEN: ${{ secrets.token }} + run: | + set -x + + REPOSITORY=${{ inputs.repository }} + SHA=$(git rev-parse HEAD) + echo "sha=${SHA}" >> $GITHUB_OUTPUT + + # Get the previous tag + if [ -n "${{ inputs.prev_version }}" ] && git rev-list ${{ inputs.prev_version }} 2> /dev/null; then + PREV_TAG="${{ inputs.prev_version }}" + else + PREV_TAG=$(gh api -H "Accept: application/vnd.github+json" /repos/${{ inputs.repository }}/releases/latest | jq -r '.tag_name // empty') + fi + + # Generate release notes + NOTES=$(gh api --method POST \ + -H "Accept: application/vnd.github+json" \ + /repos/${{ inputs.repository }}/releases/generate-notes \ + -f tag_name="${{ inputs.version }}" \ + -f target_commitish="${SHA}" \ + -f previous_tag_name="${PREV_TAG}" | jq -r '.body') + + RELEASE_DOC="${PWD}/release.md" + echo "**Full Changelog**: https://github.com/${REPOSITORY}/commits/${{ inputs.version }}" > "${RELEASE_DOC}" + + filterfunc() { echo "${NOTES}" | grep "^*\s*:$1:" | sed "s/.*:$1:\s*/* /"; } + + BREAKING_CHANGES="$(filterfunc warning)" + if [ -n "${BREAKING_CHANGES}" ]; then + echo "## :warning: Breaking Changes" >> ${RELEASE_DOC} + echo "${BREAKING_CHANGES}" >> ${RELEASE_DOC} + echo "" >> ${RELEASE_DOC} + fi + + FEATURE_CHANGES="$(filterfunc sparkles)" + if [ -n "${FEATURE_CHANGES}" ]; then + echo "## :sparkles: Features" >> ${RELEASE_DOC} + echo "${FEATURE_CHANGES}" >> ${RELEASE_DOC} + echo "" >> ${RELEASE_DOC} + fi + + BUG_FIXES="$(filterfunc bug)" + if [ -n "${BUG_FIXES}" ]; then + echo "## :bug: Bug Fixes" >> ${RELEASE_DOC} + echo "${BUG_FIXES}" >> ${RELEASE_DOC} + echo "" >> ${RELEASE_DOC} + fi + + NEW_CONTRIB=$(echo "${NOTES}" | sed -n "/Contributors/,\$p") + if [ -n "${NEW_CONTRIB}" ]; then + echo "${NEW_CONTRIB}" >> ${RELEASE_DOC} + else + echo "${NOTES}" | sed -n "/Changelog/,\$p" >> ${RELEASE_DOC} + fi + + - name: Upload Changelog Artifact + uses: actions/upload-artifact@v4 + with: + name: changelog-artifact + path: release.md \ No newline at end of file diff --git a/create-release/action.yml b/create-release/action.yml index 6a53465..46c8e6e 100644 --- a/create-release/action.yml +++ b/create-release/action.yml @@ -18,11 +18,7 @@ inputs: ref: description: 'The branch or SHA for the release (defaults to main)' required: false - skip_release: - description: 'Skip creating the release and only generate the changelog' - required: false - default: 'false' - + default: ${{ github.ref }} outputs: breaking-changes: description: "Breaking changes introduced in this release" @@ -155,7 +151,6 @@ runs: id: changelog - uses: ncipollo/release-action@main - if: ${{ inputs.skip_release == 'false' }} with: owner: ${{ steps.changelog.outputs.owner }} repo: ${{ steps.changelog.outputs.repo }} @@ -165,4 +160,4 @@ runs: draft: false prerelease: ${{ steps.check_tag.outputs.is_prerelease }} skipIfReleaseExists: true - token: ${{ inputs.github_token }} + token: ${{ inputs.github_token }} \ No newline at end of file From 9c45b991f31f47ee0fe314c8aa4c514f2edb898f Mon Sep 17 00:00:00 2001 From: Savitha Raghunathan Date: Fri, 1 Nov 2024 12:56:42 -0400 Subject: [PATCH 4/6] fix lint errors Signed-off-by: Savitha Raghunathan --- .github/workflows/generate-changelog.yml | 44 ++++++++++++------------ 1 file changed, 22 insertions(+), 22 deletions(-) diff --git a/.github/workflows/generate-changelog.yml b/.github/workflows/generate-changelog.yml index 184b6dc..893a101 100644 --- a/.github/workflows/generate-changelog.yml +++ b/.github/workflows/generate-changelog.yml @@ -34,32 +34,32 @@ jobs: - name: Checkout repository uses: actions/checkout@v4 with: - token: ${{ secrets.token }} - repository: ${{ inputs.repository }} - ref: ${{ inputs.ref }} + token: "${{ secrets.token }}" + repository: "${{ inputs.repository }}" + ref: "${{ inputs.ref }}" - name: Generate Changelog id: changelog env: - GITHUB_TOKEN: ${{ secrets.token }} + GITHUB_TOKEN: "${{ secrets.token }}" run: | set -x - REPOSITORY=${{ inputs.repository }} - SHA=$(git rev-parse HEAD) - echo "sha=${SHA}" >> $GITHUB_OUTPUT + REPOSITORY="${{ inputs.repository }}" + SHA="$(git rev-parse HEAD)" + echo "sha=${SHA}" >> "$GITHUB_OUTPUT" # Get the previous tag - if [ -n "${{ inputs.prev_version }}" ] && git rev-list ${{ inputs.prev_version }} 2> /dev/null; then + if [ -n "${{ inputs.prev_version }}" ] && git rev-list "${{ inputs.prev_version }}" 2> /dev/null; then PREV_TAG="${{ inputs.prev_version }}" else - PREV_TAG=$(gh api -H "Accept: application/vnd.github+json" /repos/${{ inputs.repository }}/releases/latest | jq -r '.tag_name // empty') + PREV_TAG=$(gh api -H "Accept: application/vnd.github+json" "/repos/${{ inputs.repository }}/releases/latest" | jq -r '.tag_name // empty') fi # Generate release notes NOTES=$(gh api --method POST \ -H "Accept: application/vnd.github+json" \ - /repos/${{ inputs.repository }}/releases/generate-notes \ + "/repos/${{ inputs.repository }}/releases/generate-notes" \ -f tag_name="${{ inputs.version }}" \ -f target_commitish="${SHA}" \ -f previous_tag_name="${PREV_TAG}" | jq -r '.body') @@ -71,34 +71,34 @@ jobs: BREAKING_CHANGES="$(filterfunc warning)" if [ -n "${BREAKING_CHANGES}" ]; then - echo "## :warning: Breaking Changes" >> ${RELEASE_DOC} - echo "${BREAKING_CHANGES}" >> ${RELEASE_DOC} - echo "" >> ${RELEASE_DOC} + echo "## :warning: Breaking Changes" >> "${RELEASE_DOC}" + echo "${BREAKING_CHANGES}" >> "${RELEASE_DOC}" + echo "" >> "${RELEASE_DOC}" fi FEATURE_CHANGES="$(filterfunc sparkles)" if [ -n "${FEATURE_CHANGES}" ]; then - echo "## :sparkles: Features" >> ${RELEASE_DOC} - echo "${FEATURE_CHANGES}" >> ${RELEASE_DOC} - echo "" >> ${RELEASE_DOC} + echo "## :sparkles: Features" >> "${RELEASE_DOC}" + echo "${FEATURE_CHANGES}" >> "${RELEASE_DOC}" + echo "" >> "${RELEASE_DOC}" fi BUG_FIXES="$(filterfunc bug)" if [ -n "${BUG_FIXES}" ]; then - echo "## :bug: Bug Fixes" >> ${RELEASE_DOC} - echo "${BUG_FIXES}" >> ${RELEASE_DOC} - echo "" >> ${RELEASE_DOC} + echo "## :bug: Bug Fixes" >> "${RELEASE_DOC}" + echo "${BUG_FIXES}" >> "${RELEASE_DOC}" + echo "" >> "${RELEASE_DOC}" fi NEW_CONTRIB=$(echo "${NOTES}" | sed -n "/Contributors/,\$p") if [ -n "${NEW_CONTRIB}" ]; then - echo "${NEW_CONTRIB}" >> ${RELEASE_DOC} + echo "${NEW_CONTRIB}" >> "${RELEASE_DOC}" else - echo "${NOTES}" | sed -n "/Changelog/,\$p" >> ${RELEASE_DOC} + echo "${NOTES}" | sed -n "/Changelog/,\$p" >> "${RELEASE_DOC}" fi - name: Upload Changelog Artifact uses: actions/upload-artifact@v4 with: name: changelog-artifact - path: release.md \ No newline at end of file + path: release.md From dbc3efa18688aa3d6cc8e8684f52195ef0a87f0a Mon Sep 17 00:00:00 2001 From: Savitha Raghunathan Date: Mon, 4 Nov 2024 14:48:32 -0500 Subject: [PATCH 5/6] integrate changelog into rel action Signed-off-by: Savitha Raghunathan --- .github/workflows/generate-changelog.yml | 9 +- create-release/action.yml | 125 ++++------------------- 2 files changed, 27 insertions(+), 107 deletions(-) diff --git a/.github/workflows/generate-changelog.yml b/.github/workflows/generate-changelog.yml index 893a101..ef2dfca 100644 --- a/.github/workflows/generate-changelog.yml +++ b/.github/workflows/generate-changelog.yml @@ -22,10 +22,11 @@ on: required: false default: ${{ github.ref }} type: string - secrets: - token: + github_token: description: 'GitHub token' required: true + type: string + jobs: changelog: @@ -34,14 +35,14 @@ jobs: - name: Checkout repository uses: actions/checkout@v4 with: - token: "${{ secrets.token }}" + token: "${{ inputs.github_token }}" repository: "${{ inputs.repository }}" ref: "${{ inputs.ref }}" - name: Generate Changelog id: changelog env: - GITHUB_TOKEN: "${{ secrets.token }}" + GITHUB_TOKEN: "${{ inputs.github_token }}" run: | set -x diff --git a/create-release/action.yml b/create-release/action.yml index 46c8e6e..6052fbb 100644 --- a/create-release/action.yml +++ b/create-release/action.yml @@ -19,19 +19,11 @@ inputs: description: 'The branch or SHA for the release (defaults to main)' required: false default: ${{ github.ref }} -outputs: - breaking-changes: - description: "Breaking changes introduced in this release" - value: ${{ steps.changelog.outputs.breaking-changes }} - features: - description: "Features introduced in this release" - value: ${{ steps.changelog.outputs.features }} - bug-fixes: - description: "Bug fixes introduced in this release" - value: ${{ steps.changelog.outputs.bug-fixes }} - new-contributors: - description: "New contributors to this release" - value: ${{ steps.changelog.outputs.new-contributors }} + is_prerelease: + description: 'Is this a pre-release?' + required: false + default: "false" + runs: using: "composite" steps: @@ -61,103 +53,30 @@ runs: echo "xy_version=${XY_VERSION}" >> $GITHUB_OUTPUT id: check_tag - - name: Checkout code - uses: actions/checkout@v4 + - name: Generate Changelog + uses: ./.github/workflows/generate-changelog.yml with: - fetch-depth: 0 - repository: ${{ inputs.repository }} - ref: ${{ inputs.ref }} - path: ${{ inputs.repository }} - token: ${{ inputs.github_token }} - - - name: Make changelog - working-directory: ./${{ inputs.repository }} - env: - GITHUB_TOKEN: ${{ inputs.github_token }} - shell: bash - run: | - set -x - set +o pipefail - - # Details we need in order to create the release - REPOSITORY=${{ inputs.repository }} - echo "owner=${REPOSITORY%/*}" >> $GITHUB_OUTPUT - echo "repo=${REPOSITORY#*/}" >> $GITHUB_OUTPUT - SHA=$(git rev-parse HEAD) - echo "sha=${SHA}" >> $GITHUB_OUTPUT - - # Let GitHub format the commits - if [ -n "${{ inputs.prev_version }}" ] && git rev-list ${{ inputs.prev_version }} 2> /dev/null; then - PREV_TAG="${{ inputs.prev_version }}" - else - PREV_TAG=$(gh api -H "Accept: application/vnd.github+json" -H "X-GitHub-Api-Version: 2022-11-28" repos/${{ inputs.repository }}/releases/latest | jq -r '.tag_name // empty') - fi - NOTES=$(gh api \ - --method POST \ - -H "Accept: application/vnd.github+json" \ - -H "X-GitHub-Api-Version: 2022-11-28" \ - repos/${{ inputs.repository }}/releases/generate-notes \ - -f tag_name="${{ inputs.version }}" \ - -f target_commitish="${{ inputs.ref }}" \ - -f previous_tag_name="${PREV_TAG}" | jq -r '.body') - filterfunc() { echo "${NOTES}" | grep "^*\s*:$1:" | sed "s/.*:$1:\s*/* /"; } + version: ${{ github.event.inputs.version }} + prev_version: ${{ github.event.inputs.prev_version }} + repository: ${{ github.event.inputs.repository }} + ref: ${{ github.event.inputs.ref }} + github_token: ${{ inputs.github_token }} - RELEASE_DOC="${PWD}/release.md" - echo "release_doc=${RELEASE_DOC}" >> $GITHUB_ENV - - BREAKING_CHANGES="$(filterfunc warning)" - if [ -n "${BREAKING_CHANGES}" ]; then - echo "## :warning: Breaking Changes" >> ${RELEASE_DOC} - echo "${BREAKING_CHANGES}" >> ${RELEASE_DOC} - echo "" >> ${RELEASE_DOC} - echo "breaking-changes<> $GITHUB_OUTPUT - echo "${BREAKING_CHANGES}" >> $GITHUB_OUTPUT - echo "nEOFn" >> $GITHUB_OUTPUT - fi - - FEATURE_CHANGES="$(filterfunc sparkles)" - if [ -n "${FEATURE_CHANGES}" ]; then - echo "## :sparkles: Features" >> ${RELEASE_DOC} - echo "${FEATURE_CHANGES}" >> ${RELEASE_DOC} - echo "" >> ${RELEASE_DOC} - echo "features<> $GITHUB_OUTPUT - echo "${FEATURE_CHANGES}" >> $GITHUB_OUTPUT - echo "nEOFn" >> $GITHUB_OUTPUT - fi - - BUG_FIXES="$(filterfunc bug)" - if [ -n "${BUG_FIXES}" ]; then - echo "## :bug: Bug Fixes" >> ${RELEASE_DOC} - echo "${BUG_FIXES}" >> ${RELEASE_DOC} - echo "" >> ${RELEASE_DOC} - echo "bug-fixes<> $GITHUB_OUTPUT - echo "${BUG_FIXES}" >> $GITHUB_OUTPUT - echo "nEOFn" >> $GITHUB_OUTPUT - fi - - # TODO(djzager): More? could make this workflow accept as an argument whether or not - # to include other types (ie. seedling, docs) + - name: Download Changelog + uses: actions/download-artifact@v4 + with: + name: changelog-artifact + path: . - # Add contributors as GitHub would have added them - NEW_CONTRIB=$(echo "${NOTES}" | sed -n "/Contributors/,\$p") - if [ -n "${NEW_CONTRIB}" ]; then - echo "${NEW_CONTRIB}" >> ${RELEASE_DOC} - echo "new-contributors<> $GITHUB_OUTPUT - echo "${NEW_CONTRIB}" | head -n -3 >> $GITHUB_OUTPUT - echo "nEOFn" >> $GITHUB_OUTPUT - else - echo "${NOTES}" | sed -n "/Changelog/,\$p" >> ${RELEASE_DOC} - fi - id: changelog - uses: ncipollo/release-action@main with: - owner: ${{ steps.changelog.outputs.owner }} - repo: ${{ steps.changelog.outputs.repo }} + owner: ${{ github.repository_owner }} + repo: ${{ inputs.repository }} tag: ${{ inputs.version }} - commit: ${{ steps.changelog.outputs.sha }} - bodyFile: ${{ env.release_doc }} + commit: ${{ github.sha }} + bodyFile: release.md draft: false - prerelease: ${{ steps.check_tag.outputs.is_prerelease }} + prerelease: ${{ inputs.is_prerelease }} skipIfReleaseExists: true token: ${{ inputs.github_token }} \ No newline at end of file From 79a2ba68f2aa51427d21e1fa752764598073881f Mon Sep 17 00:00:00 2001 From: Savitha Raghunathan Date: Mon, 4 Nov 2024 15:25:53 -0500 Subject: [PATCH 6/6] extract secret Signed-off-by: Savitha Raghunathan --- .github/workflows/generate-changelog.yml | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/.github/workflows/generate-changelog.yml b/.github/workflows/generate-changelog.yml index ef2dfca..2ed5f34 100644 --- a/.github/workflows/generate-changelog.yml +++ b/.github/workflows/generate-changelog.yml @@ -24,25 +24,37 @@ on: type: string github_token: description: 'GitHub token' - required: true + required: false type: string + secrets: + token: + description: 'GitHub token' + required: false jobs: changelog: runs-on: ubuntu-latest steps: + - name: Set GITHUB_TOKEN environment variable + run: | + if [ -n "${{ inputs.github_token }}" ]; then + echo "GITHUB_TOKEN=${{ inputs.github_token }}" >> $GITHUB_ENV + else + echo "GITHUB_TOKEN=${{ secrets.token }}" >> $GITHUB_ENV + fi + - name: Checkout repository uses: actions/checkout@v4 with: - token: "${{ inputs.github_token }}" + token: "${{ env.GITHUB_TOKEN }}" repository: "${{ inputs.repository }}" ref: "${{ inputs.ref }}" - name: Generate Changelog id: changelog env: - GITHUB_TOKEN: "${{ inputs.github_token }}" + GITHUB_TOKEN: "${{ env.GITHUB_TOKEN }}" run: | set -x