commit | 61c71b4cd4d9ff8dde6a54ba62673dce3b288347 | [log] [tgz] |
---|---|---|
author | Tim Olsen <tim.olsen@10gen.com> | Thu Sep 05 15:24:54 2013 -0400 |
committer | Tim Olsen <tim.olsen@10gen.com> | Thu Sep 05 15:24:54 2013 -0400 |
tree | d3a8081919091dc1383d1b5f939416d0d247a38d | |
parent | bbf173de1855f77ea6ec3d0b213134f7ad32f077 [diff] | |
parent | 1ed844256517a11a8bb9c7ed4d35ef1ff5480b5b [diff] |
Merge remote-tracking branch 'sigu-399/master' into add-context-to-error-messages Conflicts: validation.go
An implementation of JSON Schema, based on IETF's draft v4 - Go language
Functional, two features are missing : dependencies as schemas and id(s) as scope for references
Test phase : Passed 97% of Json Schema Test Suite
Internal improvements/refactoring in progress, anyway the interface will not change
package main import ( "github.com/sigu-399/gojsonschema" "fmt" ) func main() { schema, err := gojsonschema.NewJsonSchemaDocument("http://myhost/bla/schema1.json") // OR //schema, err := gojsonschema.NewJsonSchemaDocument("file:///home/me/myschemas/schema1.json") if err != nil { panic(err.Error()) } jsonToValidate, err := gojsonschema.GetHttpJson("http://myotherhost/blu/extract56.json") // OR //jsonToValidate, err := gojsonschema.GetFileJson("/home/billy/hotels.json") if err != nil { panic(err.Error()) } validationResult := schema.Validate(jsonToValidate) fmt.Printf("IsValid %v\n", validationResult.IsValid()) fmt.Printf("%v\n", validationResult.GetErrorMessages()) }
###Website http://json-schema.org
###Schema Core http://json-schema.org/latest/json-schema-core.html
###Schema Validation http://json-schema.org/latest/json-schema-validation.html
https://github.com/sigu-399/gojsonpointer
https://github.com/sigu-399/gojsonreference
gojsonschema uses the following test suite :