nikic / include-interceptor
Intercept PHP includes
Installs: 5 615
Dependents: 2
Suggesters: 0
Security: 0
Stars: 69
Watchers: 5
Forks: 3
Open Issues: 2
Requires
- php: >=7.1
Requires (Dev)
- phpunit/phpunit: ^7 || ^8
This package is auto-updated.
Last update: 2024-12-13 10:12:48 UTC
README
Library to intercept PHP includes. A fork of icewind1991/interceptor.
composer require nikic/include-interceptor
Usage
use Nikic\IncludeInterceptor\Interceptor; $interceptor = new Interceptor(function(string $path) { if (!wantToIntercept($path)) { return null; } return transformCode(file_get_contents($path)); }); $interceptor->setUp(); // Start intercepting includes require 'src/foo.php'; $interceptor->tearDown(); // Stop intercepting includes
The interception hook follows the following contract:
- It is only called if the included file exists.
- The passed
$path
is the realpath. - If the hook returns
null
, no interception is performed. - If the hook returns a string, these are taken as the transformed content of the file.
For convenience, a FileFilter
is provided that implements white- and black-listing
of files and directories. Paths passed to addBlackList()
and addWhiteList()
should
always be realpaths.
use Nikic\IncludeInterceptor\Interceptor; use Nikic\IncludeInterceptor\FileFilter; $fileFilter = FileFilter::createAllWhitelisted(); // Start with everything whitelisted $fileFilter->addBlackList(__DIR__ . '/src/'); // Blacklist the src/ directory $fileFilter->addWhiteList(__DIR__ . '/src/foo.php'); // But whitelist the src/foo.php file $interceptor = new Interceptor(function(string $path) use ($fileFilter) { if (!$fileFilter->test($path)) { return null; } return transformCode(file_get_contents($path)); }); $interceptor->setUp(); require 'src/foo.php';