The Routing component maps an HTTP request to a set of configuration variables.
-
Instantiate the router
$router = new Pure/Routing/Router();
-
define the routes
$router->get('/foo', $callback); // GET method $router->post('/foo', $callback); // POST method $router->put('/foo', $callback); // PUT method $router->delete('/foo', $callback); // DELETE method
$callback can be:
-
a function:
$router->get('/foo', function(){ ... });
-
a string:
function foo(){ ... } $router->get('/foo', 'foo');
where foo is a function.
Besides, the callback can be a controller.
$router->get('/foo', 'FooController@action');
Remember that all the namespace closures must be defined, like in the example:
$router->get('/foo', 'App\Controllers\FooController@action'); $router->get('/foo', 'App\Controllers\FooController::class . '@action');
Is it possible to define namespace alias, like in this example:
$router->namespace('app', 'App\Controllers'); $router->get('/foo', 'app::FooController@action');
-
-
Defining routes with parameters
- Parameters can be defined using (**$**variable) syntax, like in php
$routes->get('/user/$username', function($username){} );
- Parameters can be associated with regular expression
There are 3 types of default regular expression
- i: integer
- a: alphanumeric
- c: characters In this example we define $id as an integer:
It is possible to add new regular expression:$router->get('/user/$id:i', function($id){ ... } );
$router->rule('k', 'regular_expression');
- Parameters can be defined using (**$**variable) syntax, like in php
Middlewares let to check a route before executing it. Let's take an example, try to protect the 'dashboard' navigation from users that are not logged in:
use Pure\Routing\Middleware;
class AuthMiddleware extends Middleware
{
public function handle(){
// returns true if the user is logged in
return MyAuthNamespace\Auth::check();
}
}
$router->get('/dashboard', $callback)->middleware(AuthMiddleware::class);
If the handle function returns false, the route execution is stopped.