diff options
Diffstat (limited to 'app/Api/ActionApi.php')
-rw-r--r-- | app/Api/ActionApi.php | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/app/Api/ActionApi.php b/app/Api/ActionApi.php new file mode 100644 index 00000000..116742d8 --- /dev/null +++ b/app/Api/ActionApi.php @@ -0,0 +1,87 @@ +<?php + +namespace Kanboard\Api; + +use Kanboard\Core\Base; + +/** + * Action API controller + * + * @package Kanboard\Api + * @author Frederic Guillot + */ +class ActionApi extends Base +{ + public function getAvailableActions() + { + return $this->actionManager->getAvailableActions(); + } + + public function getAvailableActionEvents() + { + return $this->eventManager->getAll(); + } + + public function getCompatibleActionEvents($action_name) + { + return $this->actionManager->getCompatibleEvents($action_name); + } + + public function removeAction($action_id) + { + return $this->actionModel->remove($action_id); + } + + public function getActions($project_id) + { + return $this->actionModel->getAllByProject($project_id); + } + + public function createAction($project_id, $event_name, $action_name, array $params) + { + $values = array( + 'project_id' => $project_id, + 'event_name' => $event_name, + 'action_name' => $action_name, + 'params' => $params, + ); + + list($valid, ) = $this->actionValidator->validateCreation($values); + + if (! $valid) { + return false; + } + + // Check if the action exists + $actions = $this->actionManager->getAvailableActions(); + + if (! isset($actions[$action_name])) { + return false; + } + + // Check the event + $action = $this->actionManager->getAction($action_name); + + if (! in_array($event_name, $action->getEvents())) { + return false; + } + + $required_params = $action->getActionRequiredParameters(); + + // Check missing parameters + foreach ($required_params as $param => $value) { + if (! isset($params[$param])) { + return false; + } + } + + // Check extra parameters + foreach ($params as $param => $value) { + if (! isset($required_params[$param])) { + return false; + } + } + + return $this->actionModel->create($values); + } +} |