Skip to content
This repository has been archived by the owner on Jan 31, 2020. It is now read-only.

Ensure validators config is honored in non-zend-mvc contexts #168

Conversation

weierophinney
Copy link
Member

@weierophinney weierophinney commented May 16, 2017

Per a forum post the validators config key is not honored currently unless the application is within a zend-mvc context. This is due to the fact that Zend\Validator\Module wires configuration for the Zend\ModuleManager\Listener\ServiceListener in order to push merged service configuration into the plugin during bootstrap; no similar logic is available when not in a zend-mvc context, however.

This patch fixes that situation by modifying the ValidatorPluginManagerFactory to do the following:

  • If a ServiceListener service exists, it returns the plugin manager immediately (old behavior).
  • Otherwise, it checks for the config service, and, if found, a validators key with an array value. When found, it feeds that value to a Zend\ServiceManager\Config instance and uses that to configure the plugin manager before returning it.

Per https://discourse.zendframework.com/t/validatormanager-not-calling-custom-validator-factory/109/5?u=matthew
the `validators` config key is not honored currently unless the
application is within a zend-mvc context. This is due to the fact that
`Zend\Validator\Module` wires configuration for the
`Zend\ModuleManager\Listener\ServiceListener` in order to push merged
service configuration into the plugin during bootstrap; no similar logic
is available when not in a zend-mvc context, however.

This patch fixes that situation by modifying the
`ValidatorPluginManagerFactory` to do the following:

- If a `ServiceListener` service exists, it returns the plugin manager
  immediately (old behavior).
- Otherwise, it checks for the `config` service, and, if found, a
  `validators` key with an array value. When found, it feeds that value
  to a `Zend\ServiceManager\Config` instance and uses that to configure
  the plugin manager before returning it.
…e name

Doesn't affect tests, but it removes a WTF.
- No ValidatorInterface instance was needed for last two test cases
Copy link
Member

@froschdesign froschdesign left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM! 👍

weierophinney added a commit that referenced this pull request May 17, 2017
weierophinney added a commit that referenced this pull request May 17, 2017
@weierophinney weierophinney merged commit e29ddaf into zendframework:master May 17, 2017
weierophinney added a commit that referenced this pull request May 17, 2017
@weierophinney weierophinney deleted the hotfix/validators-service-config branch May 17, 2017 21:01
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants