nivpenso / react-file-watcher
a file watcher package based on reactphp
Installs: 1 770
Dependents: 1
Suggesters: 0
Security: 0
Stars: 18
Watchers: 2
Forks: 1
Open Issues: 0
Requires
- react/event-loop: ^1.1
- yosymfony/resource-watcher: ^3.0
Requires (Dev)
- ext-ev: *
- ext-event: *
- ext-libevent: *
- ext-uv: *
- pestphp/pest: ^1.0
- phpunit/phpunit: ^9
This package is auto-updated.
Last update: 2024-11-04 17:28:48 UTC
README
About
This package is based on reactphp/event-loop and provides an easy-to-use interface to set filesystem watchers and detect changes.
More in depth
The package is utilizing the abstraction of react-php to create an efficient file-watcher using the underlying platform package that is installed on the environment
Support
How to install
composer require nivpenso/react-file-watcher
How to use
code snippet
use React\EventLoop\Factory; use ReactFileWatcher\FileWatcherFactory; use ReactFileWatcher\PathObjects\PathWatcher; // create path to watch in the file system $pathToWatch = new PathWatcher("/tmp/", true); // creating the loop using ReactPHP. $loop = Factory::create(); // creating the file watcher based on the loop. $fileWatcher = FileWatcherFactory::create($loop); // call the watch and execute the callback when detecting change event. $fsevent = $fileWatcher->Watch([$pathToWatch], function($filename) { var_dump($filename); print PHP_EOL; });
Demo
This package comes with a demo that can be used. feel free to run it
Running the demo on local (Linux)
- make sure one of the supported libraries is installed on your environment (suggested:
ext-uv
) - run the following commands
# install dependecies
composer install --no-dev
# run the demo
php ./demo/test.php
After the process started you can start changing files under the path to watch (default: /tmp
) and see the messages in the terminal.
Running the demo on Docker
In case you don't have a linux machine ready, or an environment set up you can use Docker to test it.
# In terminal A run this
docker-compose -f ./demo/docker-compose.yaml up
make a change inside the tmp folder of the container to see the change detection
# In terminal B run this
docker ps # to get the container-id
docker exec -it <container-id> /bin/bash
echo "change" > /tmp/1
On the first terminal you should see the process detect the change.
Testing
This package comes with tests in it. It uses the amazing package, PEST. You can either run the tests on local or use the provided docker file that already contains a ready to use environment with all the required extensions (ev
, uv
, libevent
, event
).
running with PEST on local
composer install
./vendor/bin/pest
using docker to run tests
docker-compose -f ./tests/docker-compose.yaml up