dotink / journey
Journey is a wrapper for FastRoute which supplies missing functionality
This package's canonical repository appears to be gone and the package has been frozen as a result. Email us for help if needed.
Installs: 895
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 2
Open Issues: 0
pkg:composer/dotink/journey
Requires
- nikic/fast-route: ^1.2
README
Journey is a wrapper around FastRoute which provides some additional functionality by extending the collector and providing a thin wrapping layer around the dispatcher. Additional functionality includes:
- The ability to register shorthand patterns
- Ability to supply a route action resolver
- Ability to define parameter transformations (conversions of parameters to and from URLs)
- Easy link generation (not reverse routing)
- Direct usage of PSR-7 Requests/Response objects
Defining Routes
First we need to create a collection:
$parser = new FastRoute\RouteParser\Std(); $generator = new FastRoute\DataGenerator\GroupCountBased(); $collector = new Dotink\Journey\Collector($parser, $generator);
Once the collection is created, routes can be defined in accordance with FastRoute's documentation:
$collector->addRoute('GET', '/test', 'handler');
Multiple request methods for matching can be defined:
$collector->addRoute(['GET', 'POST'], '/test', 'handler');
And shorthands can be used for a single request type:
$collector->get(/test', 'handler');
Available only to Journey is also the any() method, which will match any one of GET, PUT, PATCH, POST, DELETE, HEAD:
$collector->any(/test', 'handler');
Pattern Matching
FastRoute provides RegEx based pattern matching out of the box, e.g.:
$collector->addRoute('GET', '/user/{id:\d+}', 'handler');
It also provides optional parameters and URL components:
$collector->addRoute('GET', '/user/{id:\d+}[/{name}]', 'handler');
While both of these remain, Journey also provides the ability to register pattern shorthands:
$collector->addPattern('#', '\d+'); $collector->addRoute('GET', '/user/{id:#}', 'handler');
A pattern must match precisely to the string between the : and the closing } in the parameter token and will be swapped out one for one with the RegEx defined as the pattern when the route is added.  If no registered pattern matches precisely, then the pattern will be interpreted as a RegEx.