LongueVue is now unmaintained. If you're searching for a web scraper, use Goutte. If you're looking for a router, take a look at FastRoute.
LongueVue is a contents extractor built on top of preg_match()
. Concretely, you can extract any string contents from anything, like discover articles on some blog to create a RSS stream per example.
Pick up the source or install it with Composer :
composer require pyrsmk/longuevue
The pattern is a chain with {var}
variables. If the chain matches, then the values are extracted :
$longuevue=new LongueVue('/articles/{id}/comments');
// Will return false
$longuevue->match('/articles');
// Will return false too
$longuevue->match('/articles//comments');
// Will return array('id'=>'72')
$longuevue->match('/articles/72/comments');
// Will return array()
$longuevue->match('/articles//comments');
You can add a validator to the engine for a specific value. If that value does not match the regex validator, then the entire chain won't match at all.
$longuevue=new LongueVue('/articles/{id}/comments');
$longuevue->addValidator('id','\d+');
// Match
$longuevue->match('/articles/72/comments');
// Won't match
$longuevue->match('/articles/some_article/comments');
Also, if the chain can have some missing values, you can declare default ones :
$longuevue=new LongueVue('/articles/{id}/comments');
$longuevue->addDefaultValue('id','1');
// Will return array('id'=>'72')
$longuevue->match('/articles/72/comments');
// Will return array('id'=>'1')
$longuevue->match('/articles//comments');
LongueVue is published under the MIT license.