Release PR image #98
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Release PR image | |
on: | |
workflow_run: | |
workflows: [PR Image Trigger] | |
types: | |
- completed | |
jobs: | |
get-pr-number: | |
name: Get PR number | |
runs-on: ubuntu-latest | |
outputs: | |
pr-number: ${{ steps.pr_number.outputs.pr_number }} | |
steps: | |
- name: 'Download artifacts' | |
uses: actions/github-script@v7 | |
with: | |
script: | | |
let allArtifacts = await github.rest.actions.listWorkflowRunArtifacts({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
run_id: context.payload.workflow_run.id, | |
}); | |
let matchArtifact = allArtifacts.data.artifacts.filter((artifact) => { | |
return artifact.name == "pr_number" | |
})[0]; | |
let download = await github.rest.actions.downloadArtifact({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
artifact_id: matchArtifact.id, | |
archive_format: 'zip', | |
}); | |
let fs = require('fs'); | |
fs.writeFileSync(`${process.env.GITHUB_WORKSPACE}/pr_number.zip`, Buffer.from(download.data)); | |
- name: 'Unzip artifact' | |
run: unzip pr_number.zip | |
- name: 'Read PR number' | |
id: pr_number | |
run: | | |
echo "pr_number=$(cat pr_number)" >> "$GITHUB_OUTPUT" | |
operator-container-push-pr: | |
needs: get-pr-number | |
permissions: | |
contents: read | |
id-token: write | |
packages: write | |
uses: metal-toolbox/container-push/.github/workflows/container-push.yml@main | |
with: | |
name: compliance-operator | |
registry_org: complianceascode | |
tag: ${{ needs.get-pr-number.outputs.pr-number }} | |
dockerfile_path: build/Dockerfile | |
vendor: 'Compliance Operator Authors' | |
checkout_ref: refs/pull/${{ needs.get-pr-number.outputs.pr-number }}/head | |
bundle-container-push-pr: | |
needs: get-pr-number | |
permissions: | |
contents: read | |
id-token: write | |
packages: write | |
uses: metal-toolbox/container-push/.github/workflows/container-push.yml@main | |
with: | |
name: compliance-operator-bundle | |
registry_org: complianceascode | |
tag: ${{ needs.get-pr-number.outputs.pr-number }} | |
dockerfile_path: bundle.Dockerfile | |
vendor: 'Compliance Operator Authors' | |
checkout_ref: refs/pull/${{ needs.get-pr-number.outputs.pr-number }}/head | |
openscap-container-push-pr: | |
needs: get-pr-number | |
permissions: | |
contents: read | |
id-token: write | |
packages: write | |
uses: metal-toolbox/container-push/.github/workflows/container-push.yml@main | |
with: | |
name: openscap-ocp | |
registry_org: complianceascode | |
tag: ${{ needs.get-pr-number.outputs.pr-number }} | |
dockerfile_path: images/openscap/Dockerfile | |
vendor: 'Compliance Operator Authors' | |
checkout_ref: refs/pull/${{ needs.get-pr-number.outputs.pr-number }}/head | |
catalog-container-push-pr: | |
needs: | |
- get-pr-number | |
- bundle-container-push-pr | |
permissions: | |
contents: read | |
id-token: write | |
packages: write | |
uses: metal-toolbox/container-push/.github/workflows/container-push.yml@main | |
with: | |
name: compliance-operator-catalog | |
registry_org: complianceascode | |
tag: ${{ needs.get-pr-number.outputs.pr-number }} | |
dockerfile_path: catalog.Dockerfile | |
vendor: 'Compliance Operator Authors' | |
checkout_ref: refs/pull/${{ needs.get-pr-number.outputs.pr-number }}/head | |
prepare_command: | | |
make catalog-deploy CATALOG_IMG=ghcr.io/complianceascode/compliance-operator-catalog:${{ needs.get-pr-number.outputs.pr-number }} | |
comment-pr: | |
needs: | |
- operator-container-push-pr | |
- bundle-container-push-pr | |
- openscap-container-push-pr | |
- catalog-container-push-pr | |
- get-pr-number | |
runs-on: ubuntu-latest | |
name: Comment on the PR | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Comment PR | |
uses: thollander/actions-comment-pull-request@v2 | |
with: | |
message: | | |
:robot: To deploy this PR, run the following command: | |
``` | |
make catalog-deploy CATALOG_IMG=ghcr.io/complianceascode/compliance-operator-catalog:${{ needs.get-pr-number.outputs.pr-number }} | |
``` |