samueltissot / wp_route
Installs: 14 996
Dependents: 0
Suggesters: 0
Security: 0
Stars: 20
Watchers: 4
Forks: 35
Open Issues: 0
Requires
- php: >=7.0
Requires (Dev)
- phpunit/phpunit: ^7
This package is auto-updated.
Last update: 2025-06-16 04:54:52 UTC
README
This is a fork of Anthony Budd's WP_Route
Added features
- small security fix
- Named Paths Variable
- renamed parameter to PathVariable
- pass an Request object to the callable function
- option to ignore query string
basic usage
WP_Route::get('/flights/', 'listFlights'); WP_Route::get('/buses/', 'listBuses'); WP_Route::post('/flights/{flight}/', 'singleFlight'); WP_Route::put('/flights/{flight}/book/{date}', 'bookFlight'); WP_Route::delete('/flights/{flight}/delete', 'deleteFlight'); WP_Route::any('flights/{flight}', array('Class', 'staticMethod')); WP_Route::patch('flights/{flight}', array($object, 'method')); WP_Route::match(['get', 'post'], 'flights/{flight}/confirm', 'confirmFlight'); // if you want to take into account the parameters when doing a path match WP_Route::get('/flights/', 'listFlights', ["match" => "*"]); // if you want to match one or more parameters WP_Route::get('/flights/', 'listFlights', ["match" => ['param2', 'param2', ...]]); // redirect WP_Route::redirect('open-google', 'https://google.com', 301); // close WP_Route::get('flights/{flight}', function singleFlight(RequestInterface $req) { $req->pathVariable('flight'); }
the arguments list
[ "parameters" => [ 'match' => [[parameter1] [, parameter2 [, ...]]], 'no_match' => [[parameter1] [, parameter2 [, ...]]], ], ]
NOTE: an empty array means : apply to all
Installation
Require WP_Route with composer
$ composer require samueltissot/wp_route
All Callback must accept a variable of type RequestInterface
a request object is passed to the callable method
note: it is in the plans to be able to provide your custom RequestInterface class (PR accepted)
examples
use samueltissot\WP_Route\RequestInterface; // an invocable class class Controller { public function __invoke(RequestInterface $req) { // code goes here; } } // or a simple function function my_super_func(RequestInterface $req) { // code goes here; } // method inside class class MyAwesomeClass { public function wow(RequestInterface $req) { // code goes here; } }
The Request Object (RequestInterface)
a small helper object that provide usefull data about the request
the Interface
interface RequestInterface { public function uri(); public function method(); public function pathVariables(); public function pathVariable($name); public function parameters(); public function parameter($name); }