Skip to content

Commit 1726da9

Browse files
authored
permission: add path separator to loader check
Signed-off-by: RafaelGSS <[email protected]> PR-URL: #47030 Reviewed-By: Geoffrey Booth <[email protected]> Reviewed-By: Benjamin Gruenbaum <[email protected]> Reviewed-By: Paolo Insogna <[email protected]> Reviewed-By: Marco Ippolito <[email protected]>
1 parent 0b328b2 commit 1726da9

File tree

3 files changed

+28
-2
lines changed

3 files changed

+28
-2
lines changed

lib/internal/modules/cjs/loader.js

+1-1
Original file line numberDiff line numberDiff line change
@@ -423,7 +423,7 @@ function readPackageScope(checkPath) {
423423
checkPath = StringPrototypeSlice(checkPath, 0, separatorIndex);
424424
// Stop the search when the process doesn't have permissions
425425
// to walk upwards
426-
if (enabledPermission && !permission.has('fs.read', checkPath)) {
426+
if (enabledPermission && !permission.has('fs.read', checkPath + sep)) {
427427
return false;
428428
}
429429
if (StringPrototypeEndsWith(checkPath, sep + 'node_modules'))
+3
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
const fs = require('node:fs');
2+
3+
fs.readFile('/etc/passwd', () => {});

test/parallel/test-cli-permission-deny-fs.js

+24-1
Original file line numberDiff line numberDiff line change
@@ -1,9 +1,12 @@
11
'use strict';
22

3-
require('../common');
3+
const common = require('../common');
4+
5+
const fixtures = require('../common/fixtures');
46
const { spawnSync } = require('child_process');
57
const assert = require('assert');
68
const fs = require('fs');
9+
const path = require('path');
710

811
{
912
const { status, stdout } = spawnSync(
@@ -126,3 +129,23 @@ const fs = require('fs');
126129
assert.strictEqual(status, 1);
127130
assert.ok(!fs.existsSync('permission-deny-example.md'));
128131
}
132+
133+
{
134+
const { root } = path.parse(process.cwd());
135+
const abs = (p) => path.join(root, p);
136+
const firstPath = abs(path.sep + process.cwd().split(path.sep, 2)[1]);
137+
if (firstPath.startsWith('/etc')) {
138+
common.skip('/etc as firstPath');
139+
}
140+
const file = fixtures.path('permission', 'loader', 'index.js');
141+
const { status, stderr } = spawnSync(
142+
process.execPath,
143+
[
144+
'--experimental-permission',
145+
`--allow-fs-read=${firstPath}`,
146+
file,
147+
]
148+
);
149+
assert.match(stderr.toString(), /resource: '.*?[\\/](?:etc|passwd)'/);
150+
assert.strictEqual(status, 1);
151+
}

0 commit comments

Comments
 (0)