diff --git a/.github/workflows/dispatch.yml b/.github/workflows/dispatch.yml index 4d0dd98..f4601a5 100644 --- a/.github/workflows/dispatch.yml +++ b/.github/workflows/dispatch.yml @@ -1,12 +1,8 @@ name: Dispatch downstreams on: - workflow_call: - workflow_dispatch: - workflow_run: - workflows: [Regenerate profile content] - types: - - completed + release: + types: [published] jobs: dispatch: @@ -28,6 +24,9 @@ jobs: owner: 'RedHatProductSecurity', repo: 'oscal-component-definitions', workflow_id: 'update-profiles.yml', + inputs: { + ref: '${{ github.event.release.tag_name }}' + }, ref: 'main' }) \ No newline at end of file diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 0000000..08ffbe5 --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,53 @@ +name: Release content + +on: + workflow_dispatch: + inputs: + version: + description: 'Release version' + required: true + +jobs: + release: + runs-on: ubuntu-latest + steps: + - name: Generate app token + uses: tibdex/github-app-token@v2.1.0 + id: get_installation_token + with: + app_id: ${{ secrets.APP_ID }} + private_key: ${{ secrets.PRIVATE_KEY }} + permissions: >- + {"contents": "write"} + - name: Clone + uses: actions/checkout@v4 + with: + token: ${{ steps.get_installation_token.outputs.token }} + - name: Autosync + uses: RedHatProductSecurity/trestle-bot/actions/autosync@v0.8.0 + with: + markdown_path: "markdown/profiles" + oscal_model: "profile" + commit_message: "Update content for release [skip ci]" + skip_regenerate: true + commit_user_name: "trestle-bot[bot]" + commit_user_email: "136850459+trestle-bot[bot]@users.noreply.github.com" + version: ${{ github.event.inputs.version }} + - name: Create and push tags + env: + VERSION: ${{ github.event.inputs.version }} + run: | + git tag "${VERSION}" + git push origin "${VERSION}" + - name: Create Release + uses: actions/github-script@v7 + with: + github-token: ${{ steps.get_installation_token.outputs.token }} + script: | + await github.rest.repos.createRelease({ + owner: context.repo.owner, + repo: context.repo.repo, + tag_name: '${{ github.event.inputs.version }}', + name: 'v${{ github.event.inputs.version }}', + generate_release_notes: true, + }) \ No newline at end of file