configure(['shared_by_default' => false]); } else { $plugins->setShareByDefault(false); } } static::$plugins = $plugins; } /** * Get plugin manager for locating validators * * @return ValidatorPluginManager */ public static function getPluginManager() { if (! static::$plugins instanceof ValidatorPluginManager) { $plugins = new ValidatorPluginManager(new ServiceManager()); static::setPluginManager($plugins); return $plugins; } return static::$plugins; } /** * @param mixed $value * @param class-string $classBaseName * @param array $options OPTIONAL associative array of options to pass as * the sole argument to the validator constructor. * @return bool * @throws Exception\InvalidArgumentException For an invalid $options argument. */ public static function execute($value, $classBaseName, array $options = []) { if ($options && array_values($options) === $options) { throw new Exception\InvalidArgumentException( 'Invalid options provided via $options argument; must be an associative array' ); } $plugins = static::getPluginManager(); $validator = $plugins->get($classBaseName, $options); return $validator->isValid($value); } }