Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Linux | OS X | Windows |
---|---|---|
NSFW is a native abstraction for Linux, Windows, and OSX file watching services which tries to keep a consistent interface and feature set across operating systems. NSFW offers recursive file watching into deep file systems all at no additional cost to the Javascript layer. In Linux, NSFW recursively builds an inotify watch tree natively, which collects events concurrently to the javascript thread. In OSX, NSFW utilizes the FSEventsService, which recursively watches for file system changes in a specified directory. In Windows, NSFW implements a server around the ReadDirectoryChangesW method.
When NSFW has events and is not being throttled, it will group those events in the order that they occurred and report them to the Javascript layer in a single callback. This is an improvement over services that utilize Node FS.watch, which uses a callback for every file event that is triggered. Every callback FS.watch makes to the event queue is a big bonus to NSFW's performance when watching large file system operations, because NSFW will only make 1 callback with many events within a specified throttle period.
So why NSFW? Because it has a consistent and minimal footprint in the Javascript layer, manages recursive watching for you, and is super easy to use.
var nsfw = require('nsfw');
var watcher1;
return nsfw(
'dir1',
function(events) {
// handle events
})
.then(function(watcher) {
watcher1 = watcher;
return watcher.start();
})
.then(function() {
// we are now watching dir1 for events!
// To stop watching
watcher1.stop()
});
// With options
var watcher2;
return nsfw(
'dir2',
function(events) {
// handles other events
},
{
debounceMS: 250,
errorCallback(errors) {
//handle errors
},
excludedPaths: ['dir2/node_modules']
})
.then(function(watcher) {
watcher2 = watcher;
return watcher.start();
})
.then(function() {
// we are now watching dir2 for events!
// we can update excludedPaths array
return watcher2.updateExcludedPaths(['dir2/node_modules', '.git']);
})
.then(function() {
// To stop watching
watcher2.stop();
})
updateExcludedPaths
functionAn array of events as they have happened in a directory, it's children, or to a file.
[
{
"action": 2, // nsfw.actions.MODIFIED
"directory": "/home/nsfw/watchDir",
"file": "file1.ext"
},
{
"action": 0, // nsfw.actions.CREATED
"directory": "/home/nsfw/watchDir",
"file": "folder"
},
{
"action": 1, // nsfw.actions.DELETED
"directory": "home/nsfw/watchDir/testFolder",
"file": "test.ext"
},
{
"action": 3, // nsfw.actions.RENAMED
"directory": "home/nsfw/watchDir",
"oldFile": "oldname.ext",
"newDirectory": "home/nsfw/watchDir/otherDirectory"
"newFile": "newname.ext"
}
]
Event are enumerated by the nsfw.actions enumeration
nsfw.actions = {
CREATED: 0,
DELETED: 1,
MODIFIED: 2,
RENAMED: 3
};
NSFW is a native node module and requires Node-Gyp to be functional before you can install it. Make sure you have completed installing all of the dependencies listed for Node-Gyp on your operating system.
FAQs
A simple file watcher for Node
The npm package nsfw receives a total of 6,408 weekly downloads. As such, nsfw popularity was classified as popular.
We found that nsfw demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers 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.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.