Whoops error handler middleware to handle application or middleware specific errors.
$ composer require "designcise/bitframe-whoops"
Please note that this package requires PHP 8.2.0 or newer.
The constructor has the following signature:
new ErrorHandler(
ResponseFactoryInterface,
HandlerProviderNegotiator::class,
[options],
);- The first argument to the constructor must be an instance of
Psr\Http\Message\ResponseFactoryInterface; - The second argument to the constructor must be an implementation of
\BitFrame\Whoops\Provider\ProviderInterface; - The third argument to the constructor is an optional array of options to specify the following:
catchGlobalErrors: When set totrueerrors will be handled outside of current batch of middleware set.- Other options are simply method names in
Whoops\Handler\*Handler.phpandBitFrame\Whoops\Handler\*Handler.php. For example, to setWhoops\Handler\JsonResponseHandler::setJsonApi()you would pass in:['setJsonApi' => false], etc.
As a shortcut, you can also use the static method ErrorHandler::fromNegotiator($factory, $options). This would use the \BitFrame\Whoops\Provider\HandlerProviderNegotiator by default.
To run the middleware, simply pass in a BitFrame\Whoops\ErrorHandler instance to your middleware runner / dispatcher.
For example, to handle middleware-specific errors with BitFrame\App (or other PSR-15 dispatchers) it would look something like this:
use BitFrame\App;
use BitFrame\Emitter\SapiEmitter;
use BitFrame\Whoops\ErrorHandler;
use BitFrame\Whoops\Provider\HandlerProviderNegotiator;
use BitFrame\Factory\HttpFactory;
$app = new App();
$middleware = function () {
throw new \Exception('hello world!');
};
$app->use([
SapiEmitter::class,
new ErrorHandler(HttpFactory::getFactory(), HandlerProviderNegotiator::class, [
'addTraceToOutput' => true,
'setJsonApi' => false,
]),
$middleware,
]);
$app->run();To handle global errors with BitFrame\App (or other PSR-15 dispatchers) it would look something like this:
use BitFrame\App;
use BitFrame\Whoops\ErrorHandler;
use BitFrame\Factory\HttpFactory;
$app = new App();
$app->run([
ErrorHandler::fromNegotiator(HttpFactory::getFactory(), [
'catchGlobalErrors' => true,
'addTraceToOutput' => true,
'setJsonApi' => false,
]),
]);
throw new \Exception('hello world!');The error handler middleware automatically determines the error handler to use based on the Accept header. The following error handler providers are included:
BitFrame\Whoops\Provider\HtmlHandlerProviderforWhoops\Handler\PrettyPageHandler;BitFrame\Whoops\Provider\JsonHandlerProviderforWhoops\Handler\JsonResponseHandler;BitFrame\Whoops\Provider\JsonpHandlerProviderforBitFrame\Whoops\Handler\JsonpResponseHandler;BitFrame\Whoops\Provider\TextHandlerProviderforWhoops\Handler\PlainTextHandler;BitFrame\Whoops\Provider\XmlHandlerProviderforWhoops\Handler\XmlResponseHandler;
To run the tests you can use the following commands:
| Command | Type |
|---|---|
composer test |
PHPUnit tests |
composer style |
CodeSniffer |
composer md |
MessDetector |
composer check |
PHPStan |
- File issues at https://github.com/designcise/bitframe-whoops/issues
- Issue patches to https://github.com/designcise/bitframe-whoops/pulls
Complete documentation for v3 will be available soon.
Please see License File for licensing information.