2014-10-22 19:59:09 +02:00
|
|
|
#!/usr/bin/env php
|
|
|
|
<?php
|
|
|
|
|
|
|
|
require __DIR__.'/app/common.php';
|
|
|
|
|
|
|
|
use Core\Cli;
|
|
|
|
use Core\Tool;
|
|
|
|
use Model\Config;
|
|
|
|
use Model\Task;
|
2014-11-23 20:13:38 +01:00
|
|
|
use Model\TaskFinder;
|
|
|
|
use Model\TaskExport;
|
2014-10-22 19:59:09 +02:00
|
|
|
use Model\Notification;
|
|
|
|
|
|
|
|
$config = new Config($registry);
|
2014-11-23 20:13:38 +01:00
|
|
|
$config->setupTranslations();
|
|
|
|
$config->setupTimezone();
|
2014-10-22 19:59:09 +02:00
|
|
|
|
|
|
|
// Setup CLI
|
|
|
|
$cli = new Cli;
|
|
|
|
|
|
|
|
// Usage
|
|
|
|
$cli->register('help', function() {
|
|
|
|
echo 'Kanboard command line interface'.PHP_EOL.'==============================='.PHP_EOL.PHP_EOL;
|
|
|
|
echo '- Task export to stdout (CSV format): '.$GLOBALS['argv'][0].' export-csv <project_id> <start_date> <end_date>'.PHP_EOL;
|
|
|
|
echo '- Send notifications for due tasks: '.$GLOBALS['argv'][0].' send-notifications-due-tasks'.PHP_EOL;
|
|
|
|
});
|
|
|
|
|
|
|
|
// CSV Export
|
|
|
|
$cli->register('export-csv', function() use ($cli, $registry) {
|
|
|
|
|
|
|
|
if ($GLOBALS['argc'] !== 5) {
|
|
|
|
$cli->call($cli->default_command);
|
|
|
|
}
|
|
|
|
|
|
|
|
$project_id = $GLOBALS['argv'][2];
|
|
|
|
$start_date = $GLOBALS['argv'][3];
|
|
|
|
$end_date = $GLOBALS['argv'][4];
|
|
|
|
|
2014-11-23 20:13:38 +01:00
|
|
|
$taskExport = new TaskExport($registry);
|
|
|
|
$data = $taskExport->export($project_id, $start_date, $end_date);
|
2014-10-22 19:59:09 +02:00
|
|
|
|
|
|
|
if (is_array($data)) {
|
|
|
|
Tool::csv($data);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// Send notification for tasks due
|
|
|
|
$cli->register('send-notifications-due-tasks', function() use ($cli, $registry) {
|
|
|
|
|
|
|
|
$notificationModel = new Notification($registry);
|
2014-11-23 20:13:38 +01:00
|
|
|
$taskModel = new TaskFinder($registry);
|
2014-10-22 19:59:09 +02:00
|
|
|
$tasks = $taskModel->getOverdueTasks();
|
|
|
|
|
|
|
|
// Group tasks by project
|
|
|
|
$projects = array();
|
|
|
|
|
|
|
|
foreach ($tasks as $task) {
|
|
|
|
$projects[$task['project_id']][] = $task;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Send notifications for each project
|
|
|
|
foreach ($projects as $project_id => $project_tasks) {
|
|
|
|
|
|
|
|
$users = $notificationModel->getUsersList($project_id);
|
|
|
|
|
|
|
|
$notificationModel->sendEmails(
|
|
|
|
'notification_task_due',
|
|
|
|
$users,
|
|
|
|
array('tasks' => $project_tasks, 'project' => $project_tasks[0]['project_name'])
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
$cli->execute();
|