avalanche-development / talus
Microframework with Swagger routing
Requires
- php: >=5.6.0
- avalanche-development/crash-pad: ^0.5
- avalanche-development/peel: ^0.3
- avalanche-development/swagger-caster-middleware: ^0.2
- avalanche-development/swagger-header-middleware: ^0.3
- avalanche-development/swagger-router-middleware: ^1.2
- avalanche-development/swagger-validation-middleware: ^0.5
- psr/http-message: ^1.0
- psr/log: ^1.0
- zendframework/zend-diactoros: ^1.3
Requires (Dev)
- codeclimate/php-test-reporter: ^0.3
- php-mock/php-mock-phpunit: ^1.1
- phpunit/phpunit: ^5.7
This package is not auto-updated.
Last update: 2024-11-21 02:51:04 UTC
README
PHP microframework that leverages swagger documentation to handle routing.
Installation
It's recommended that you use Composer to install talus.
$ composer require avalanche-development/talus
talus requires PHP 5.6 or newer.
Usage
This microframework uses swagger-router-middleware to parse and understand a provided swagger documentation. It also uses peel http exceptions and crash-pad to standardize error responses. To instantiate talus, you'll need to provide the swagger document in the form of an array.
$talus = new AvalancheDevelopment\Talus\Talus([..swagger..]);
The parsed swagger information is available via the swagger
attribute on the request. In your application, you can access this information like so.
function ($request, $response) { $someParameter = $request->getAttribute('swagger')['params']['someParameter']; }
Controllers
Controllers are attached to routes by the operationId in the swagger spec. Each operation should have a unique operationId, and this will inform talus which controller to invoke. Controllers must be callable and have a function ($request, $response)
interface.
$talus->addController('getThing', function ($request, $response) { // get that thing }); $talus->addController('getComplexThing', function ($request, $response) use ($db) { return (new Controller($db))->getComplexThing($request, $response); });
Middleware
Middleware can be added onto the stack and will be executed in the order they are added. As a note, the first executed piece of middleware will always be swagger-router-middleware
(which will give you a swagger
attribute with all sorts of goodies in it) and the last executed piece will always be the provided controller callable.
$talus->addMiddleware(function ($request, $response, $next) {
// do something
return $next($request, $response);
});
Error Handling
Any exceptions thrown during the stack, which includes routing errors and request body parsing failures, will be caught and passed through to the error handler. Some of these exceptions implement HttpErrorInterface
peel
, making them easier to deal with. The default error handler crash-pad
provided will handle this and return a standard response, though you can totally roll your own.
$talus->setErrorHandler(function ($request, $response, $exception) {
// do something with that exception
return $response;
});
It is recommended that you throw exceptions, especially peel
ones, within your controllers instead of trying to handle the error yourself. This will keep things standardized.
Execution
Once the controllers are set, middleware is stacked on, and error handler is customized, all that's left to do is to run the app. This will walk through the middleware stack and execute the appropriate controller, then walk back through middleware and output the provided response object. If there are any problems along the way the error handler should capture them and return a relevant error message.
$talus = new AvalancheDevelopment\Talus\Talus([..swagger..]);
$talus->addController(..callback..);
$talus->addMiddleware(..callback..);
$talus->run();
Documentation Route
This is a feature of swagger-router-middleware
. If the standard 'documentation route' is detected (path of /api-docs), the rest of the stack is immediately skipped and the swagger spec is returned as json. An error with json_encode will throw a standard \Exception.
Tests
To execute the test suite, you'll need phpunit (and to install package with dev dependencies).
$ phpunit
License
talus is licensed under the MIT license. See License File for more information.