A Laravel 5 wrapper for use of the jmespath.php library. The jmespath.php library is an implementation of the JMESPath specification.
This package also provides Artisan commands to pre-compile and manage your JMESPath expressions.
$ composer require libtek/laravel-jmespathIn config/app.php, add the service provider to the $providers array:
'providers' => [
// ...
Libtek\Jmes\JmesServiceProvider::class,
],In config/app.php, add the facade to the $aliases array:
'aliases' => [
// ...
'Jmes' => Libtek\Jmes\Facades\Jmes::class,
],If you'd like to modify the default configuration values or define expressions to pre-compile, publish the package config file:
php artisan vendor:publish --provider="Libtek\Jmes\JmesServiceProvider"This will create a jmes.php file in your config directory.
$result = Jmes::search($expression, $data);$result = jmes($expression, $data);Two Artisan commands are available with the package:
This compiles and caches JMESPath expressions. Expressions can be sourced in multiple ways:
-
Running the command with no options or arguments will look for expressions in the
jmes.phpconfig file:php artisan jmes:compile
-
Passing a single expression to the command:
php artisan jmes:compile 'foo.*.baz' -
Setting the
-cor--clioption will prompt for expressions to be added manually:php artisan jmes:compile --cli Please enter a JMESPath expression: > foo.*.baz
This will delete any previously compiled expressions:
php artisan jmes:clearPass -h or --help to either command to view its usage.