Class JsonSchema

  • All Implemented Interfaces:
    JsonValidator, JsonSchemaWalker

    public class JsonSchema
    extends BaseJsonValidator
    This is the core of json constraint implementation. It parses json constraint file and generates JsonValidators. The class is thread safe, once it is constructed, it can be used to validate multiple json data concurrently.
    • Constructor Detail

      • JsonSchema

        protected JsonSchema​(JsonSchema copy)
        Copy constructor.
        Parameters:
        copy - to copy from
    • Method Detail

      • fromRef

        public JsonSchema fromRef​(JsonSchema refEvaluationParentSchema,
                                  JsonNodePath refEvaluationPath)
        Creates a schema using the current one as a template with the parent as the ref.

        This is typically used if this schema is a schema resource that can be pointed to by various references.

        Parameters:
        refEvaluationParentSchema - the parent ref
        refEvaluationPath - the ref evaluation path
        Returns:
        the schema
      • getCurrentUri

        public URI getCurrentUri()
      • getRefSchemaNode

        public com.fasterxml.jackson.databind.JsonNode getRefSchemaNode​(String ref)
        Find the schema node for $ref attribute.
        Parameters:
        ref - String
        Returns:
        JsonNode
      • findLexicalRoot

        public JsonSchema findLexicalRoot()
      • findSchemaResourceRoot

        public JsonSchema findSchemaResourceRoot()
        Finds the root of the schema resource.

        This is either the schema document root or the subschema resource root.

        Returns:
        the root of the schema
      • isSchemaResourceRoot

        public boolean isSchemaResourceRoot()
        Determines if this schema resource is a schema resource root.

        This is either the schema document root or the subschema resource root.

        Returns:
        if this schema is a schema resource root
      • getId

        public String getId()
      • validate

        public Set<ValidationMessage> validate​(ExecutionContext executionContext,
                                               com.fasterxml.jackson.databind.JsonNode jsonNode,
                                               com.fasterxml.jackson.databind.JsonNode rootNode,
                                               JsonNodePath instanceLocation)
        START OF VALIDATE METHODS
        Parameters:
        executionContext - ExecutionContext
        jsonNode - JsonNode
        rootNode - JsonNode
        instanceLocation - JsonNodePath
        Returns:
        A list of ValidationMessage if there is any validation error, or an empty list if there is no error.
      • validate

        public Set<ValidationMessage> validate​(com.fasterxml.jackson.databind.JsonNode rootNode)
        Validate the given root JsonNode, starting at the root of the data path.
        Parameters:
        rootNode - JsonNode
        Returns:
        A list of ValidationMessage if there is any validation error, or an empty list if there is no error.
      • validate

        public <T> T validate​(com.fasterxml.jackson.databind.JsonNode rootNode,
                              OutputFormat<T> format)
        Validates the given root JsonNode, starting at the root of the data path. The output will be formatted using the formatter specified.
        Type Parameters:
        T - the result type
        Parameters:
        rootNode - the root note
        format - the formatter
        Returns:
        the result
      • validate

        public <T> T validate​(com.fasterxml.jackson.databind.JsonNode rootNode,
                              OutputFormat<T> format,
                              com.networknt.schema.ExecutionCustomizer executionCustomizer)
        Validates the given root JsonNode, starting at the root of the data path. The output will be formatted using the formatter specified.
        Type Parameters:
        T - the result type
        Parameters:
        rootNode - the root note
        format - the formatter
        executionCustomizer - the execution customizer
        Returns:
        the result
      • validateAndCollect

        public ValidationResult validateAndCollect​(com.fasterxml.jackson.databind.JsonNode node)
      • walk

        public ValidationResult walk​(ExecutionContext executionContext,
                                     com.fasterxml.jackson.databind.JsonNode node,
                                     boolean shouldValidateSchema)
        Walk the JSON node
        Parameters:
        executionContext - ExecutionContext
        node - JsonNode
        shouldValidateSchema - indicator on validation
        Returns:
        result of ValidationResult
      • walk

        public ValidationResult walk​(com.fasterxml.jackson.databind.JsonNode node,
                                     boolean shouldValidateSchema)
      • walkAtNode

        public ValidationResult walkAtNode​(ExecutionContext executionContext,
                                           com.fasterxml.jackson.databind.JsonNode node,
                                           com.fasterxml.jackson.databind.JsonNode rootNode,
                                           JsonNodePath instanceLocation,
                                           boolean shouldValidateSchema)
      • walk

        public Set<ValidationMessage> walk​(ExecutionContext executionContext,
                                           com.fasterxml.jackson.databind.JsonNode node,
                                           com.fasterxml.jackson.databind.JsonNode rootNode,
                                           JsonNodePath instanceLocation,
                                           boolean shouldValidateSchema)
        Description copied from interface: JsonValidator
        This is default implementation of walk method. Its job is to call the validate method if shouldValidateSchema is enabled.
        Parameters:
        executionContext - ExecutionContext
        node - JsonNode
        rootNode - JsonNode
        instanceLocation - JsonNodePath
        shouldValidateSchema - boolean
        Returns:
        a set of validation messages if shouldValidateSchema is true.
      • hasRequiredValidator

        public boolean hasRequiredValidator()
      • getRequiredValidator

        public JsonValidator getRequiredValidator()
      • hasTypeValidator

        public boolean hasTypeValidator()
      • initializeValidators

        public void initializeValidators()
        Initializes the validators' JsonSchema instances. For avoiding issues with concurrency, in 1.0.49 the JsonSchema instances affiliated with validators were modified to no more preload the schema and lazy loading is used instead.

        This comes with the issue that this way you cannot rely on validating important schema features, in particular $ref resolution at instantiation from JsonSchemaFactory.

        By calling initializeValidators you can enforce preloading of the JsonSchema instances of the validators.

      • isDynamicAnchor

        public boolean isDynamicAnchor()
      • createExecutionContext

        public ExecutionContext createExecutionContext()
        Creates an execution context.
        Returns:
        the execution context