-
Notifications
You must be signed in to change notification settings - Fork 399
Roadmap
Not that simple. There are a few one-one relationships, but href
, for instance, is another matter. RFC 6570 is not an easy beast, and the current v4 hyper-schema draft expands upon it even more...
Right now, only the "current level" of the schema is checked. That is, with:
{
"properties": {
"p": { "type": "string" }
}
}
when starting from the root, only the correctness of properties
is checked, but the schema for p
is not.
Validating all of the schema at once instead unfortunately requires quite a lot of changes.
Right now, there is SchemaURIs
, KeywordRegistries
and even BuiltinSchemas
. This is rather messy. Unify all this in a nicer way.
After some discussion on https://github.com/fge/json-schema-validator/issues/28, this could be an example API:
MetaSchema mySchema = MetaSchema.basedOn(BuiltinSchemas.DRAFTV3_HYPERSCHEMA)
.withURI("your://schema/uri#").addKeyword("indexed", NodeType.BOOLEAN).build();
// Create JsonSchemaFactory with this new schema, make it the default (second argument
// to .addMetaSchema() is true)
JsonSchemaFactory factory = JsonSchemaFactory.builder().addMetaSchema(mySchema, true).build();
The idea would be to have two versions of .addKeyword
to a (yet non existing) MetaSchema.Builder
class:
-
.addKeyword(String keyword, NodeType first, NodeType... other)
: add a keyword with only simple syntax checking (the possible types arefirst
orother
); -
.addKeyword(Keyword keyword)
: add a full-fledged keyword.
Not necessarily in order!
- Right now, the
.addRedirection()
method ofJsonSchemaFactory
only knows how to redirect fully qualified URIs to schemas. Allow to redirect full paths as well. - Revamp URI handling in general by introducing the notion of a scope.
When reporting error messages, right now we only mention the keyword causing the failure. JSON Schema has title and description, but right now these are completely ignored (except at the syntax checking level).
On the other hand, since the implementation is purely server side, this feature may be done without. And the problem would then be to transmit these informations down the path (in ValidationContext
?), and insert them in messages.
Right now, when a schema is fetched from any URI, it is cached permanently until the application shuts down. This is inappropriate in a good number of usage scenarios (for instance, HTTP with an expiry time of 0).
Extend/replace URIDownloader
to account for this.
ehcache seems to be the most likely candidate, however it is far from being simple: ideally, both keys and values would have to implement Serializable. Ugh.