Comment on the pull request #1
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
# Commenting on a PR requires write access | |
# but PR opened from forks does not get write access | |
# except when triggered with `pull_request_target` | |
# | |
# So the comments payload must be created from a `pull_request` event workflow. | |
# Then that payload can be posted as PR comment in a `pull_request_target` event workflow. | |
# | |
# Documentation: https://docs.github.com/en/actions/reference/events-that-trigger-workflows#pull_request_target | |
# Blog post with example: https://securitylab.github.com/research/github-actions-preventing-pwn-requests/ | |
name: Comment on the pull request | |
on: | |
workflow_run: | |
workflows: ['Benchmark Tests'] | |
types: | |
- completed | |
permissions: | |
pull-requests: write | |
jobs: | |
upload: | |
runs-on: ubuntu-latest | |
# Only run on `issue_comment`, to prevent running on a malicious PR | |
if: (github.event.workflow_run.conclusion == 'success' || github.event.workflow_run.conclusion == 'failure') && github.event.workflow_run.event == 'issue_comment' | |
steps: | |
- name: 'Download artifact' | |
uses: actions/github-script@v7 | |
with: | |
script: | | |
var artifacts = await github.rest.actions.listWorkflowRunArtifacts({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
run_id: ${{ github.event.workflow_run.id }}, | |
}); | |
var matchArtifact = artifacts.data.artifacts.filter((artifact) => { | |
return artifact.name == "benchmark-assets" | |
})[0]; | |
var download = await github.rest.actions.downloadArtifact({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
artifact_id: matchArtifact.id, | |
archive_format: 'zip', | |
}); | |
var fs = require('fs'); | |
fs.writeFileSync('${{ github.workspace }}/benchmark-assets.zip', Buffer.from(download.data)); | |
- run: unzip benchmark-assets.zip | |
- name: 'Comment on PR' | |
uses: actions/github-script@v7 | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
script: | | |
var fs = require('fs'); | |
var issue_number = Number(fs.readFileSync('./benchmark-results/NR')); | |
var report = String(fs.readFileSync('./benchmark-results/lab-benchmark.md')); | |
var memory_report = String(fs.readFileSync('./memory-leak-report.md')); | |
// Get the existing comments. | |
const {data: comments} = await github.rest.issues.listComments({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
issue_number: issue_number, | |
}) | |
// Find any comment already made by the bot. | |
const botComment = comments.find(comment => comment.user.id === 41898282) | |
if (botComment) { | |
await github.rest.issues.updateComment({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
comment_id: botComment.id, | |
body: [report, memory_report].join('\n') | |
}) | |
} else { | |
await github.rest.issues.createComment({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
issue_number: issue_number, | |
body: [report, memory_report].join('\n') | |
}); | |
} |