vitodtagliente / pure-routing
The Pure Routing Component
Installs: 82
Dependents: 3
Suggesters: 0
Security: 0
Stars: 4
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/vitodtagliente/pure-routing
This package is auto-updated.
Last update: 2025-10-13 16:56:56 UTC
README
The Routing component maps an HTTP request to a set of configuration variables.
HOW TO
- 
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:
 $router->get('/user/$id:i', function($id){ ... } ); It is possible to add new regular expression:$router->rule('k', 'regular_expression'); 
 
- Parameters can be defined using (**$**variable) syntax, like in php
How To define middlewares
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.