diff options
author | Frederic Guillot <fred@kanboard.net> | 2016-09-19 21:28:11 -0400 |
---|---|---|
committer | Frederic Guillot <fred@kanboard.net> | 2016-09-19 21:28:11 -0400 |
commit | a65941eadb3ddcec93132006c885106a6aa4cb9b (patch) | |
tree | f2375037d55335259e0644c5e1ae3670b2499607 /app/Action | |
parent | a2fd6525a0f627451380997e2859992b64c8181f (diff) |
Add new automatic action to close task based on date moved
Diffstat (limited to 'app/Action')
-rw-r--r-- | app/Action/TaskCloseNoActivityColumn.php | 2 | ||||
-rw-r--r-- | app/Action/TaskCloseNotMovedColumn.php | 96 |
2 files changed, 97 insertions, 1 deletions
diff --git a/app/Action/TaskCloseNoActivityColumn.php b/app/Action/TaskCloseNoActivityColumn.php index b2ee5224..e97aaac6 100644 --- a/app/Action/TaskCloseNoActivityColumn.php +++ b/app/Action/TaskCloseNoActivityColumn.php @@ -5,7 +5,7 @@ namespace Kanboard\Action; use Kanboard\Model\TaskModel; /** - * Close automatically a task after inactive and in an defined column + * Close automatically a task after inactive and in a defined column * * @package Kanboard\Action * @author Frederic Guillot diff --git a/app/Action/TaskCloseNotMovedColumn.php b/app/Action/TaskCloseNotMovedColumn.php new file mode 100644 index 00000000..cee5256b --- /dev/null +++ b/app/Action/TaskCloseNotMovedColumn.php @@ -0,0 +1,96 @@ +<?php + +namespace Kanboard\Action; + +use Kanboard\Model\TaskModel; + +/** + * Close automatically in a defined column after a certain amount of time + * + * @package Kanboard\Action + * @author Frederic Guillot + */ +class TaskCloseNotMovedColumn extends Base +{ + /** + * Get automatic action description + * + * @access public + * @return string + */ + public function getDescription() + { + return t('Close a task in a specific column when not moved during a given period'); + } + + /** + * Get the list of compatible events + * + * @access public + * @return array + */ + public function getCompatibleEvents() + { + return array(TaskModel::EVENT_DAILY_CRONJOB); + } + + /** + * Get the required parameter for the action (defined by the user) + * + * @access public + * @return array + */ + public function getActionRequiredParameters() + { + return array( + 'duration' => t('Duration in days'), + 'column_id' => t('Column') + ); + } + + /** + * Get the required parameter for the event + * + * @access public + * @return string[] + */ + public function getEventRequiredParameters() + { + return array('tasks'); + } + + /** + * Execute the action (close the task) + * + * @access public + * @param array $data Event data dictionary + * @return bool True if the action was executed or false when not executed + */ + public function doAction(array $data) + { + $results = array(); + $max = $this->getParam('duration') * 86400; + + foreach ($data['tasks'] as $task) { + $duration = time() - $task['date_moved']; + + if ($duration > $max && $task['column_id'] == $this->getParam('column_id')) { + $results[] = $this->taskStatusModel->close($task['id']); + } + } + + return in_array(true, $results, true); + } + + /** + * Check if the event data meet the action condition + * + * @access public + * @param array $data Event data dictionary + * @return bool + */ + public function hasRequiredCondition(array $data) + { + return count($data['tasks']) > 0; + } +} |