microsoft/openvmm

Public

mirrored fromhttps://github.com/microsoft/openvmmAvailable

CodeCommitsIssuesPull requestsActionsInsightsSecurity
72d4de3ec5931bd94f790c931b43326308f0c50a

Branches

Tags

  • No tags available.
0Branches0Tags
Go to file
Add file
Code

Clone

HTTPS

Download ZIP

.github/workflows/unsafe-reviewers.yml

52lines · modepreview

name: Unsafe Reviewers Check
on:
  workflow_dispatch:
  pull_request_target:
    types: [opened, reopened, synchronize]

# https://docs.github.com/en/actions/using-jobs/assigning-permissions-to-jobs
permissions:
  id-token: write
  contents: read
  pull-requests: write

concurrency:
  group: ${{ github.workflow }}-${{ github.head_ref }}
  cancel-in-progress: true


jobs:
  UnsafeReview:
    runs-on: ubuntu-latest
    if: github.event.pull_request.merged != true && github.event.action != 'closed'
    steps:
      # NOTE: We're checking out both repos to avoid a security vulnerability
      # Any code that runs in this workflow should be using the checked out base repo to avoid
      # running code from a potentially malicious PR
      # https://securitylab.github.com/resources/github-actions-preventing-pwn-requests/
      # https://nathandavison.com/blog/github-actions-and-the-threat-of-malicious-pull-requests
      - name: Checkout base repo
        uses: actions/checkout@v4
        with:
          path: base
          fetch-depth: 0
      - name: Checkout head repo
        uses: actions/checkout@v4
        with:
          repository: ${{ github.event.pull_request.head.repo.full_name }}
          ref: ${{ github.event.pull_request.head.ref }}
          token: ${{ secrets.GITHUB_TOKEN }}
          fetch-depth: 0
          path: head-repo

      - name: Get merge base commit
        id: merge-base
        run: |
          git fetch origin ${{ github.base_ref }}
          git merge-base HEAD origin/${{ github.base_ref }} > merge-base.txt
          echo "MERGE_BASE=$(cat merge-base.txt)" >> $GITHUB_ENV
        working-directory: head-repo

      - name: Run unsafe code review script
        run: pip3 install -r ./base/.github/scripts/add_unsafe_reviewers/requirements.txt && python3 ./base/.github/scripts/add_unsafe_reviewers/add-unsafe-reviewers.py ./head-repo "${{ env.MERGE_BASE }}" --token "${{ secrets.GITHUB_TOKEN }}" --pull-request "${{ github.event.number }}"
        shell: bash