Giter Site home page Giter Site logo

odata-query-parser's Introduction

odata-query-parser

Parse OData v4 query strings.

Packagist Version Packagist PHP from Packagist Build Status Maintainability Known Vulnerabilities

Summary

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

Installation

Add the package to your dependencies:

composer require khalyomede/odata-query-parser

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.

use Khalyomede\OdataQueryParser;

$data = OdataQueryParser::parse('http://example.com/api/user?$select=id,name,age');

If you inspect $data, this is what you will get:

[
  "select" => [
    "id",
    "name",
    "age"
  ]
]

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.

use Khalyomede/OdataQueryParser;

$data = OdataQueryParser::parse("http://example.com/api/user?select=id,name,age", $withDollar = false);

If you inspect $data, this is what you will get:

[
  "select" => [
    "id",
    "name",
    "age"
  ]
]

API

OdataQueryParser::parse(string $url, bool $withDollar = true): array;

parameters

  • string $url: The URL to parse the query strings from. It should be a "complete" or "full" URL, which means that http://example.com will pass while example.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 keys.

returns

An associative array:

return = [
	string? "select" => array<string>,
	string? "count" => bool,
	string? "top" => int,
	string? "skip" => int,
	string? "orderBy" => array<OrderBy>,
	string? "filter" => array<Filter>
];

OrderBy = [
	string "property" => string,
	string "direction" => Direction
]

Direction = "asc" | "desc"

Filter = [
	string "left" => string,
	string "operator" => string,
	string "right" => mixed
]

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 direction of the $orderby query string value is neither asc or desc

Known issues

  • $filter command will not parse or and functions (like contains() of substringof), because I did not focused on this for the moment (the parser for $filter is too simplist, I should find a way to create an AST).

odata-query-parser's People

Contributors

khalyomede avatar

Stargazers

 avatar  avatar

Watchers

 avatar  avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.