ZF2 Module for automating validation of incoming input.
Allows the following:
- Defining named input filters.
- Mapping named input filters to named controller services.
- Returning an
ApiProblemResponse
with validation error messages on invalid input.
Please see the composer.json file.
Run the following composer
command:
$ composer require "zfcampus/zf-content-validation:~1.0-dev"
Alternately, manually add the following to your composer.json
, in the require
section:
"require": {
"zfcampus/zf-content-validation": "~1.0-dev"
}
And then run composer update
to ensure the module is installed.
Finally, add the module name to your project's config/application.config.php
under the modules
key:
return array(
/* ... */
'modules' => array(
/* ... */
'ZF\ContentValidation',
),
/* ... */
);
This module utilizes two user level configuration keys zf-content-validation
and also
input_filter_specs
(named such that this functionality can be moved into ZF2 in the future).
The zf-content-validation
key is a mapping between controller service names as the key, and the
value being an array of mappings that determine which HTTP method to respond to and what input
filter to map to for the given request. The keys for the mapping can either be an HTTP method that
accepts a request body (i.e., POST
, PUT
, PATCH
, or DELETE
), or it can be the word
input_filter
. The value assigned for the input_filter
key will be used in the case that no input
filter is configured for the current HTTP request method.
Example where there is a default as well as a GET filter:
'zf-content-validation' => array(
'Application\Controller\HelloWorld' => array(
'input_filter' => 'Application\Controller\HelloWorld\Validator',
'POST' => 'Application\Controller\HelloWorld\CreationValidator',
),
),
In the above example, the Application\Controller\HelloWorld\Validator
service will be selected for
PATCH
, PUT
, or DELETE
requests, while the Application\Controller\HelloWorld\CreationValidator
will be selected for POST
requests.
input_filter_spec
is for configuration-driven creation of input filters. The keys for this array
will be a unique name, but more often based off the service name it is mapped to under the
zf-content-validation
key. The values will be an input filter configuration array, as is
described in the ZF2 manual section on input
filters.
Example:
'input_filter_specs' => array(
'Application\Controller\HelloWorldGet' => array(
0 => array(
'name' => 'name',
'required' => true,
'filters' => array(
0 => array(
'name' => 'Zend\Filter\StringTrim',
'options' => array(),
),
),
'validators' => array(),
'description' => 'Hello to name',
'allow_empty' => false,
'continue_if_empty' => false,
),
),
The following configuration is defined by the module in order to function within a ZF2 application.
'input_filters' => array(
'abstract_factories' => array(
'ZF\ContentValidation\InputFilter\InputFilterAbstractServiceFactory',
),
),
'service_manager' => array(
'factories' => array(
'ZF\ContentValidation\ContentValidationListener' => 'ZF\ContentValidation\ContentValidationListenerFactory',
),
),
'validators' => array(
'factories' => array(
'ZF\ContentValidation\Validator\DbRecordExists' => 'ZF\ContentValidation\Validator\Db\RecordExistsFactory',
'ZF\ContentValidation\Validator\DbNoRecordExists' => 'ZF\ContentValidation\Validator\Db\NoRecordExistsFactory',
),
),
This listener is attached to the MvcEvent::EVENT_ROUTE
event at priority -650
. Its purpose is
to utilize the zf-content-validation
configuration in order to determine if the current request's
selected controller service name has a configured input filter. If it does, it will traverse the
mappings from the configuration file to create the appropriate input filter (from configuration or
the Zend Framework 2 input filter plugin manager) in order to validate the incoming data. This
particular listener utilizes the data from the zf-content-negotiation
data container in order to
get the deserialized content body parameters.
This plugin is available to Zend Framework 2 controllers. When invoked ($this->getInputFilter()
or
$this->plugin('getinputfilter')->__invoke()
), it returns whatever is in the MVC event parameter
ZF\ContentValidation\InputFilter
, returning null for any value that is not an implementation of
Zend\InputFilter\InputFilter
.
This abstract factory is responsible for creating and returning an appropriate input filter given
a name and the configuration from the top-level key input_filter_specs
. It is registered with
Zend\InputFilter\InputFilterPluginManager
.