Mercurial > hg > isophonics-drupal-site
diff vendor/consolidation/annotated-command/src/Hooks/Dispatchers/ValidateHookDispatcher.php @ 0:4c8ae668cc8c
Initial import (non-working)
author | Chris Cannam |
---|---|
date | Wed, 29 Nov 2017 16:09:58 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/vendor/consolidation/annotated-command/src/Hooks/Dispatchers/ValidateHookDispatcher.php Wed Nov 29 16:09:58 2017 +0000 @@ -0,0 +1,46 @@ +<?php + +namespace Consolidation\AnnotatedCommand\Hooks\Dispatchers; + +use Consolidation\AnnotatedCommand\AnnotationData; +use Consolidation\AnnotatedCommand\CommandData; +use Consolidation\AnnotatedCommand\CommandError; +use Consolidation\AnnotatedCommand\Hooks\HookManager; +use Consolidation\AnnotatedCommand\Hooks\ValidatorInterface; + +/** + * Call hooks + */ +class ValidateHookDispatcher extends HookDispatcher implements ValidatorInterface +{ + public function validate(CommandData $commandData) + { + $hooks = [ + HookManager::PRE_ARGUMENT_VALIDATOR, + HookManager::ARGUMENT_VALIDATOR, + HookManager::POST_ARGUMENT_VALIDATOR, + HookManager::PRE_COMMAND_HOOK, + HookManager::COMMAND_HOOK, + ]; + $validators = $this->getHooks($hooks, $commandData->annotationData()); + foreach ($validators as $validator) { + $validated = $this->callValidator($validator, $commandData); + if ($validated === false) { + return new CommandError(); + } + if (is_object($validated)) { + return $validated; + } + } + } + + protected function callValidator($validator, CommandData $commandData) + { + if ($validator instanceof ValidatorInterface) { + return $validator->validate($commandData); + } + if (is_callable($validator)) { + return $validator($commandData); + } + } +}