Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
node-readfiles
Advanced tools
A lightweight Node.js module to recursively read files in a directory using ES6 Promises
A lightweight node.js module to recursively read files in a directory using ES6 Promises.
npm install node-readfiles
You can safely add readfiles
anywhere in your project.
var readfiles = require('node-readfiles');
Asynchronusly read the files in a directory returning a Promise.
A relative or absolute path of the directory to read files.
An optional object parameter with the following properties:
readfiles.FULL_PATH
, readfiles.RELATIVE
, or readfiles.FILENAME
, whether the callback's returns the full-path, relative-path or only the filenames of the traversed files. (default is readfiles.RELATIVE
)?
matches one character*
matches zero or more characters**
matches zero or more 'directories' in a path-1
is infinte, and 0
is none (defaults to -1).
(defaults to false)The optional callback function is triggered everytime a file is found. If there's an error while reading the file the err
parameter will contain the error that occured, When readContents
is true, the contents
parameter will be populated with the contents of the file encoded using the encoding
option. For convenience the stat
result object is passed to the callback for you to use.
[1] The contents
parameter will be null
when the readContents
option is false
.
When working with asynchronous operations, you can simply return a function (next) { ... }
which will enabled you to completed your asynchronous operation until you call next()
.
readfiles('/path/to/dir/', function (err, filename, content, stat) {
if (err) throw err;
return function (next) {
setTimeout(function () {
console.log('File ' + filename);
next();
}, 3000);
};
});
When calling readfiles
, an ES6 Promise is returned with an array of all the files that were found. You can then call then
or catch
to see if readfiles
encountered an error.
var readfiles = require('node-readfiles');
readfiles('/path/to/dir/', function (err, filename, content) {
if (err) throw err;
console.log('File ' + filename + ':');
console.log(content);
}).then(function (files) {
console.log('Read ' + files.length + ' file(s)');
}).catch(function (err) {
console.log('Error reading files:', err.message);
});
The default behavior, is to recursively list all files in a directory. By default readfiles
will exclude all dot files.
readfiles('/path/to/dir/', function (err, filename, content) {
if (err) throw err;
console.log('File ' + filename + ':');
console.log(content);
}).then(function (files) {
console.log('Read ' + files.length + ' file(s)');
console.log(files.join('\n'));
});
Read all files in a directory, excluding sub-directories.
readfiles('/path/to/dir/', {
depth: 0
}, function (err, filename, content) {
if (err) throw err;
console.log('File ' + filename + ':');
console.log(content);
}).then(function (files) {
console.log('Read ' + files.length + ' file(s)');
console.log(files.join('\n'));
});
The above can also be accomplished using the filter
option.
readfiles('/path/to/dir/', {
filter: '*' // instead of the default '**'
}, function (err, filename, content) {
if (err) throw err;
console.log('File ' + filename + ':');
console.log(content);
}).then(function (files) {
console.log('Read ' + files.length + ' file(s)');
console.log(files.join('\n'));
});
Recursively read all files with "txt" extension in a directory and display the contents.
readfiles('/path/to/dir/', {
filter: '*.txt'
}, function (err, filename, content) {
if (err) throw err;
console.log('File ' + filename + ':');
console.log(content);
}).then(function (files) {
console.log('Read ' + files.length + ' file(s)');
});
Recursively read all files with that match "t?t" in a directory and display the contents.
readfiles('/path/to/dir/', {
filter: '*.t?t'
}, function (err, filename, content) {
if (err) throw err;
console.log('File ' + filename + ':');
console.log(content);
}).then(function (files) {
console.log('Read ' + files.length + ' file(s)');
});
Recursively list all json files in a directory including all sub-directories, without reading the files.
readfiles('/path/to/dir/', {
filter: '*.json',
readContents: false
}, function (err, filename, content) {
if (err) throw err;
console.log('File ' + filename);
});
MIT licensed (See LICENSE.txt)
FAQs
A lightweight Node.js module to recursively read files in a directory using ES6 Promises
We found that node-readfiles demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.