Skip to content

Commit

Permalink
ci: Read build matrix JSON explicitly (shaka-project#1461)
Browse files Browse the repository at this point in the history
Because we used require() to read build-matrix.json, the file could be
replaced with build-matrix.json.js, allowing code injection into our CI
pipelines. This fixes this vulnerability by reading the JSON text with
the fs module, then explicitly parsing it, rather than relying on
require().

This also changes the location of the file, to match its location in
other projects.

Note that this workflow is not currently giving any elevated permissions
to users, so it is not currently possible to damage the repo through a
PR. But this might have been possible in the past, due to
organization-wide defaults for token permissions (recently fixed). No
evidence has been found of past exploit.

See also shaka-project/shaka-streamer#216 and
shaka-project/static-ffmpeg-binaries#57
  • Loading branch information
joeyparrish authored Dec 16, 2024
1 parent df745bd commit 774cd3f
Show file tree
Hide file tree
Showing 2 changed files with 4 additions and 2 deletions.
6 changes: 4 additions & 2 deletions .github/workflows/build.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -52,16 +52,18 @@ jobs:
id: configure
shell: node {0}
run: |
const fs = require('fs');
const enableSelfHosted = ${{ inputs.self_hosted }};
const buildMatrix = JSON.parse(fs.readFileSync("${{ github.workspace }}/build-matrix.json"));
// Use enableSelfHosted to decide what the build matrix below should
// include.
const {hosted, selfHosted} = require("${{ github.workspace }}/.github/workflows/build-matrix.json");
const {hosted, selfHosted} = buildMatrix;
const include = enableSelfHosted ? hosted.concat(selfHosted) : hosted;
const os = include.map((config) => config.os);
// Output JSON objects consumed by the build matrix below.
const fs = require('fs');
fs.writeFileSync(process.env.GITHUB_OUTPUT,
[
`INCLUDE=${ JSON.stringify(include) }`,
Expand Down
File renamed without changes.

0 comments on commit 774cd3f

Please sign in to comment.