-
Notifications
You must be signed in to change notification settings - Fork 30.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fs.isWatchAvailable() [capabilities check for fs.watch()] #29894
Comments
@nodejs/fs |
Putting TOCTOU issues aside... It would need to be implemented in libuv first but there will be situations where libuv can't determine whether file watching would work, so you'd either have to accept false positives or false negatives. Doesn't seem that useful to me. |
Rather than add a way to check (which opens the door for TOCTOU, as Ben pointed out) I think a better approach would be to try to fail hard if it doesn't work. That way you could catch the exception, and swtich to an alternative method. Detecting all those conditions, is, however, not easy AFAIK. |
At a minimum, I would suggest some definition of what is to happen when A specific runtime Exception at the point of invocation would suffice, while also addressing TOCTOU concerns. |
It's never unavailable, sometimes the OS simply just doesn't reports events. How do you suggest libuv deals with that? Whitelisting/blacklisting based on the fs type isn't good enough because of false positives/negatives (and also suffers from TOCTOU issues.) |
Since it's virtually impossible to avoid false positives/negatives, you are absolutely right that the notion of writing truly portable code with conditional use of After considering your points, it's clear that the initial enhancement request is not a good idea. Still, there are times when the implementation will know for certain that the OS won't report events. It'd be (arguably) nice to have some indicator in these cases (and my suggestion would be a hard fail with a thrown Error to minimize TOCTOU problems). For instance, I'd be proposing the addition of the following to the documentation:
Also, for the sake of complete disclosure: I have a specific vested interest since I'm on the platform team for IBM i (@libuv/ibmi). There are scenarios where we know watching won't work and we'd like the option of throwing an |
I'm fairly certain on AIX an error is thrown if watch() is unavailable. It's the reason for this catch block in the report tests: node/test/report/test-report-uv-handles.js Lines 15 to 22 in 6db45bf
|
Thanks! I didn't catch that! |
Thanks all for handling! |
Is your feature request related to a problem? Please describe.
The
fs.watch()
File System method is handy and useful. Application and module developers are incented to use it for its advantages overfs.watchFile()
. However, it is inconsistent across platforms, and the documentation states that it "is unavailable in some situations."Application developers lack a good way of knowing whether the API is even available, making it diffucult to write portable JavaScript code. The documentation does a nice job of hitting some of the platforms and conditions, but it would be tedious for a developer to write logic around this, not to mention managing periodic updates as new conditions/platforms are added.
Describe the solution you'd like
I'd like for a new method to be available in
fs
to check whetherwatch()
is available. That way, portable code can be written that "falls back" tofs.watchFile()
if feasible.Not only would this enable portability, it would enable OS-specific conditions to be checked within the Node.js implementation. For example, the AIX implementation could check whether AHAFS is enabled.
Even further, if the new
isWatchAvailable()
method could take a directory as a parameter, then its implementation could also check whetherfs.watch()
would function on objects within that directory (and therefore say "no" for SMB shares, etc).Describe alternatives you've considered
Implementations could throw a specific Exception/Error if the platform doesn't support
fs.watch()
. However, it seems like the behavior is completely unspecified when the function is not available.The text was updated successfully, but these errors were encountered: