Skip to content

Commit

Permalink
fix: readdir should check for access rights, fixes #294
Browse files Browse the repository at this point in the history
  • Loading branch information
Nicolas Ramz committed Apr 21, 2020
1 parent bc04178 commit 59eef81
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 1 deletion.
2 changes: 2 additions & 0 deletions lib/binding.js
Original file line number Diff line number Diff line change
Expand Up @@ -963,6 +963,8 @@ Binding.prototype.readdir = function(
throw new FSError('ENOTDIR', dirpath);
}

this.access(dirpath, parseInt('0002', 8));

let list = dir.list();
if (encoding === 'buffer') {
list = list.map(function(item) {
Expand Down
45 changes: 44 additions & 1 deletion test/lib/fs.readdir.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,15 @@ describe('fs.readdir(path, callback)', function() {
empty: {}
}
}
}
},
denied: mock.directory({
mode: 0o000,
items: [
{
'one.txt': 'content'
}
]
})
});
});
afterEach(mock.restore);
Expand Down Expand Up @@ -92,6 +100,29 @@ describe('fs.readdir(path, callback)', function() {
);
});

it('calls with an error for restricted path', function(done) {
fs.readdir('denied', function(err, items) {
assert.instanceOf(err, Error);
assert.isUndefined(items);
done();
});
});

withPromise.it('promise calls with an error for restricted path', function(
done
) {
fs.promises.readdir('denied').then(
function() {
assert.fail('should not succeed.');
done();
},
function(err) {
assert.instanceOf(err, Error);
done();
}
);
});

inVersion('>=10.10').it('should support "withFileTypes" option', function(
done
) {
Expand Down Expand Up @@ -216,4 +247,16 @@ describe('fs.readdirSync(path)', function() {
fs.readdirSync('bogus');
});
});

it('throws when access refused', function() {
assert.throws(function() {
fs.readdirSync('denied');
});
});

it('throws when access refused', function() {
assert.throws(function() {
fs.readdirSync('denied');
});
});
});

0 comments on commit 59eef81

Please sign in to comment.