NAME
Data::Schema::Manual::Plugin - Writing plugins for Data::Schema
OVERVIEW
This document is explains how to write plugins for Data::Schema.
INTRODUCTION
Any object can become a plugin as long as it satisfies these requirements.
1. It has a validator([$validator]) method to retrieve/set the validator property.
2. has handle_*() methods according to which functionalities it wants to supply.
HANDLE_*() METHOD CONVENTION
The convention for handle_*() methods is to return 0 if fail, 1 if succeed, or -1 if decline. If a plugin decline to handle some event, the next plugin in the list will be tried.
AVAILABLE HANDLE_*() METHODS
handle_unknown_type($type)
This is called by DS in the validation process when encountering an unknown type to give a chance for plugins to load new types. Used for example by DSP::LoadSchema::YAMLFile to load schemas from YAML files.
handle_type($data, $attr_hashes)
This is for type handler. Called by DS's validate() to validate a type. See the implementation in, for example, DST::Base.
handle_pre_check_attrs($data)
This is for type handler. Called by DST::Base's handle_type() method to allow subclass type handlers to do some checks before evaluating type attributes.
handle_attr_NAME($data, $arg)
This is for type handler. Called by DST::Base's handle_type() method to allow subclass type handlers to do attribute checking. For example, if attribute min is encountered in the schema, handle_attr_min will be called.
DIFFERENCES FROM TYPE HANDLER
Type handler can be thought of as yet another plugin. The differences are:
1. It is registered via $validator->register_type() instead of $validator->register_plugin().
2. It will only be involved in type checking during validation process. Specifically it will only handle:
handle_pre_check_attrs()
handle_type()
handle_attr_*()
3. You also need to supply cmp().
USING YOUR NEW PLUGIN
To use your new plugin, register it via:
$validator->register_plugin('Your::Class');
or
$validator->register_plugin($your_obj);
SEE ALSO
AUTHOR
Steven Haryanto, <steven at masterweb.net>
COPYRIGHT & LICENSE
Copyright 2009 Steven Haryanto, all rights reserved.
This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself.