Documentation ¶
Overview ¶
Example ¶
package main import ( "encoding/json" "fmt" "log" jsref "github.com/sng2c/jsref" "github.com/sng2c/jsref/provider" ) func main() { var v interface{} src := []byte(` { "foo": ["bar", {"$ref": "#/sub"}, {"$ref": "obj2#/sub"}], "sub": "baz" }`) if err := json.Unmarshal(src, &v); err != nil { log.Printf("%s", err) return } // External reference mp := provider.NewMap() _ = mp.Set("obj2", map[string]string{"sub": "quux"}) res := jsref.New() _ = res.AddProvider(mp) // Register the provider data := []struct { Ptr string Options []jsref.Option }{ { Ptr: "#/foo/0", // "bar" }, { Ptr: "#/foo/1", // "baz" }, { Ptr: "#/foo/2", // "quux" (resolves via `mp`) }, { Ptr: "#/foo", // ["bar",{"$ref":"#/sub"},{"$ref":"obj2#/sub"}] }, { Ptr: "#/foo", // ["bar","baz","quux"] // experimental option to resolve all resulting values Options: []jsref.Option{jsref.WithRecursiveResolution(true)}, }, } for _, set := range data { result, err := res.Resolve(v, set.Ptr, set.Options...) if err != nil { // failed to resolve fmt.Printf("err: %s\n", err) continue } b, _ := json.Marshal(result) fmt.Printf("%s -> %s\n", set.Ptr, string(b)) } }
Output: #/foo/0 -> "bar" #/foo/1 -> "baz" #/foo/2 -> "quux" #/foo -> ["bar",{"$ref":"#/sub"},{"$ref":"obj2#/sub"}] #/foo -> ["bar","baz","quux"]
Index ¶
Examples ¶
Constants ¶
This section is empty.
Variables ¶
var DefaultMaxRecursions = 10
var ErrMaxRecursion = errors.New("reached max number of recursions")
var ErrReferenceLoop = errors.New("reference loop detected")
Functions ¶
This section is empty.
Types ¶
type Option ¶
func WithNilValue ¶
func WithRecursiveResolution ¶
WithRecursiveResolution allows ou to enable recursive resolution on the *result* data structure. This means that after resolving the JSON reference in the structure at hand, it does another pass at resolving the entire data structure. Depending on your structure and size, this may incur significant cost.
Please note that recursive resolution of the result is still experimental. If you find problems, please submit a pull request with a failing test case.
type Resolver ¶
type Resolver struct { MaxRecursions int // contains filtered or unexported fields }
Resolver is responsible for interpreting the provided JSON reference.
func (*Resolver) AddProvider ¶
AddProvider adds a new Provider to be searched for in case a JSON pointer with more than just the URI fragment is given.
func (*Resolver) Resolve ¶
func (r *Resolver) Resolve(v interface{}, ptr string, options ...Option) (ret interface{}, err error)
Resolve takes a target `v`, and a JSON pointer `spec`. spec is expected to be in the form of
[scheme://[userinfo@]host/path[?query]]#fragment [scheme:opaque[?query]]#fragment
where everything except for `#fragment` is optional. If the fragment is empty, an error is returned.
If `spec` is the empty string, `v` is returned This method handles recursive JSON references.
If `WithRecursiveResolution` option is given and its value is true, an attempt to resolve all references within the resulting object is made by traversing the structure recursively. Default is false