Documentation ¶
Index ¶
- type AdditionalProperties
- type Discriminator
- type ExternalResolver
- type NoExternal
- type Num
- type Parser
- type PatternProperty
- type Property
- type RawPatternProperties
- type RawPatternProperty
- type RawProperties
- type RawProperty
- type RawSchema
- type ReferenceResolver
- type RootResolver
- type Schema
- type SchemaType
- type Settings
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type AdditionalProperties ¶
AdditionalProperties is JSON Schema additionalProperties validator description.
func (AdditionalProperties) MarshalJSON ¶
func (p AdditionalProperties) MarshalJSON() ([]byte, error)
MarshalJSON implements json.Marshaler.
func (*AdditionalProperties) UnmarshalJSON ¶
func (p *AdditionalProperties) UnmarshalJSON(data []byte) error
UnmarshalJSON implements json.Unmarshaler.
type Discriminator ¶
type Discriminator struct { PropertyName string `json:"propertyName"` Mapping map[string]string `json:"mapping,omitempty"` }
Discriminator is JSON Schema discriminator description.
type ExternalResolver ¶ added in v0.36.0
ExternalResolver resolves external links.
type NoExternal ¶ added in v0.37.0
type NoExternal struct{}
NoExternal is ExternalResolver that always returns error.
type Num ¶ added in v0.16.0
Num represents JSON number.
func (Num) MarshalJSON ¶ added in v0.17.1
MarshalJSON implements json.Marshaler.
func (*Num) UnmarshalJSON ¶ added in v0.16.0
UnmarshalJSON implements json.Unmarshaler.
type Parser ¶
type Parser struct {
// contains filtered or unexported fields
}
Parser parses JSON schemas.
type PatternProperty ¶ added in v0.23.0
PatternProperty is a property pattern.
type Property ¶
type Property struct { Name string // Property name. Description string // Property description. Schema *Schema // Property schema. Required bool // Whether the field is required or not. }
Property is a JSON Schema Object property.
type RawPatternProperties ¶ added in v0.23.0
type RawPatternProperties []RawPatternProperty
RawPatternProperties is unparsed JSON Schema patternProperties validator description.
func (RawPatternProperties) MarshalJSON ¶ added in v0.23.0
func (r RawPatternProperties) MarshalJSON() ([]byte, error)
MarshalJSON implements json.Marshaler.
func (*RawPatternProperties) UnmarshalJSON ¶ added in v0.23.0
func (r *RawPatternProperties) UnmarshalJSON(data []byte) error
UnmarshalJSON implements json.Unmarshaler.
type RawPatternProperty ¶ added in v0.23.0
RawPatternProperty is item of RawPatternProperties.
type RawProperties ¶
type RawProperties []RawProperty
RawProperties is unparsed JSON Schema properties validator description.
func (RawProperties) MarshalJSON ¶
func (p RawProperties) MarshalJSON() ([]byte, error)
MarshalJSON implements json.Marshaler.
func (*RawProperties) UnmarshalJSON ¶
func (p *RawProperties) UnmarshalJSON(data []byte) error
UnmarshalJSON implements json.Unmarshaler.
type RawProperty ¶
RawProperty is item of RawProperties.
type RawSchema ¶
type RawSchema struct { Ref string `json:"$ref,omitempty"` Summary string `json:"summary,omitempty"` Description string `json:"description,omitempty"` Type string `json:"type,omitempty"` Format string `json:"format,omitempty"` Properties RawProperties `json:"properties,omitempty"` AdditionalProperties *AdditionalProperties `json:"additionalProperties,omitempty"` PatternProperties RawPatternProperties `json:"patternProperties,omitempty"` Required []string `json:"required,omitempty"` Items *RawSchema `json:"items,omitempty"` Nullable bool `json:"nullable,omitempty"` AllOf []*RawSchema `json:"allOf,omitempty"` OneOf []*RawSchema `json:"oneOf,omitempty"` AnyOf []*RawSchema `json:"anyOf,omitempty"` Discriminator *Discriminator `json:"discriminator,omitempty"` Enum []json.RawMessage `json:"enum,omitempty"` MultipleOf Num `json:"multipleOf,omitempty"` Maximum Num `json:"maximum,omitempty"` ExclusiveMaximum bool `json:"exclusiveMaximum,omitempty"` Minimum Num `json:"minimum,omitempty"` ExclusiveMinimum bool `json:"exclusiveMinimum,omitempty"` MaxLength *uint64 `json:"maxLength,omitempty"` MinLength *uint64 `json:"minLength,omitempty"` Pattern string `json:"pattern,omitempty"` MaxItems *uint64 `json:"maxItems,omitempty"` MinItems *uint64 `json:"minItems,omitempty"` UniqueItems bool `json:"uniqueItems,omitempty"` MaxProperties *uint64 `json:"maxProperties,omitempty"` MinProperties *uint64 `json:"minProperties,omitempty"` Default json.RawMessage `json:"default,omitempty"` Example json.RawMessage `json:"example,omitempty"` Deprecated bool `json:"deprecated,omitempty"` XAnnotations map[string]jx.Raw `json:"-"` }
RawSchema is unparsed JSON Schema.
func (*RawSchema) UnmarshalJSON ¶ added in v0.25.0
UnmarshalJSON implements json.Unmarshaler.
type ReferenceResolver ¶
ReferenceResolver resolves JSON schema references.
type RootResolver ¶ added in v0.22.0
type RootResolver struct {
// contains filtered or unexported fields
}
RootResolver is ReferenceResolver implementation.
func NewRootResolver ¶ added in v0.22.0
func NewRootResolver(root []byte) *RootResolver
NewRootResolver creates new RootResolver.
func (*RootResolver) ResolveReference ¶ added in v0.22.0
func (r *RootResolver) ResolveReference(ref string) (rawSchema *RawSchema, err error)
ResolveReference implements ReferenceResolver.
type Schema ¶
type Schema struct { XOgenName string // Annotation to set type name. Type SchemaType Format string // Schema format, optional. Summary string // Schema summary from Reference Object, optional. Description string // Schema description, optional. Ref string // Whether schema is referenced. Item *Schema // Only for Array and Object with additional properties. AdditionalProperties *bool // Whether Object has additional properties. PatternProperties []PatternProperty // Only for Object. Enum []interface{} // Only for Enum. Properties []Property // Only for Object. Nullable bool // Whether schema is nullable or not. Any types. OneOf []*Schema AnyOf []*Schema AllOf []*Schema Discriminator *Discriminator // Numeric validation (Integer, Number). Maximum Num ExclusiveMaximum bool Minimum Num ExclusiveMinimum bool MultipleOf Num // String validation. MaxLength *uint64 MinLength *uint64 Pattern string // Array validation. MaxItems *uint64 MinItems *uint64 UniqueItems bool // Object validation. MaxProperties *uint64 MinProperties *uint64 Examples []json.RawMessage // Default schema value. Default interface{} DefaultSet bool }
Schema is a JSON Schema.
func (*Schema) AddExample ¶
func (s *Schema) AddExample(r json.RawMessage)
AddExample adds example for this Schema.
type SchemaType ¶
type SchemaType string
SchemaType is a JSON Schema type.
const ( // Empty is empty (unset) schema type. Empty SchemaType = "" // OneOf, AnyOf, AllOf. // Object is "object" schema type. Object SchemaType = "object" // Array is "array" schema type. Array SchemaType = "array" // Integer is "integer" schema type. Integer SchemaType = "integer" // Number is "number" schema type. Number SchemaType = "number" // String is "string" schema type. String SchemaType = "string" // Boolean is "boolean" schema type. Boolean SchemaType = "boolean" // Null is "null" schema type. Null SchemaType = "null" )
type Settings ¶
type Settings struct { External ExternalResolver // Resolver is a root resolver. Resolver ReferenceResolver // Enables type inference. // // For example: // // { // "items": { // "type": "string" // } // } // // In that case schemaParser will handle that schema as "array" schema, because it has "items" field. InferTypes bool }
Settings is parser settings.