Download the PHP package globyapp/odata-query-parser without Composer
On this page you can find all versions of the php package globyapp/odata-query-parser. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download globyapp/odata-query-parser
More information about globyapp/odata-query-parser
Files in globyapp/odata-query-parser
Package odata-query-parser
Short Description Parse OData v4 query strings, outputs proper PHP objects.
License MIT
Informations about the package odata-query-parser
Odata Query Parser
Parse OData v4 query strings, outputs proper PHP objects.
Summary
- About
- Features
- Requirements
- Installation
- Examples
- API
- Known issues
- Thanks
About
I needed to only parse query strings to convert OData v4 commands into an understandable array that I could use to make a Laravel package to offer a way to automatically use Eloquent to filter the response according to this parsed array of OData v4 command.
As I did not see a package exclusively dealing with parsing the query strings, and saw that some people worked on their own without open sourcing it, I decided I would start one myself.
Features
- Parses an URL and returns an array
- Supports
$select
,$top
,$skip
,$orderby
,$count
- Partial support for
$filter
(see Known issues section) - You can use a parse mode that let you parse these keywords without prepending
$
Requirements
- PHP >= 8.2.0
- Composer
Installation
Add the package to your dependencies:
Examples
1. Use \$select to filter on some fields
In this example, we will use the $select
OData query string command to filter the fields returned by our API.
If you inspect $data
, this is what you will get:
2. Use non dollar syntax
In this example, we will use a unique feature of this library: to be able to not specify any dollar, while still being able to use the OData v4 URL query parameter grammar.
If you inspect $data
, this is what you will get:
API
Parameters
- string
$url
: The URL to parse the query strings from. It should be a "complete" or "full" URL, which means thathttps://example.com
will pass whileexample.com
will not pass - bool
$withDollar
: Set it to false if you want to parse query strings without having to add the$
signs before each key.
Returns
An OdataQuery object:
Throws
InvalidArgumentException
- If the parameter
$url
is not a valid URL (see the parameter description to know what is a valid URL) - If the
$top
query string value is not an integer - If the
$top
query string value is lower than 0 - If the
$skip
query string value is not an integer - If the
$skip
query string value is lower than 0 - If the
$count
query string value is not a boolean - If the formatting of
$orderby
is not valid (should be a property, space and the direction) - If the direction of the
$orderby
query string value is neitherasc
ordesc
(case-insensitive) - This will throw an InvalidDirectionException, inheriting InvalidArgumentException.
- If the formatting of
$filter
is not valid (should be a property, space, operator, space and value) - If the operator of the
$filter
query string value is noteq
,ne
,gt
,ge
,lt
,le
orin
(case-insensitive) - This will throw an InvalidFilterOperatorException, inheriting InvalidArgumentException.
- If the parameter
LogicException
- If an unforeseen edge case is triggered by an input value. For example when a regex operation fails. Should never be thrown under normal operation.
- If an edge case is found, please report them as an issue. Currently, I cannot write test cases for them as I don't know how to trigger them.
Known issues
$filter
command will not parseor
and functions (likecontains()
ofsubstringof
), because I did not focus on this for the moment (the parser for$filter
is too simplistic, I should find a way to create an AST).
Thanks
Feel free to open any issues or PRs.
MIT © 2024
All versions of odata-query-parser with dependencies
ext-mbstring Version *