NAME
JSON::Schema::Modern::Vocabulary - Base role for JSON Schema vocabulary classes
VERSION
version 0.516
SYNOPSIS
package MyApp::Vocabulary::Awesome;
use Moo::Role;
with 'JSON::Schema::Modern::Vocabulary';
DESCRIPTION
This package is the role which all all vocabulary classes for JSON::Schema::Modern must compose, describing the basic structure expected of a vocabulary class.
User-defined custom vocabularies are not supported at this time.
ATTRIBUTES
METHODS
vocabulary
The canonical URI describing the vocabulary, as described in JSON Schema Core Meta-specification, section 8.1.2. Must be implemented by the composing class. May require the specification_version
from the JSON::Schema::Modern object (or the spec_version
field from the $state
object) as an argument.
keywords
The list of keywords defined by the vocabulary. Must be implemented by the composing class.
traverse
Traverses a subschema. Callers are expected to establish a new $state
scope.
traverse_subschema
Recursively traverses the schema at the current keyword.
traverse_array_schemas
Recursively traverses the list of subschemas at the current keyword.
traverse_object_schemas
Recursively traverses the (subschema) values of the object at the current keyword.
traverse_property_schema
Recursively traverses the subschema under one property of the object at the current keyword.
eval
Evaluates a subschema. Callers are expected to establish a new $state
scope.
SUPPORT
Bugs may be submitted through https://github.com/karenetheridge/JSON-Schema-Modern/issues.
I am also usually active on irc, as 'ether' at irc.perl.org
and irc.libera.chat
.
AUTHOR
Karen Etheridge <ether@cpan.org>
COPYRIGHT AND LICENCE
This software is copyright (c) 2020 by Karen Etheridge.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.