ingress-nginx-helm/vendor/github.com/yalp/jsonpath/README.md
Manuel Alejandro de Brito Fontes 307bf76454 Update go dependencies
2020-02-19 19:42:50 -03:00

59 lines
2.2 KiB
Markdown

[![Build Status](https://travis-ci.org/yalp/jsonpath.svg?branch=master)](https://travis-ci.org/yalp/jsonpath)
This was mostly an experiment to learn go and test using closures to interpret a JSON path.
You should use https://github.com/PaesslerAG/jsonpath instead.
# jsonpath
a (partial) implementation in [Go](http://golang.org) based on [Stefan Goener JSON Path](http://goessner.net/articles/JsonPath/)
## Limitations
* No support for subexpressions : `$books[(@.length-1)]`
* No support for filters : `$books[?(@.price > 10)]`
* Strings in brackets must use double quotes : `$["bookstore"]`
* Cannot operate on struct fields
The third limitation comes from using the `text/scanner` package from the standard library.
The last one could be overcome by using reflection.
## JsonPath quick intro
All expressions start `$`.
Examples (supported by the current implementation) :
* `$` the current object (or array)
* `$.books` access to the key of an object (or `$["books"]`with bracket syntax)
* `$.books[1]` access to the index of an array
* `$.books[1].authors[1].name` chaining of keys and index
* `$["books"][1]["authors"][1]["name"]` the same with braket syntax
* `$.books[0,1,3]` union on an array
* `$["books", "songs", "movies"]` union on an object
* `$books[1:3]` second and third items of an array
* `$books[:-2:2]` every two items except the last two of an array
* `$books[::-1]` all items in reversed order
* `$..authors` all authors (recursive search)
Checkout the [tests](jsonpath_test.go) for more examples.
## Install
go get github.com/yalp/jsonpath
## Usage
A jsonpath applies to any JSON decoded data using `interface{}` when decoded with [encoding/json](http://golang.org/pkg/encoding/json/) :
var bookstore interface{}
err := json.Unmarshal(data, &bookstore)
authors, err := jsonpath.Read(bookstore, "$..authors")
A jsonpath expression can be prepared to be reused multiple times :
allAuthors, err = jsonpath.Prepare("$..authors")
...
var bookstore interface{}
err := json.Unmarshal(data, &bookstore)
authors, err := allAuthors(bookstore)
The type of the values returned by the `Read` method or `Prepare` functions depends on the jsonpath expression.