Installations
npm install smart-fs
Developer Guide
Typescript
No
Module System
ESM
Min. Node Version
>= 20
Node Version
22.13.1
NPM Version
10.9.2
Score
73.9
Supply Chain
99.3
Quality
85.7
Maintenance
50
Vulnerability
97.6
License
Releases
Contributors
Languages
JavaScript (100%)
Love this project? Help keep it running — sponsor us today! 🚀
Developer
blackflux
Download Statistics
Total Downloads
493,245
Last Day
944
Last Week
2,116
Last Month
5,285
Last Year
47,885
GitHub Statistics
4 Stars
2,031 Commits
2 Forks
2 Watching
7 Branches
4 Contributors
Bundle Size
156.58 kB
Minified
47.70 kB
Minified + Gzipped
Package Meta Information
Latest Version
5.0.2
Package Id
smart-fs@5.0.2
Unpacked Size
15.88 kB
Size
5.70 kB
File Count
14
NPM Version
10.9.2
Node Version
22.13.1
Publised On
29 Jan 2025
Total Downloads
Cumulative downloads
Total Downloads
493,245
Last day
13.6%
944
Compared to previous day
Last week
22.7%
2,116
Compared to previous week
Last month
116.3%
5,285
Compared to previous month
Last year
10.6%
47,885
Compared to previous year
Daily Downloads
Weekly Downloads
Monthly Downloads
Yearly Downloads
Dependencies
8
smart-fs
Abstraction Layer for File Management.
Drop in replacement for fs.
Getting Started
$ npm install --save smart-fs
Functions
guessFile(filepath, { exclude = [] })
Extends and returns filepath with the file extension as appropriate. Returns null
if no good match was found.
A few notes:
- Only extends extensions, not partial file names
- Will prefer to match the exact file
- Will return
null
when multiple possible extensions are found
To exclude certain extensions from being matched provide them in the exclude
option.
walkDir(dirpath)
Iteratively walk dirpath and return relative paths of all files contained.
Will only return entries where fs.lstatSync(...).isFile()
evaluates to true (this excludes symlinks).
cleaningDelete(filepath)
Delete file and all empty parent directories.
smartParse(content, options = { treatAs = null, resolve = true, refPath = process.cwd() })
Core logic of smartRead
but takes content and refPath.
smartRead(filepath, options = { treatAs = null, resolve = true })
Read and parse file based on file extension.
The following extensions are handled in order:
.json
: Loads file using JSON.parse..xml
: Loads file using xml-js..yml
and.yaml
: Loads file using yaml-boost..js
: Loads file using import. Result is a promise!.*
: Treats file as text file and loads as array of lines.
Note that the required cache is not automatically invalidated when loading cached .js
files.
To ignore file extension and force treat the file as a certain type, you can pass the option treatAs
as e.g. json
.
To simply load yml files without resolving them pass resolve
as false
smartWrite(filepath. content, options = { treatAs = null, mergeStrategy = (existing, changeset) => changeset, create = true, pretty = false, keepOrder = true, resolve = false })
Serialize and write content to file based on file extension.
The file and all necessary folders are created if not present.
The file is only actually written if the content has changed. Returns true if the file was written, false otherwise.
The following extension are handled in order:
.json
: Serialize uses JSON.stringify..xml
: Serialize using xml-js..yml
and.yaml
: Serialize uses yaml-boost..*
: Expects content as array and serializes by joining array using new line character.
To ignore file extension and force treat the file as a certain type, you can pass the option treatAs
as e.g. json
.
The mergeStrategy
option can be used to customize how the new content is merged if the target file already exists.
By default the file is simply overwritten.
When create
is set to false
no action is taken if the file does not already exist.
When pretty
is set to true
, the output is formatted more compact.
When keepOrder
is set to true
and a file is overwritten,
the new content is ordered according to the existing content (e.g. for json
and yml
)
To resolve
the original file before overwrite merging pass the option as true
.
Important
Do not use this library for loading if you don't trust the source of the files you are loading!
No vulnerabilities found.
Reason
no binaries found in the repo
Reason
license file detected
Details
- Info: project has a license file: LICENSE:0
- Info: FSF or OSI recognized license: MIT License: LICENSE:0
Reason
10 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 8
Reason
2 existing vulnerabilities detected
Details
- Warn: Project is vulnerable to: GHSA-pfrx-2q88-qq97
- Warn: Project is vulnerable to: GHSA-p6mc-m468-83gw
Reason
Found 8/17 approved changesets -- score normalized to 4
Reason
no effort to earn an OpenSSF best practices badge detected
Reason
security policy file not detected
Details
- Warn: no security policy file detected
- Warn: no security file to analyze
- Warn: no security file to analyze
- Warn: no security file to analyze
Reason
project is not fuzzed
Details
- Warn: no fuzzer integrations found
Reason
SAST tool is not run on all commits -- score normalized to 0
Details
- Warn: 0 commits out of 30 are checked with a SAST tool
Score
5
/10
Last Scanned on 2025-02-03
The Open Source Security Foundation is a cross-industry collaboration to improve the security of open source software (OSS). The Scorecard provides security health metrics for open source projects.
Learn More