<?php /** * @link http://github.com/zendframework/zend-validator for the canonical source repository * @copyright Copyright (c) 2005-2016 Zend Technologies USA Inc. (http://www.zend.com) * @license http://framework.zend.com/license/new-bsd New BSD License */ namespace Zend\Validator; use Interop\Container\ContainerInterface; use Zend\ServiceManager\Config; use Zend\ServiceManager\FactoryInterface; use Zend\ServiceManager\ServiceLocatorInterface; class ValidatorPluginManagerFactory implements FactoryInterface { /** * zend-servicemanager v2 support for invocation options. * * @param array */ protected $creationOptions; /** * {@inheritDoc} * * @return ValidatorPluginManager */ public function __invoke(ContainerInterface $container, $name, array $options = null) { $pluginManager = new ValidatorPluginManager($container, $options ?: []); // If this is in a zend-mvc application, the ServiceListener will inject // merged configuration during bootstrap. if ($container->has('ServiceListener')) { return $pluginManager; } // If we do not have a config service, nothing more to do if (! $container->has('config')) { return $pluginManager; } $config = $container->get('config'); // If we do not have validators configuration, nothing more to do if (! isset($config['validators']) || ! is_array($config['validators'])) { return $pluginManager; } // Wire service configuration for validators (new Config($config['validators']))->configureServiceManager($pluginManager); return $pluginManager; } /** * {@inheritDoc} * * @return ValidatorPluginManager */ public function createService(ServiceLocatorInterface $container, $name = null, $requestedName = null) { return $this($container, $requestedName ?: ValidatorPluginManager::class, $this->creationOptions); } /** * zend-servicemanager v2 support for invocation options. * * @param array $options * @return void */ public function setCreationOptions(array $options) { $this->creationOptions = $options; } }