legatus / router
A fast and composable middleware router inspired in Express.js
Requires
- php: >=7.4
- legatus/http-errors: ^0.1.0
- mnavarrocarter/path-to-regexp-php: ^1.0
- psr/http-server-middleware: ^1.0
Requires (Dev)
- ext-json: *
- friendsofphp/php-cs-fixer: ^2.16
- infection/infection: ^0.16.4
- nyholm/psr7: ^1.2
- phpunit/phpunit: ^9.0
- vimeo/psalm: ^3.7
This package is auto-updated.
Last update: 2024-11-12 20:55:00 UTC
README
A fast and composable middleware router inspired in Express.js
Installation
You can install the Router component using Composer:
composer require legatus/router
Quick Start
<?php declare(strict_types=1); use Legatus\Http\Router; use Legatus\Http\RoutingContext; use Legatus\Http\RoutingContextError; use Psr\Http\Message\ResponseInterface as Resp; use Psr\Http\Message\ServerRequestInterface as Req; use function Legatus\Http\handle_func; /** * @param Req $req * @return Resp * @throws RoutingContextError */ function show_user(Req $req): Resp { $id = RoutingContext::of($req)->getParam('id'); return new Nyholm\Psr7\Response(200, [], 'Hello User ' . $id); } $router = new Router(); $router->get('/users/:id', handle_func('show_user')); $request = new Nyholm\Psr7\ServerRequest('GET', '/users/1'); $response = $router->handle($request); echo $response->getBody() . PHP_EOL; // Hello User 1
For more details you can check the online documentation here.
Project status & release process
While this library is still under development, it is well tested and should be stable enough to use in production environments.
The current releases are numbered 0.x.y. When a non-breaking change is introduced (adding new methods, optimizing existing code, etc.), y is incremented.
When a breaking change is introduced, a new 0.x version cycle is always started.
It is therefore safe to lock your project to a given release cycle, such as 0.2.*.
If you need to upgrade to a newer release cycle, check the release history for a list of changes introduced by each further 0.x.0 version.
Community
We still do not have a community channel. If you would like to help with that, you can let me know!
Contributing
Read the contributing guide to know how can you contribute to Legatus.
Security Issues
Please report security issues privately by email and give us a period of grace before disclosing.
About Legatus
Legatus is a personal open source project led by MatÃas Navarro Carter and developed by contributors.