williameggers/reactphp-filesystem-monitor

Asynchronous filesystem monitor based on ReactPHP

Maintainers

Package info

github.com/williameggers/reactphp-filesystem-monitor

pkg:composer/williameggers/reactphp-filesystem-monitor

Statistics

Installs: 0

Dependents: 0

Suggesters: 0

Stars: 0

0.5.0 2026-05-26 11:21 UTC

This package is auto-updated.

Last update: 2026-05-26 11:56:32 UTC


README

This is a maintained fork of react-filesystem-monitor.

See CONTRIBUTING.md for contribution guidelines and SECURITY.md for vulnerability reporting.

Original work:

  • tsufeki (2016)

Maintained fork:

  • William Eggers (2026–present)

Asynchronous filesystem monitor based on ReactPHP.

Currently these implementations are available:

  • INotifyExtensionMonitor based on the PECL inotify extension, preferred on Linux when the extension is installed.
  • INotifyProcessMonitor based on inotifywait command line utility, used on Linux.
  • FsWatchProcessMonitor based on fswatch, used on OSX.

The factory prefers INotifyExtensionMonitor on Linux when the PECL extension is available, falls back to INotifyProcessMonitor otherwise, and uses FsWatchProcessMonitor on other platforms.

All implementations' constructors take two arguments: a path to watch (file or recursively watched directory) and optional array of event to watch for (defaults to all events).

Available events:

  • access i.e. read
  • attribute - modification of permissions, timestamps etc.
  • close
  • create
  • delete
  • modify
  • move_from, move_to - file move, fired with source and destination path respectively. Only those for paths inside watched dir are fired.
  • open

These events pass as arguments: path which triggered it, boolean indicating whether the path is a directory, event name and monitor instance itself.

Additional events:

  • all - fired for all events above
  • start - fired when watchers finished setting up
  • error

Please note that not all backends support all events. fswatch won't emit open and close events; also start is fired immediately after process starts instead of when setup is complete.

The PECL inotify backend recursively registers watches for subdirectories and automatically adds watches for directories created or moved into the watched tree.

Example

$loop = React\EventLoop\Factory::create();

$monitor = (new ReactFilesystemMonitor\FilesystemMonitorFactory())->create('foo/bar', ['modify', 'delete']);
$monitor->on('all', function ($path, $isDir, $event, $monitor) {
    echo sprintf("%s:  %s%s\n", $event, $path, $isDir ? ' [dir]' : '');
});
$monitor->start($loop);

$loop->run();