kalimulhaq / json-query
Build Laravel Query Using JSON Query String
Installs: 155
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/kalimulhaq/json-query
Requires
- php: ^7.2|^8.0
- illuminate/support: ^7.0|^8.0
- netresearch/jsonmapper: ^3.0
Requires (Dev)
- orchestra/testbench: ^4.0
- phpunit/phpunit: ^8.0
README
JsonQuery is a query language for your Laravel/Lumen API, which convert JSON query to Laravel Eloquent ORM query.
Installation
You can install the package via composer:
composer require kalimulhaq/json-query
Usage
use Illuminate\Http\Request; use Kalimulhaq\JsonQuery\JsonQueryFacade as JsonQuery; class UsersController extends Controller { public function index(Request $request) { $this->user = $request->user(); $json2query = JsonQuery::init('App\User', $request->filter); $json2query->buildQuery(); $json2query->buildResult($request->limit, $request->page); $result = $json2query->result(); $meta = $json2query->meta(); return response()->json(['data' => $result, 'paginator' => $meta]); } }
Filter
filter is a valid JSON string of the following form
{
"select": [],
"where": {},
"order": [],
"include": [],
"include_count": [],
"scopes": []
}
Example
{
"select": ["id","first_name","last_name","email","phone"],
"where": {
"wildcard": {
"fields": ["first_name","last_name","email","role.name"],
"value": "any keyword"
},
"and": [
{
"field": "email",
"operator": "like",
"value": "test@email.com"
},
{
"field": "phone",
"value": "123456789"
},
{
"or": [
{
"field": "first_name",
"operator": "like",
"value": "kalim"
},
{
"field": "first_name",
"operator": "like",
"value": "juli"
}
]
},
{
"field": "role",
"operator": "where_has",
"value": {
"and": [
{
"field": "name",
"value": "admin"
}
]
}
}
]
},
"include": [
{
"relation": "role",
"select": ["id","name"],
"include": [
{
"relation": "permission",
"select": ["id","name"]
}
]
}
],
"include_count": [
{
"relation": "task"
}
],
"order": [
{
"field": "first_name",
"order": "asc"
},
{
"field": "last_name",
"order": "asc"
}
]
}
Select
select is an array of columns to select from the base model, If removed * will be used
Where
where is a valid json object used to construct the WHERE clause
{
"and": [],
"or": [],
"field": "",
"value": "",
"operator": "",
"sub_operator": ""
}
and
to combine the where clause with AND
or
to combine the where clause with OR
Both and and or are arrays of objects, each object is representing one where clause
{
"field": "",
"value": "",
"operator": "",
"sub_operator": ""
}
If operator removed = will be used as a default operator
The (optional) outside field, value, operator, sub_operator make a singal where clause which will be combined with AND with the and and or groups.
field
column name or relationship name, if operator is has, not_has, where_has, or where_not_has the field will be consider is a relationship
value
any type of value to search. if operator is has, not_has, where_has, or where_not_has the value will be an object of where type
operator
supported operators are =, !=, <, >, <=, >=, between, not_between, in, not_in, null, not_null, date, day, moth, year, time, like, has, not_has, where_has, and where_not_has
sub_operator
sub operator is only required if operator is has or not_has, and supported sub operators are =, !=, <, >, <=, >=
Order
Order is used to order the rows. order is An array of objects
[
{
"field": "first_name",
"order": "asc"
}
]
Include
In order to includes related models. include is an array of objects with same structure of the root filter (see above) object with extra property relation.
{
"relation":"",
"select": [],
"where": {},
"order": [],
"include": [],
"include_count": [],
"scopes": []
}
Include Count
In order to includes related models count. include_count is an array of objects.
{
"relation":"",
"where": {}
}
Changelog
Please see CHANGELOG for more information what has changed recently.
Credits
License
The MIT License (MIT). Please see License File for more information.