GHSA-hw6r-g8gj-2987

Suggest an improvement
Source
https://github.com/advisories/GHSA-hw6r-g8gj-2987
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2023/08/GHSA-hw6r-g8gj-2987/GHSA-hw6r-g8gj-2987.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-hw6r-g8gj-2987
Published
2023-08-30T20:47:13Z
Modified
2023-08-30T20:47:13Z
Summary
Actions expression injection in `filter-test-configs` (`GHSL-2023-181`)
Details

The pytorch/pytorch filter-test-configs workflow is vulnerable to an expression injection in Actions, allowing an attacker to potentially leak secrets and alter the repository using the workflow.

Details

The filter-test-configs workflow is using the raw github.event.workflow_run.head_branch value inside the filter step:

- name: Select all requested test configurations
  shell: bash
  env:
    GITHUB_TOKEN: ${{ inputs.github-token }}
    JOB_NAME: ${{ steps.get-job-name.outputs.job-name }}
  id: filter
  run: |
    ...
    python3 "${GITHUB_ACTION_PATH}/../../scripts/filter_test_configs.py" \
      ...
      --branch "${{ github.event.workflow_run.head_branch }}"

In the event of a repository using filter-test-configs in a pull_request_target-triggered workflow, an attacker could use a malicious branch name to gain command execution in the step and potentially leak secrets.

name: Example

on: pull_request_target

jobs:
  example:
    runs-on: ubuntu-latest
    steps:
      - name: Filter
        uses: pytorch/pytorch/.github/actions/filter-test-configs@v2

Impact

This issue may lead to stealing workflow secrets.

Remediation

  1. Use an intermediate environment variable for potentially attacker-controlled values such as github.event.workflow_run.head_branch:
    - name: Select all requested test configurations
      shell: bash
      env:
        GITHUB_TOKEN: ${{ inputs.github-token }}
        JOB_NAME: ${{ steps.get-job-name.outputs.job-name }}
        HEAD_BRANCH: ${{ github.event.workflow_run.head_branch }}
      id: filter
      run: |
        ...
        python3 "${GITHUB_ACTION_PATH}/../../scripts/filter_test_configs.py" \
          ...
          --branch "$HEAD_BRANCH"
    

Resources

Database specific
{
    "nvd_published_at": null,
    "cwe_ids": [],
    "severity": "MODERATE",
    "github_reviewed": true,
    "github_reviewed_at": "2023-08-30T20:47:13Z"
}
References

Affected packages

GitHub Actions / https://github.com/pytorch/pytorch/.github/actions/filter-test-configs

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected

Database specific

{
    "last_known_affected_version_range": "< 2.0.1"
}