Documentation ¶
Overview ¶
Example ¶
s, err := schema.ReadFile("schema.json") if err != nil { log.Printf("failed to read schema: %s", err) return } for name, pdef := range s.Properties { // Do what you will with `pdef`, which contain // Schema information for `name` property _ = name _ = pdef } // Create a validator v := validator.New(s) // You can also validate an arbitrary piece of data var p interface{} // initialize using json.Unmarshal... if err := v.Validate(p); err != nil { log.Printf("failed to validate data: %s", err) }
Output:
Index ¶
- Constants
- Variables
- type AdditionalItems
- type AdditionalProperties
- type Bool
- type DependencyMap
- type ErrExtract
- type ErrInvalidFieldValue
- type ErrInvalidReference
- type ErrMaxItemsValidationFailed
- type ErrMaxLengthValidationFailed
- type ErrMaxPropertiesValidationFailed
- type ErrMaximumValidationFailed
- type ErrMinItemsValidationFailed
- type ErrMinLengthValidationFailed
- type ErrMinPropertiesValidationFailed
- type ErrMinimumValidationFailed
- type ErrPatternValidationFailed
- type ErrRequiredField
- type Format
- type Integer
- type ItemSpec
- type Number
- type PrimitiveType
- type PrimitiveTypes
- type Schema
- func (s Schema) BaseURL() *url.URL
- func (s *Schema) Decode(in io.Reader) error
- func (s *Schema) Extract(m map[string]interface{}) error
- func (s Schema) IsPropRequired(pname string) bool
- func (s Schema) MarshalJSON() ([]byte, error)
- func (s *Schema) Resolve() (ref *Schema, err error)
- func (s Schema) ResolveURL(v string) (u *url.URL, err error)
- func (s *Schema) Root() *Schema
- func (s Schema) Scope() string
- func (s *Schema) UnmarshalJSON(data []byte) error
- type SchemaList
Examples ¶
Constants ¶
View Source
const ( SchemaURL = `http://json-schema.org/draft-04/schema` HyperSchemaURL = `http://json-schema.org/draft-03/hyper-schema` MIMEType = "application/schema+json" )
Variables ¶
View Source
var ( ErrAdditionalProperties = errors.New("additional properties are not allowed") ErrAnyOfValidationFailed = errors.New("'anyOf' validation failed") ErrArrayItemValidationFailed = errors.New("'array' validation failed") ErrInvalidStringArray = errors.New("invalid value: expected array of string") ErrDependencyItemType = errors.New("'dependency' elements must be a array of strings or a schema") ErrOneOfValidationFailed = errors.New("'oneOf' validation failed") ErrIntegerValidationFailed = errors.New("'integer' validation failed") ErrInvalidEnum = errors.New("invalid enum type") ErrInvalidFormat = errors.New("invalid format") ErrInvalidHostname = errors.New("invalid hostname") ErrInvalidIPv4 = errors.New("invalid IPv4 address") ErrInvalidIPv6 = errors.New("invalid IPv6 address") ErrInvalidSchemaList = errors.New("invalid schema list") ErrInvalidType = errors.New("invalid type") ErrMissingDependency = errors.New("missing dependency") ErrMultipleOfValidationFailed = errors.New("'multipleOf' validation failed") ErrNotValidationFailed = errors.New("'not' validation failed") ErrNumberValidationFailed = errors.New("'number' validation failed") ErrPropNotFound = errors.New("property not found") ErrUniqueItemsValidationFailed = errors.New("'uniqueItems' validation failed") ErrSchemaNotFound = errors.New("schema not found") )
Functions ¶
This section is empty.
Types ¶
type AdditionalItems ¶
type AdditionalItems struct {
*Schema
}
type AdditionalProperties ¶
type AdditionalProperties struct {
*Schema
}
type DependencyMap ¶
DependencyMap contains the dependencies defined within this schema. for a given dependency name, you can have either a schema or a list of property names
type ErrExtract ¶
func (ErrExtract) Error ¶
func (e ErrExtract) Error() string
type ErrInvalidFieldValue ¶
func (ErrInvalidFieldValue) Error ¶
func (e ErrInvalidFieldValue) Error() string
type ErrInvalidReference ¶
func (ErrInvalidReference) Error ¶
func (e ErrInvalidReference) Error() string
type ErrMaxItemsValidationFailed ¶
func (ErrMaxItemsValidationFailed) Error ¶
func (e ErrMaxItemsValidationFailed) Error() string
type ErrMaxLengthValidationFailed ¶
func (ErrMaxLengthValidationFailed) Error ¶
func (e ErrMaxLengthValidationFailed) Error() string
type ErrMaxPropertiesValidationFailed ¶
func (ErrMaxPropertiesValidationFailed) Error ¶
func (e ErrMaxPropertiesValidationFailed) Error() string
type ErrMaximumValidationFailed ¶
func (ErrMaximumValidationFailed) Error ¶
func (e ErrMaximumValidationFailed) Error() string
type ErrMinItemsValidationFailed ¶
func (ErrMinItemsValidationFailed) Error ¶
func (e ErrMinItemsValidationFailed) Error() string
type ErrMinLengthValidationFailed ¶
func (ErrMinLengthValidationFailed) Error ¶
func (e ErrMinLengthValidationFailed) Error() string
type ErrMinPropertiesValidationFailed ¶
func (ErrMinPropertiesValidationFailed) Error ¶
func (e ErrMinPropertiesValidationFailed) Error() string
type ErrMinimumValidationFailed ¶
func (ErrMinimumValidationFailed) Error ¶
func (e ErrMinimumValidationFailed) Error() string
type ErrPatternValidationFailed ¶
func (ErrPatternValidationFailed) Error ¶
func (e ErrPatternValidationFailed) Error() string
type ErrRequiredField ¶
type ErrRequiredField struct {
Name string
}
func (ErrRequiredField) Error ¶
func (e ErrRequiredField) Error() string
type ItemSpec ¶
type ItemSpec struct { TupleMode bool // If this is true, the positions mean something. if false, len(Schemas) should be 1, and we should apply the same schema validation to all elements Schemas SchemaList }
type PrimitiveType ¶
type PrimitiveType int
const ( UnspecifiedType PrimitiveType = iota NullType IntegerType StringType ObjectType ArrayType BooleanType NumberType )
func (PrimitiveType) MarshalJSON ¶
func (t PrimitiveType) MarshalJSON() ([]byte, error)
func (PrimitiveType) String ¶
func (t PrimitiveType) String() string
func (*PrimitiveType) UnmarshalJSON ¶
func (t *PrimitiveType) UnmarshalJSON(data []byte) error
type PrimitiveTypes ¶
type PrimitiveTypes []PrimitiveType
func (PrimitiveTypes) Contains ¶
func (ts PrimitiveTypes) Contains(p PrimitiveType) bool
func (PrimitiveTypes) Len ¶
func (pt PrimitiveTypes) Len() int
func (PrimitiveTypes) Less ¶
func (pt PrimitiveTypes) Less(i, j int) bool
func (PrimitiveTypes) Swap ¶
func (pt PrimitiveTypes) Swap(i, j int)
func (*PrimitiveTypes) UnmarshalJSON ¶
func (ts *PrimitiveTypes) UnmarshalJSON(data []byte) error
type Schema ¶
type Schema struct { ID string `json:"id,omitempty"` Title string `json:"title,omitempty"` Description string `json:"description,omitempty"` Default interface{} `json:"default,omitempty"` Type PrimitiveTypes `json:"type,omitempty"` SchemaRef string `json:"$schema,omitempty"` Definitions map[string]*Schema `json:"definitions,omitempty"` Reference string `json:"$ref,omitempty"` Format Format `json:"format,omitempty"` // NumericValidations MultipleOf Number `json:"multipleOf,omitempty"` Minimum Number `json:"minimum,omitempty"` Maximum Number `json:"maximum,omitempty"` ExclusiveMinimum Bool `json:"exclusiveMinimum,omitempty"` ExclusiveMaximum Bool `json:"exclusiveMaximum,omitempty"` // StringValidation MaxLength Integer `json:"maxLength,omitempty"` MinLength Integer `json:"minLength,omitempty"` Pattern *regexp.Regexp `json:"pattern,omitempty"` // ArrayValidations AdditionalItems *AdditionalItems Items *ItemSpec MinItems Integer MaxItems Integer UniqueItems Bool // ObjectValidations MaxProperties Integer `json:"maxProperties,omitempty"` MinProperties Integer `json:"minProperties,omitempty"` Required []string `json:"required,omitempty"` Dependencies DependencyMap `json:"dependencies,omitempty"` Properties map[string]*Schema `json:"properties,omitempty"` AdditionalProperties *AdditionalProperties `json:"additionalProperties,omitempty"` PatternProperties map[*regexp.Regexp]*Schema `json:"patternProperties,omitempty"` Enum []interface{} `json:"enum,omitempty"` AllOf SchemaList `json:"allOf,omitempty"` AnyOf SchemaList `json:"anyOf,omitempty"` OneOf SchemaList `json:"oneOf,omitempty"` Not *Schema `json:"not,omitempty"` // contains filtered or unexported fields }
func (Schema) IsPropRequired ¶
func (Schema) MarshalJSON ¶
func (*Schema) Resolve ¶
Resolve returns the schema after it has been resolved. If s.Reference is the empty string, the current schema is returned.
func (*Schema) UnmarshalJSON ¶
type SchemaList ¶
type SchemaList []*Schema
func (*SchemaList) Extract ¶
func (l *SchemaList) Extract(v interface{}) error
func (*SchemaList) ExtractIfPresent ¶
func (l *SchemaList) ExtractIfPresent(m map[string]interface{}, name string) error
Click to show internal directories.
Click to hide internal directories.