NAME

JSON::Schema::Modern::Vocabulary - Base role for JSON Schema vocabulary classes

VERSION

version 0.519

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.