|
| 1 | +name: Report workflow security problems |
| 2 | + |
| 3 | +on: |
| 4 | + workflow_dispatch: |
| 5 | + push: |
| 6 | + branches: [ develop ] |
| 7 | + paths: |
| 8 | + - '.github/workflows/**' |
| 9 | + |
| 10 | +permissions: |
| 11 | + issues: write |
| 12 | + |
| 13 | +jobs: |
| 14 | + prt: |
| 15 | + runs-on: ubuntu-latest |
| 16 | + timeout-minutes: 15 |
| 17 | + # Only run this in our repos (Prevent notification spam by forks) |
| 18 | + if: ${{ github.repository_owner == 'xdev-software' }} |
| 19 | + steps: |
| 20 | + - uses: actions/checkout@v6 |
| 21 | + |
| 22 | + - name: Check |
| 23 | + id: check |
| 24 | + run: | |
| 25 | + grep -l 'pull_request_target:' --exclude report-gha-workflow-security-problems.yml *.yml > reported.txt && exit 1 || exit 0 |
| 26 | + working-directory: .github/workflows |
| 27 | + |
| 28 | + - name: Find already existing issue |
| 29 | + id: find-issue |
| 30 | + if: ${{ !cancelled() }} |
| 31 | + run: | |
| 32 | + echo "number=$(gh issue list -l 'bug' -l 'automated' -L 1 -S 'in:title "Incorrectly configure GHA workflow (prt)"' -s 'open' --json 'number' --jq '.[].number')" >> $GITHUB_OUTPUT |
| 33 | + env: |
| 34 | + GH_TOKEN: ${{ github.token }} |
| 35 | + |
| 36 | + - name: Close issue if everything is fine |
| 37 | + if: ${{ success() && steps.find-issue.outputs.number != '' }} |
| 38 | + run: gh issue close -r 'not planned' ${{ steps.find-issue.outputs.number }} |
| 39 | + env: |
| 40 | + GH_TOKEN: ${{ github.token }} |
| 41 | + |
| 42 | + - name: Create report |
| 43 | + if: ${{ failure() && steps.check.conclusion == 'failure' }} |
| 44 | + run: | |
| 45 | + echo 'Detected usage of `pull_request_target`. This event is dangerous and MUST NOT BE USED AT ALL COST!' > reported.md |
| 46 | + echo '' >> reported.md |
| 47 | + echo '/cc @xdev-software/gha-workflow-security' >> reported.md |
| 48 | + echo '' >> reported.md |
| 49 | + echo '```' >> reported.md |
| 50 | + cat .github/workflows/reported.txt >> reported.md |
| 51 | + echo '```' >> reported.md |
| 52 | + cat reported.md |
| 53 | +
|
| 54 | + - name: Create Issue From File |
| 55 | + if: ${{ failure() && steps.check.conclusion == 'failure' }} |
| 56 | + uses: peter-evans/create-issue-from-file@fca9117c27cdc29c6c4db3b86c48e4115a786710 # v6 |
| 57 | + with: |
| 58 | + issue-number: ${{ steps.find-issue.outputs.number }} |
| 59 | + title: 'Incorrectly configure GHA workflow (prt)' |
| 60 | + content-filepath: ./reported.md |
| 61 | + labels: bug, automated |
0 commit comments