com.github.fge.jsonschema.keyword.digest.Digester Maven / Gradle / Ivy
/*
* Copyright (c) 2013, Francis Galiegue
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the Lesser GNU General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* Lesser GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
package com.github.fge.jsonschema.keyword.digest;
import com.fasterxml.jackson.databind.JsonNode;
import com.github.fge.jsonschema.keyword.validator.KeywordValidator;
import com.github.fge.jsonschema.processors.digest.SchemaDigester;
import com.github.fge.jsonschema.processors.validation.ArraySchemaDigester;
import com.github.fge.jsonschema.processors.validation.ObjectSchemaDigester;
import com.github.fge.jsonschema.util.NodeType;
import java.util.EnumSet;
/**
* Interface for a digester
*
* A digester, as its name implies, digests a schema (which comes here as a
* {@link JsonNode}) and returns a simplified form of it, according to its
* context.
*
* It is mainly used for keywords, for building a simplified form of a schema
* in order to ease the job of keyword construction; but most importantly, it
* also reports the instance types supported by this keyword.
*
* It is also used to build a digested form of schemas for array/object
* schema selections.
*
* @see SchemaDigester
* @see KeywordValidator
* @see ArraySchemaDigester
* @see ObjectSchemaDigester
*/
public interface Digester
{
/**
* Return the instance types handled by this digested form
*
* @return a set of {@link NodeType}s
*/
EnumSet supportedTypes();
/**
* Digest a schema into a simplified form
*
* @param schema the schema to digest
* @return the digested form
*/
JsonNode digest(final JsonNode schema);
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy