designcise / bitframe-whoops
Whoops error handler middleware
Installs: 119
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/designcise/bitframe-whoops
Requires
- php: >=8.2
- filp/whoops: ^2.15
- psr/http-factory: ^1.0
- psr/http-server-handler: ^1.0
- psr/http-server-middleware: ^1.0
Requires (Dev)
- mockery/mockery: ^1.4
- phpmd/phpmd: @stable
- phpstan/phpstan: *
- phpunit/phpunit: ^9.5
- squizlabs/php_codesniffer: 3.*
README
Whoops error handler middleware to handle application or middleware specific errors.
Installation
$ composer require "designcise/bitframe-whoops"
Please note that this package requires PHP 8.2.0 or newer.
Quickstart
Instantiating
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.
How to Run the Middleware
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!');
How Does It Work?
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;
Tests
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 |
Contributing
- File issues at https://github.com/designcise/bitframe-whoops/issues
- Issue patches to https://github.com/designcise/bitframe-whoops/pulls
Documentation
Complete documentation for v3 will be available soon.
License
Please see License File for licensing information.